diff options
| author | Gregory P. Smith <greg@krypto.org> | 2019-05-06 17:54:06 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-05-06 17:54:06 -0400 | 
| commit | 2cc0223f43a1ffd59c887a73e2b0ce5202f3be90 (patch) | |
| tree | 15fdf06b495c6c94644ce79c2684ebfe912e6cbf /Lib/test/test_httplib.py | |
| parent | 7b3a028c357dcc76b5aff7297e7c8052f897afb5 (diff) | |
| download | cpython-git-2cc0223f43a1ffd59c887a73e2b0ce5202f3be90.tar.gz | |
bpo-35925: Skip SSL tests that fail due to weak external certs. (GH-13124)
Modern Linux distros such as Debian Buster have default OpenSSL system
configurations that reject connections to servers with weak certificates
by default.  This causes our test suite run with external networking
resources enabled to skip these tests when they encounter such a failure.
Fixing the network servers is a separate issue.
Diffstat (limited to 'Lib/test/test_httplib.py')
| -rw-r--r-- | Lib/test/test_httplib.py | 25 | 
1 files changed, 21 insertions, 4 deletions
| diff --git a/Lib/test/test_httplib.py b/Lib/test/test_httplib.py index 65914616c7..968cbd86a1 100644 --- a/Lib/test/test_httplib.py +++ b/Lib/test/test_httplib.py @@ -4,6 +4,7 @@ import io  import itertools  import os  import array +import re  import socket  import threading @@ -1619,14 +1620,30 @@ class HTTPSTest(TestCase):          # We feed the server's cert as a validating cert          import ssl          support.requires('network') -        with support.transient_internet('self-signed.pythontest.net'): +        selfsigned_pythontestdotnet = 'self-signed.pythontest.net' +        with support.transient_internet(selfsigned_pythontestdotnet):              context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT)              self.assertEqual(context.verify_mode, ssl.CERT_REQUIRED)              self.assertEqual(context.check_hostname, True)              context.load_verify_locations(CERT_selfsigned_pythontestdotnet) -            h = client.HTTPSConnection('self-signed.pythontest.net', 443, context=context) -            h.request('GET', '/') -            resp = h.getresponse() +            try: +                h = client.HTTPSConnection(selfsigned_pythontestdotnet, 443, +                                           context=context) +                h.request('GET', '/') +                resp = h.getresponse() +            except ssl.SSLError as ssl_err: +                ssl_err_str = str(ssl_err) +                # In the error message of [SSL: CERTIFICATE_VERIFY_FAILED] on +                # modern Linux distros (Debian Buster, etc) default OpenSSL +                # configurations it'll fail saying "key too weak" until we +                # address https://bugs.python.org/issue36816 to use a proper +                # key size on self-signed.pythontest.net. +                if re.search(r'(?i)key.too.weak', ssl_err_str): +                    raise unittest.SkipTest( +                        f'Got {ssl_err_str} trying to connect ' +                        f'to {selfsigned_pythontestdotnet}. ' +                        'See https://bugs.python.org/issue36816.') +                raise              server_string = resp.getheader('server')              resp.close()              h.close() | 
