aboutsummaryrefslogtreecommitdiffstats
path: root/tests/test_fernet.py
diff options
context:
space:
mode:
authorAlex Gaynor <alex.gaynor@gmail.com>2013-10-31 14:16:24 -0700
committerAlex Gaynor <alex.gaynor@gmail.com>2013-10-31 14:16:24 -0700
commitfb8adfcb2f0a67519ee81cad0c50d2e359ff3a20 (patch)
treec9dd8f8fc8fdf21fa0c313019c7da00bb6a005a1 /tests/test_fernet.py
parent139cf462ca0126d6ed161a4b32e6b6c889c77318 (diff)
downloadcryptography-fb8adfcb2f0a67519ee81cad0c50d2e359ff3a20.tar.gz
cryptography-fb8adfcb2f0a67519ee81cad0c50d2e359ff3a20.tar.bz2
cryptography-fb8adfcb2f0a67519ee81cad0c50d2e359ff3a20.zip
Use raw vector files
Diffstat (limited to 'tests/test_fernet.py')
-rw-r--r--tests/test_fernet.py56
1 files changed, 37 insertions, 19 deletions
diff --git a/tests/test_fernet.py b/tests/test_fernet.py
index 7bdfa3fa..382a232c 100644
--- a/tests/test_fernet.py
+++ b/tests/test_fernet.py
@@ -1,31 +1,49 @@
import base64
+import calendar
+import json
+import os
+
+import iso8601
+
+import pytest
import six
from cryptography.fernet import Fernet
+def json_parametrize(keys, path):
+ with open(path) as f:
+ data = json.load(f)
+ return pytest.mark.parametrize(keys, [
+ tuple([entry[k] for k in keys])
+ for entry in data
+ ])
+
+
class TestFernet(object):
- def test_generate(self):
- f = Fernet(base64.urlsafe_b64decode(
- b"cw_0x689RpI-jtRR7oE8h_eQsKImvJapLeSbXpwF4e4="
- ))
- token = f._encrypt_from_parts(
- b"hello",
- 499162800,
- b"".join(map(six.int2byte, range(16))),
+ @json_parametrize(
+ ("secret", "now", "iv", "src", "token"),
+ os.path.join(os.path.dirname(__file__), "vectors", "fernet", "generate.json")
+ )
+ def test_generate(self, secret, now, iv, src, token):
+ f = Fernet(base64.urlsafe_b64decode(secret.encode("ascii")))
+ actual_token = f._encrypt_from_parts(
+ src.encode("ascii"),
+ calendar.timegm(iso8601.parse_date(now).utctimetuple()),
+ b"".join(map(six.int2byte, iv))
)
- assert token == (b"gAAAAAAdwJ6wAAECAwQFBgcICQoLDA0ODy021cpGVWKZ_eEwCGM"
- b"4BLLF_5CV9dOPmrhuVUPgJobwOz7JcbmrR64jVmpU4IwqDA==")
+ assert actual_token == token
- def test_verify(self):
- f = Fernet(base64.urlsafe_b64decode(
- b"cw_0x689RpI-jtRR7oE8h_eQsKImvJapLeSbXpwF4e4="
- ))
+ @json_parametrize(
+ ("secret", "now", "src", "ttl_sec", "token"),
+ os.path.join(os.path.dirname(__file__), "vectors", "fernet", "verify.json")
+ )
+ def test_verify(self, secret, now, src, ttl_sec, token):
+ f = Fernet(base64.urlsafe_b64decode(secret.encode("ascii")))
payload = f.decrypt(
- (b"gAAAAAAdwJ6wAAECAwQFBgcICQoLDA0ODy021cpGVWKZ_eEwCGM4BLLF_5CV9dO"
- b"PmrhuVUPgJobwOz7JcbmrR64jVmpU4IwqDA=="),
- ttl=60,
- current_time=499162801
+ token.encode("ascii"),
+ ttl=ttl_sec,
+ current_time=calendar.timegm(iso8601.parse_date(now).utctimetuple())
)
- assert payload == b"hello"
+ assert payload == src