diff options
| author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2017-09-26 10:23:24 +0800 | 
|---|---|---|
| committer | Alex Gaynor <alex.gaynor@gmail.com> | 2017-09-25 22:23:24 -0400 | 
| commit | 72c92f5ed1a3fe1b5196e0247bbe4cbe5e93c1a7 (patch) | |
| tree | 2d7c2ddc1174a8185ac1a0d13b4189ae1b70b3ad /tests/x509/test_x509.py | |
| parent | 7bb0210ef9e4cd7c822ea3864bd7b18f3877c24b (diff) | |
| download | cryptography-72c92f5ed1a3fe1b5196e0247bbe4cbe5e93c1a7.tar.gz cryptography-72c92f5ed1a3fe1b5196e0247bbe4cbe5e93c1a7.tar.bz2 cryptography-72c92f5ed1a3fe1b5196e0247bbe4cbe5e93c1a7.zip | |
both parse and encode the ASN1 string type for Name attributes (#3896)
* both parse and encode the ASN1 string type for Name attributes
Previously cryptography encoded everything (except country names) as
UTF8String. This caused problems with chain building in libraries like
NSS where the subject and issuer are expected to match byte-for-byte.
With this change we now parse and store the ASN1 string type as a
private _type in NameAttribute. We then use this to encode when issuing
a new certificate. This allows the CertificateBuilder to properly
construct an identical issuer and fixes the issue with NSS.
* make the sentinel private too
Diffstat (limited to 'tests/x509/test_x509.py')
| -rw-r--r-- | tests/x509/test_x509.py | 58 | 
1 files changed, 58 insertions, 0 deletions
| diff --git a/tests/x509/test_x509.py b/tests/x509/test_x509.py index 06aef666..0ce0a632 100644 --- a/tests/x509/test_x509.py +++ b/tests/x509/test_x509.py @@ -28,6 +28,7 @@ from cryptography.hazmat.primitives.asymmetric import dsa, ec, padding, rsa  from cryptography.hazmat.primitives.asymmetric.utils import (      decode_dss_signature  ) +from cryptography.x509.name import _ASN1Type  from cryptography.x509.oid import (      AuthorityInformationAccessOID, ExtendedKeyUsageOID, ExtensionOID,      NameOID, SignatureAlgorithmOID @@ -1496,6 +1497,43 @@ class TestRSACertificateRequest(object):              x509.DNSName(b"cryptography.io"),          ] +    def test_build_cert_private_type_encoding(self, backend): +        issuer_private_key = RSA_KEY_2048.private_key(backend) +        subject_private_key = RSA_KEY_2048.private_key(backend) +        not_valid_before = datetime.datetime(2002, 1, 1, 12, 1) +        not_valid_after = datetime.datetime(2030, 12, 31, 8, 30) +        name = x509.Name([ +            x509.NameAttribute( +                NameOID.STATE_OR_PROVINCE_NAME, u'Texas', +                _ASN1Type.PrintableString), +            x509.NameAttribute(NameOID.LOCALITY_NAME, u'Austin'), +            x509.NameAttribute( +                NameOID.COMMON_NAME, u'cryptography.io', _ASN1Type.IA5String), +        ]) +        builder = x509.CertificateBuilder().serial_number( +            777 +        ).issuer_name( +            name +        ).subject_name( +            name +        ).public_key( +            subject_private_key.public_key() +        ).not_valid_before( +            not_valid_before +        ).not_valid_after(not_valid_after) +        cert = builder.sign(issuer_private_key, hashes.SHA256(), backend) + +        for dn in (cert.subject, cert.issuer): +            assert dn.get_attributes_for_oid( +                NameOID.STATE_OR_PROVINCE_NAME +            )[0]._type == _ASN1Type.PrintableString +            assert dn.get_attributes_for_oid( +                NameOID.STATE_OR_PROVINCE_NAME +            )[0]._type == _ASN1Type.PrintableString +            assert dn.get_attributes_for_oid( +                NameOID.LOCALITY_NAME +            )[0]._type == _ASN1Type.UTF8String +      def test_build_cert_printable_string_country_name(self, backend):          issuer_private_key = RSA_KEY_2048.private_key(backend)          subject_private_key = RSA_KEY_2048.private_key(backend) @@ -3628,6 +3666,26 @@ class TestNameAttribute(object):          with pytest.raises(ValueError):              x509.NameAttribute(NameOID.ORGANIZATION_NAME, u'') +    def test_country_name_type(self): +        na = x509.NameAttribute(NameOID.COUNTRY_NAME, u"US") +        assert na._type == _ASN1Type.PrintableString +        na2 = x509.NameAttribute( +            NameOID.COUNTRY_NAME, u"US", _ASN1Type.IA5String +        ) +        assert na2._type == _ASN1Type.IA5String + +    def test_types(self): +        na = x509.NameAttribute(NameOID.COMMON_NAME, u"common") +        assert na._type == _ASN1Type.UTF8String +        na2 = x509.NameAttribute( +            NameOID.COMMON_NAME, u"common", _ASN1Type.IA5String +        ) +        assert na2._type == _ASN1Type.IA5String + +    def test_invalid_type(self): +        with pytest.raises(TypeError): +            x509.NameAttribute(NameOID.COMMON_NAME, u"common", "notanenum") +      def test_eq(self):          assert x509.NameAttribute(              x509.ObjectIdentifier('2.999.1'), u'value' | 
