aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorPaul Kehrer <paul.l.kehrer@gmail.com>2016-12-05 07:12:43 -0600
committerAlex Gaynor <alex.gaynor@gmail.com>2016-12-05 08:12:43 -0500
commit0cf3690df91566c14c0c916f42af790de76e9e57 (patch)
tree0f441fcf5d12787f7ba614d651b5a7cf96de903a /tests
parent56aae486666c552dc8e0b3a864387b535807c3a7 (diff)
downloadcryptography-0cf3690df91566c14c0c916f42af790de76e9e57.tar.gz
cryptography-0cf3690df91566c14c0c916f42af790de76e9e57.tar.bz2
cryptography-0cf3690df91566c14c0c916f42af790de76e9e57.zip
friendly error if you put a date too far in the future on windows (#3279)
Diffstat (limited to 'tests')
-rw-r--r--tests/test_x509.py30
1 files changed, 30 insertions, 0 deletions
diff --git a/tests/test_x509.py b/tests/test_x509.py
index 5d334242..966cba6f 100644
--- a/tests/test_x509.py
+++ b/tests/test_x509.py
@@ -8,6 +8,7 @@ import binascii
import datetime
import ipaddress
import os
+import sys
import warnings
from pyasn1.codec.der import decoder
@@ -1524,6 +1525,35 @@ class TestCertificateBuilder(object):
builder.sign(private_key, hashes.SHA256(), backend)
+ @pytest.mark.skipif(sys.platform != "win32", reason="Requires windows")
+ @pytest.mark.parametrize(
+ ("not_valid_before", "not_valid_after"),
+ [
+ [datetime.datetime(1999, 1, 1), datetime.datetime(9999, 1, 1)],
+ [datetime.datetime(9999, 1, 1), datetime.datetime(9999, 12, 31)],
+ ]
+ )
+ @pytest.mark.requires_backend_interface(interface=RSABackend)
+ @pytest.mark.requires_backend_interface(interface=X509Backend)
+ def test_invalid_time_windows(self, not_valid_before, not_valid_after,
+ backend):
+ private_key = RSA_KEY_2048.private_key(backend)
+ builder = x509.CertificateBuilder().subject_name(x509.Name([
+ x509.NameAttribute(NameOID.COUNTRY_NAME, u'US'),
+ ])).issuer_name(x509.Name([
+ x509.NameAttribute(NameOID.COUNTRY_NAME, u'US'),
+ ])).public_key(
+ private_key.public_key()
+ ).serial_number(
+ 777
+ ).not_valid_before(
+ not_valid_before
+ ).not_valid_after(
+ not_valid_after
+ )
+ with pytest.raises(ValueError):
+ builder.sign(private_key, hashes.SHA256(), backend)
+
@pytest.mark.requires_backend_interface(interface=RSABackend)
@pytest.mark.requires_backend_interface(interface=X509Backend)
def test_no_subject_name(self, backend):