diff options
author | Alex Gaynor <alex.gaynor@gmail.com> | 2015-12-23 21:25:00 -0500 |
---|---|---|
committer | Alex Gaynor <alex.gaynor@gmail.com> | 2015-12-23 21:25:00 -0500 |
commit | 8c52c203accd5fdb35fcdae33bbf3fa172c7879f (patch) | |
tree | f2e5d35a290c45f8b6f29b1e1cb76455edcbfb5e /tests/test_x509.py | |
parent | 6d99de1ba968215b6c8566738c3f5ff3b7ac3312 (diff) | |
parent | 7e75b620f1c63fcc6168fe611eafa97fd709121b (diff) | |
download | cryptography-8c52c203accd5fdb35fcdae33bbf3fa172c7879f.tar.gz cryptography-8c52c203accd5fdb35fcdae33bbf3fa172c7879f.tar.bz2 cryptography-8c52c203accd5fdb35fcdae33bbf3fa172c7879f.zip |
Merge pull request #2558 from reaperhulk/managing-memory-is-fun
fix a potential memory issue when retaining revoked certs from a CRL
Diffstat (limited to 'tests/test_x509.py')
-rw-r--r-- | tests/test_x509.py | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/tests/test_x509.py b/tests/test_x509.py index ae2746e3..ab4d6660 100644 --- a/tests/test_x509.py +++ b/tests/test_x509.py @@ -173,6 +173,20 @@ class TestCertificateRevocationList(object): # Check that len() works for CRLs. assert len(crl) == 12 + def test_revoked_cert_retrieval_retain_only_revoked(self, backend): + """ + This test attempts to trigger the crash condition described in + https://github.com/pyca/cryptography/issues/2557 + PyPy does gc at its own pace, so it will only be reliable on CPython. + """ + revoked = _load_cert( + os.path.join("x509", "custom", "crl_all_reasons.pem"), + x509.load_pem_x509_crl, + backend + )[11] + assert revoked.revocation_date == datetime.datetime(2015, 1, 1, 0, 0) + assert revoked.serial_number == 11 + def test_extensions(self, backend): crl = _load_cert( os.path.join("x509", "custom", "crl_ian_aia_aki.pem"), |