diff options
| author | Gregory P. Smith <greg@mad-scientist.com> | 2010-01-03 02:06:07 (GMT) |
|---|---|---|
| committer | Gregory P. Smith <greg@mad-scientist.com> | 2010-01-03 02:06:07 (GMT) |
| commit | 9d3252154f99c8f229e12e4146ae322abf042450 (patch) | |
| tree | d406bfc6480798852edd68de7741f45561da2e71 /Lib/test/test_httplib.py | |
| parent | 79a3eb1058057185cb901b0f5f67fea05494e1fb (diff) | |
| download | cpython-9d3252154f99c8f229e12e4146ae322abf042450.zip cpython-9d3252154f99c8f229e12e4146ae322abf042450.tar.gz cpython-9d3252154f99c8f229e12e4146ae322abf042450.tar.bz2 | |
issue3972: HTTPConnection and HTTPSConnection now support a
source_address parameter.
Also cleans up an annotation in the socket documentation.
Diffstat (limited to 'Lib/test/test_httplib.py')
| -rw-r--r-- | Lib/test/test_httplib.py | 37 |
1 files changed, 35 insertions, 2 deletions
diff --git a/Lib/test/test_httplib.py b/Lib/test/test_httplib.py index cd54323..c0c12e7 100644 --- a/Lib/test/test_httplib.py +++ b/Lib/test/test_httplib.py @@ -3,7 +3,8 @@ import httplib import StringIO import socket -from unittest import TestCase +import unittest +TestCase = unittest.TestCase from test import test_support @@ -237,6 +238,38 @@ class OfflineTest(TestCase): def test_responses(self): self.assertEquals(httplib.responses[httplib.NOT_FOUND], "Not Found") + +class SourceAddressTest(TestCase): + def setUp(self): + self.serv = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + self.port = test_support.bind_port(self.serv) + self.source_port = test_support.find_unused_port() + self.serv.listen(5) + self.conn = None + + def tearDown(self): + if self.conn: + self.conn.close() + self.conn = None + self.serv.close() + self.serv = None + + def testHTTPConnectionSourceAddress(self): + self.conn = httplib.HTTPConnection(HOST, self.port, + source_address=('', self.source_port)) + self.conn.connect() + self.assertEqual(self.conn.sock.getsockname()[1], self.source_port) + + @unittest.skipIf(not hasattr(httplib, 'HTTPSConnection'), + 'httplib.HTTPSConnection not defined') + def testHTTPSConnectionSourceAddress(self): + self.conn = httplib.HTTPSConnection(HOST, self.port, + source_address=('', self.source_port)) + # We don't test anything here other the constructor not barfing as + # this code doesn't deal with setting up an active running SSL server + # for an ssl_wrapped connect() to actually return from. + + class TimeoutTest(TestCase): PORT = None @@ -294,7 +327,7 @@ class HTTPSTimeoutTest(TestCase): def test_main(verbose=None): test_support.run_unittest(HeaderTests, OfflineTest, BasicTest, TimeoutTest, - HTTPSTimeoutTest) + HTTPSTimeoutTest, SourceAddressTest) if __name__ == '__main__': test_main() |
