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()  | 
