More specific methods.

This commit is contained in:
Itamar Turner-Trauring 2022-04-06 11:31:26 -04:00
parent ab1297cdd6
commit 5a82ea880b

View File

@ -100,23 +100,34 @@ class PinningHTTPSValidation(AsyncTestCase):
self.addCleanup(self._port_assigner.tearDown) self.addCleanup(self._port_assigner.tearDown)
return AsyncTestCase.setUp(self) return AsyncTestCase.setUp(self)
def to_file(self, key_or_cert) -> FilePath: def _temp_file_with_data(self, data: bytes) -> FilePath:
""" """
Write the given key or cert to a temporary file on disk, return the Write data to temporary file, return its path.
path.
""" """
path = self.mktemp() path = self.mktemp()
with open(path, "wb") as f: with open(path, "wb") as f:
if isinstance(key_or_cert, x509.Certificate): f.write(data)
data = key_or_cert.public_bytes(serialization.Encoding.PEM) return FilePath(path)
else:
data = key_or_cert.private_bytes( def cert_to_file(self, cert) -> FilePath:
"""
Write the given certificate to a temporary file on disk, return the
path.
"""
return self._temp_file_with_data(cert.public_bytes(serialization.Encoding.PEM))
def private_key_to_file(self, private_key) -> FilePath:
"""
Write the given key to a temporary file on disk, return the
path.
"""
return self._temp_file_with_data(
private_key.private_bytes(
encoding=serialization.Encoding.PEM, encoding=serialization.Encoding.PEM,
format=serialization.PrivateFormat.TraditionalOpenSSL, format=serialization.PrivateFormat.TraditionalOpenSSL,
encryption_algorithm=serialization.NoEncryption(), encryption_algorithm=serialization.NoEncryption(),
) )
f.write(data) )
return FilePath(path)
def generate_private_key(self): def generate_private_key(self):
"""Create a RSA private key.""" """Create a RSA private key."""
@ -197,7 +208,7 @@ class PinningHTTPSValidation(AsyncTestCase):
private_key = self.generate_private_key() private_key = self.generate_private_key()
certificate = self.generate_certificate(private_key) certificate = self.generate_certificate(private_key)
async with self.listen( async with self.listen(
self.to_file(private_key), self.to_file(certificate) self.private_key_to_file(private_key), self.cert_to_file(certificate)
) as url: ) as url:
response = await self.request(url, certificate) response = await self.request(url, certificate)
self.assertEqual(await response.content(), b"YOYODYNE") self.assertEqual(await response.content(), b"YOYODYNE")
@ -214,7 +225,7 @@ class PinningHTTPSValidation(AsyncTestCase):
certificate2 = self.generate_certificate(private_key2) certificate2 = self.generate_certificate(private_key2)
async with self.listen( async with self.listen(
self.to_file(private_key1), self.to_file(certificate1) self.private_key_to_file(private_key1), self.cert_to_file(certificate1)
) as url: ) as url:
with self.assertRaises(ResponseNeverReceived): with self.assertRaises(ResponseNeverReceived):
await self.request(url, certificate2) await self.request(url, certificate2)
@ -230,7 +241,7 @@ class PinningHTTPSValidation(AsyncTestCase):
certificate = self.generate_certificate(private_key, expires_days=-10) certificate = self.generate_certificate(private_key, expires_days=-10)
async with self.listen( async with self.listen(
self.to_file(private_key), self.to_file(certificate) self.private_key_to_file(private_key), self.cert_to_file(certificate)
) as url: ) as url:
response = await self.request(url, certificate) response = await self.request(url, certificate)
self.assertEqual(await response.content(), b"YOYODYNE") self.assertEqual(await response.content(), b"YOYODYNE")