aboutsummaryrefslogtreecommitdiffstats
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
parent139cf462ca0126d6ed161a4b32e6b6c889c77318 (diff)
downloadcryptography-fb8adfcb2f0a67519ee81cad0c50d2e359ff3a20.tar.gz
cryptography-fb8adfcb2f0a67519ee81cad0c50d2e359ff3a20.tar.bz2
cryptography-fb8adfcb2f0a67519ee81cad0c50d2e359ff3a20.zip
Use raw vector files
-rw-r--r--dev-requirements.txt3
-rw-r--r--tests/test_fernet.py56
-rw-r--r--tests/vectors/fernet/generate.json9
-rw-r--r--tests/vectors/fernet/verify.json9
-rw-r--r--tox.ini3
5 files changed, 59 insertions, 21 deletions
diff --git a/dev-requirements.txt b/dev-requirements.txt
index 752517dd..530ada91 100644
--- a/dev-requirements.txt
+++ b/dev-requirements.txt
@@ -1,6 +1,7 @@
+coverage
flake8
+iso8601
pretend
pytest
-coverage
sphinx
tox
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
diff --git a/tests/vectors/fernet/generate.json b/tests/vectors/fernet/generate.json
new file mode 100644
index 00000000..d1f3e083
--- /dev/null
+++ b/tests/vectors/fernet/generate.json
@@ -0,0 +1,9 @@
+[
+ {
+ "token": "gAAAAAAdwJ6wAAECAwQFBgcICQoLDA0ODy021cpGVWKZ_eEwCGM4BLLF_5CV9dOPmrhuVUPgJobwOz7JcbmrR64jVmpU4IwqDA==",
+ "now": "1985-10-26T01:20:00-07:00",
+ "iv": [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15],
+ "src": "hello",
+ "secret": "cw_0x689RpI-jtRR7oE8h_eQsKImvJapLeSbXpwF4e4="
+ }
+]
diff --git a/tests/vectors/fernet/verify.json b/tests/vectors/fernet/verify.json
new file mode 100644
index 00000000..08c480f5
--- /dev/null
+++ b/tests/vectors/fernet/verify.json
@@ -0,0 +1,9 @@
+[
+ {
+ "token": "gAAAAAAdwJ6wAAECAwQFBgcICQoLDA0ODy021cpGVWKZ_eEwCGM4BLLF_5CV9dOPmrhuVUPgJobwOz7JcbmrR64jVmpU4IwqDA==",
+ "now": "1985-10-26T01:20:01-07:00",
+ "ttl_sec": 60,
+ "src": "hello",
+ "secret": "cw_0x689RpI-jtRR7oE8h_eQsKImvJapLeSbXpwF4e4="
+ }
+]
diff --git a/tox.ini b/tox.ini
index 92bcb75b..57b42412 100644
--- a/tox.ini
+++ b/tox.ini
@@ -3,9 +3,10 @@ envlist = py26,py27,pypy,py32,py33,docs,pep8
[testenv]
deps =
- pytest
coverage
+ iso8601
pretend
+ pytest
commands =
coverage run --source=cryptography/,tests/ -m pytest
coverage report -m --fail-under 100