1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
|
from duo_client.https_wrapper import CertValidatingHTTPSConnection
import unittest
from unittest import mock
import ssl
class TestSSLContextCreation(unittest.TestCase):
""" Test that the SSL context used to wrap sockets is configured correctly """
def test_no_ca_certs(self):
conn = CertValidatingHTTPSConnection('api-fakehost.duosecurity.com')
self.assertEqual(conn.default_ssl_context.verify_mode, ssl.CERT_NONE) # noqa: DUO122, testing insecure context
@mock.patch('ssl.SSLContext.load_verify_locations')
def test_with_ca_certs(self, mock_load):
mock_load.return_value = None
conn = CertValidatingHTTPSConnection('api-fakehost.duosecurity.com', ca_certs='cafilepath')
self.assertEqual(conn.default_ssl_context.verify_mode, ssl.CERT_REQUIRED)
mock_load.assert_called_with(cafile='cafilepath')
@mock.patch('ssl.SSLContext.load_cert_chain')
def test_with_certfile(self, mock_load):
mock_load.return_value = None
CertValidatingHTTPSConnection('api-fakehost.duosecurity.com', cert_file='certfilepath')
mock_load.assert_called_with('certfilepath', None)
def test_ssl2_ssl3_off(self):
conn = CertValidatingHTTPSConnection('api-fakehost.duosecurity.com')
self.assertEqual(conn.default_ssl_context.options & ssl.OP_NO_SSLv2, ssl.OP_NO_SSLv2)
self.assertEqual(conn.default_ssl_context.options & ssl.OP_NO_SSLv3, ssl.OP_NO_SSLv3)
@mock.patch('socket.socket.connect')
def test_server_hostname(self, mock_connect):
hostname = 'api-fakehost.duosecurity.com'
conn = CertValidatingHTTPSConnection(hostname)
conn.connect()
self.assertEqual(conn.sock.server_hostname, hostname)
@mock.patch('socket.socket.connect')
def test_server_hostname_with_port(self, mock_connect):
hostname = 'api-fakehost.duosecurity.com'
conn = CertValidatingHTTPSConnection(f'{hostname}:443')
conn.connect()
self.assertEqual(conn.sock.server_hostname, hostname)
|