diff options
| author | Antoine Pitrou <solipsis@pitrou.net> | 2010-10-22 18:19:07 +0000 | 
|---|---|---|
| committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-10-22 18:19:07 +0000 | 
| commit | d532321f7ba2e23e4110f05331fee8beca736826 (patch) | |
| tree | 9383fb529fee0b92edc2a06e0435b7e8560cb1ec /Lib/test/test_urllib2net.py | |
| parent | 4ebfdf01bb128005842be322fc89457d527ff000 (diff) | |
| download | cpython-git-d532321f7ba2e23e4110f05331fee8beca736826.tar.gz | |
Issue #5639: Add a *server_hostname* argument to `SSLContext.wrap_socket`
in order to support the TLS SNI extension.  `HTTPSConnection` and
`urlopen()` also use this argument, so that HTTPS virtual hosts are now
supported.
Diffstat (limited to 'Lib/test/test_urllib2net.py')
| -rw-r--r-- | Lib/test/test_urllib2net.py | 33 | 
1 files changed, 29 insertions, 4 deletions
| diff --git a/Lib/test/test_urllib2net.py b/Lib/test/test_urllib2net.py index a4af01ae03..0a777c49b7 100644 --- a/Lib/test/test_urllib2net.py +++ b/Lib/test/test_urllib2net.py @@ -9,6 +9,10 @@ import socket  import urllib.error  import urllib.request  import sys +try: +    import ssl +except ImportError: +    ssl = None  TIMEOUT = 60  # seconds @@ -278,13 +282,34 @@ class TimeoutTest(unittest.TestCase):          self.assertEqual(u.fp.fp.raw._sock.gettimeout(), 60) +@unittest.skipUnless(ssl, "requires SSL support") +class HTTPSTests(unittest.TestCase): + +    def test_sni(self): +        # Checks that Server Name Indication works, if supported by the +        # OpenSSL linked to. +        # The ssl module itself doesn't have server-side support for SNI, +        # so we rely on a third-party test site. +        expect_sni = ssl.HAS_SNI +        with support.transient_internet("bob.sni.velox.ch"): +            u = urllib.request.urlopen("https://bob.sni.velox.ch/") +            contents = u.readall() +            if expect_sni: +                self.assertIn(b"Great", contents) +                self.assertNotIn(b"Unfortunately", contents) +            else: +                self.assertNotIn(b"Great", contents) +                self.assertIn(b"Unfortunately", contents) + +  def test_main():      support.requires("network")      support.run_unittest(AuthTests, -                              OtherNetworkTests, -                              CloseSocketTest, -                              TimeoutTest, -                              ) +                         HTTPSTests, +                         OtherNetworkTests, +                         CloseSocketTest, +                         TimeoutTest, +                         )  if __name__ == "__main__":      test_main() | 
