summaryrefslogtreecommitdiff
path: root/tests/debug_test.py
blob: 50da3d89ee1f23ebe86005de84291425eace850b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#! /usr/bin/env python
# -*- coding: utf-8 -*-
# vi:ts=4:et

from . import localhost
import pycurl
import unittest

from . import appmanager
from . import util

setup_module, teardown_module = appmanager.setup(('app', 8380))

class DebugTest(unittest.TestCase):
    def setUp(self):
        self.curl = util.DefaultCurl()
        self.debug_entries = []

    def tearDown(self):
        self.curl.close()

    def debug_function(self, t, b):
        self.debug_entries.append((t, b))

    def test_perform_get_with_debug_function(self):
        self.curl.setopt(pycurl.VERBOSE, 1)
        self.curl.setopt(pycurl.DEBUGFUNCTION, self.debug_function)
        self.curl.setopt(pycurl.URL, 'http://%s:8380/success' % localhost)
        sio = util.BytesIO()
        self.curl.setopt(pycurl.WRITEFUNCTION, sio.write)
        self.curl.perform()

        # Some checks with no particular intent
        self.check(0, util.b('Trying'))
        if util.pycurl_version_less_than(7, 24):
            self.check(0, util.b('connected'))
        else:
            self.check(0, util.b('Connected to %s' % localhost))
        self.check(0, util.b('port 8380'))
        # request
        self.check(2, util.b('GET /success HTTP/1.1'))
        # response
        self.check(1, util.b('HTTP/1.0 200 OK'))
        self.check(1, util.b('Content-Length: 7'))
        # result
        self.check(3, util.b('success'))

    # test for #210
    def test_debug_unicode(self):
        self.curl.setopt(pycurl.VERBOSE, 1)
        self.curl.setopt(pycurl.DEBUGFUNCTION, self.debug_function)
        self.curl.setopt(pycurl.URL, 'http://%s:8380/utf8_body' % localhost)
        sio = util.BytesIO()
        self.curl.setopt(pycurl.WRITEFUNCTION, sio.write)
        self.curl.perform()

        # 3 = response body
        search = util.b('\xd0\x94\xd1\x80\xd1\x83\xd0\xb6\xd0\xb1\xd0\xb0 \xd0\xbd\xd0\xb0\xd1\x80\xd0\xbe\xd0\xb4\xd0\xbe\xd0\xb2').decode('utf8')
        self.check(3, search.encode('utf8'))

    def check(self, wanted_t, wanted_b):
        for t, b in self.debug_entries:
            if t == wanted_t and wanted_b in b:
                return
        assert False, "%d: %s not found in debug entries\nEntries are:\n%s" % \
            (wanted_t, repr(wanted_b), repr(self.debug_entries))