11 from httplib2 import socks
12 from httplib2.test import miniserver
26 class FunctionalProxyHttpTest(unittest.TestCase):
29 raise nose.SkipTest('socks module unavailable')
31 raise nose.SkipTest('subprocess module unavailable')
33 # start a short-lived miniserver so we can get a likely port
35 self.httpd, self.proxyport = miniserver.start_server(
36 miniserver.ThisDirHandler)
38 self.httpd, self.port = miniserver.start_server(
39 miniserver.ThisDirHandler)
41 self.pidfile = tempfile.mktemp()
42 self.logfile = tempfile.mktemp()
43 fd, self.conffile = tempfile.mkstemp()
44 f = os.fdopen(fd, 'w')
45 our_cfg = tinyproxy_cfg % {'user': os.getlogin(),
46 'pidfile': self.pidfile,
47 'port': self.proxyport,
48 'logfile': self.logfile}
52 # TODO use subprocess.check_call when 2.4 is dropped
53 ret = subprocess.call(['tinyproxy', '-c', self.conffile])
54 self.assertEqual(0, ret)
56 if e.errno == errno.ENOENT:
57 raise nose.SkipTest('tinyproxy not available')
63 pid = int(open(self.pidfile).read())
64 os.kill(pid, signal.SIGTERM)
66 if e.errno == errno.ESRCH:
67 print '\n\n\nTinyProxy Failed to start, log follows:'
68 print open(self.logfile).read()
69 print 'end tinyproxy log\n\n\n'
71 map(os.unlink, (self.pidfile,
75 def testSimpleProxy(self):
76 proxy_info = httplib2.ProxyInfo(socks.PROXY_TYPE_HTTP,
77 'localhost', self.proxyport)
78 client = httplib2.Http(proxy_info=proxy_info)
80 response, body = client.request('http://localhost:%d/%s' %
82 self.assertEqual(response.status, 200)
83 self.assertEqual(body, open(os.path.join(miniserver.HERE, src)).read())
84 lf = open(self.logfile).read()
85 expect = ('Established connection to host "127.0.0.1" '
86 'using file descriptor')
87 self.assertTrue(expect in lf,
88 'tinyproxy did not proxy a request for miniserver')