123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- #
- # This file is part of pyasn1-modules software.
- #
- # Created by Russ Housley
- # Copyright (c) 2019, Vigil Security, LLC
- # License: http://snmplabs.com/pyasn1/license.html
- #
- import sys
- import unittest
- from pyasn1.codec.der.decoder import decode as der_decoder
- from pyasn1.codec.der.encoder import encode as der_encoder
- from pyasn1_modules import pem
- from pyasn1_modules import rfc5280
- from pyasn1_modules import rfc5990
- class RSAKEMTestCase(unittest.TestCase):
- pem_text = """\
- MEcGCyqGSIb3DQEJEAMOMDgwKQYHKIGMcQICBDAeMBkGCiuBBRCGSAksAQIwCwYJ
- YIZIAWUDBAIBAgEQMAsGCWCGSAFlAwQBBQ==
- """
- def setUp(self):
- self.asn1Spec = rfc5280.AlgorithmIdentifier()
- def testDerCodec(self):
- substrate = pem.readBase64fromText(self.pem_text)
- asn1Object, rest = der_decoder(substrate, asn1Spec=self.asn1Spec)
- self.assertFalse(rest)
- self.assertTrue(asn1Object.prettyPrint())
- self.assertEqual(substrate, der_encoder(asn1Object))
- self.assertEqual(rfc5990.id_rsa_kem, asn1Object['algorithm'])
- rsa_kem_p, rest = der_decoder(
- asn1Object['parameters'],
- asn1Spec=rfc5280.algorithmIdentifierMap[rfc5990.id_rsa_kem])
- self.assertFalse(rest)
- self.assertTrue(rsa_kem_p.prettyPrint())
- self.assertEqual(asn1Object['parameters'], der_encoder(rsa_kem_p))
- self.assertEqual(rfc5990.id_kem_rsa, rsa_kem_p['kem']['algorithm'])
- kem_rsa_p, rest = der_decoder(
- rsa_kem_p['kem']['parameters'],
- asn1Spec=rfc5280.algorithmIdentifierMap[rfc5990.id_kem_rsa])
- self.assertFalse(rest)
- self.assertTrue(kem_rsa_p.prettyPrint())
- self.assertEqual(
- rsa_kem_p['kem']['parameters'], der_encoder(kem_rsa_p))
- self.assertEqual(16, kem_rsa_p['keyLength'])
- self.assertEqual(
- rfc5990.id_kdf_kdf3, kem_rsa_p['keyDerivationFunction']['algorithm'])
- kdf_p, rest = der_decoder(
- kem_rsa_p['keyDerivationFunction']['parameters'],
- asn1Spec=rfc5280.algorithmIdentifierMap[rfc5990.id_kdf_kdf3])
- self.assertFalse(rest)
- self.assertTrue(kdf_p.prettyPrint())
- self.assertEqual(
- kem_rsa_p['keyDerivationFunction']['parameters'],
- der_encoder(kdf_p))
- def testOpenTypes(self):
- substrate = pem.readBase64fromText(self.pem_text)
- asn1Object, rest = der_decoder(
- substrate, asn1Spec=self.asn1Spec, decodeOpenTypes=True)
- self.assertFalse(rest)
- self.assertTrue(asn1Object.prettyPrint())
- self.assertEqual(substrate, der_encoder(asn1Object))
- self.assertEqual(rfc5990.id_rsa_kem, asn1Object['algorithm'])
- self.assertEqual(
- rfc5990.id_kem_rsa, asn1Object['parameters']['kem']['algorithm'])
- self.assertEqual(
- 16, asn1Object['parameters']['kem']['parameters']['keyLength'])
- suite = unittest.TestLoader().loadTestsFromModule(sys.modules[__name__])
- if __name__ == '__main__':
- result = unittest.TextTestRunner(verbosity=2).run(suite)
- sys.exit(not result.wasSuccessful())
|