aboutsummaryrefslogtreecommitdiffstats
path: root/tests/utils.py
diff options
context:
space:
mode:
authorDonald Stufft <donald@stufft.io>2013-10-18 17:35:07 -0700
committerDonald Stufft <donald@stufft.io>2013-10-18 17:35:07 -0700
commitf6c61eb4a475a8579885d015e54aa65b8528083b (patch)
treed2421ebcab14687d06104dd44bfec22a8a09244a /tests/utils.py
parentc1061753ef6a7276c33f76df954f7097c8b78303 (diff)
parent87cd0db396e157b3fb160b8b6fd770e2c661ace2 (diff)
downloadcryptography-f6c61eb4a475a8579885d015e54aa65b8528083b.tar.gz
cryptography-f6c61eb4a475a8579885d015e54aa65b8528083b.tar.bz2
cryptography-f6c61eb4a475a8579885d015e54aa65b8528083b.zip
Merge pull request #121 from reaperhulk/hash-saga-loaders
hash vector loader and tests (Hash Saga Part 2)
Diffstat (limited to 'tests/utils.py')
-rw-r--r--tests/utils.py35
1 files changed, 35 insertions, 0 deletions
diff --git a/tests/utils.py b/tests/utils.py
index 6b1cfd79..03b780f8 100644
--- a/tests/utils.py
+++ b/tests/utils.py
@@ -119,3 +119,38 @@ def load_openssl_vectors(vector_data):
"ciphertext": vector[4].encode("ascii"),
})
return vectors
+
+
+def load_hash_vectors(vector_data):
+ vectors = []
+
+ for line in vector_data:
+ line = line.strip()
+
+ if not line or line.startswith("#") or line.startswith("["):
+ continue
+
+ if line.startswith("Len"):
+ length = int(line.split(" = ")[1])
+ elif line.startswith("Msg"):
+ """
+ In the NIST vectors they have chosen to represent an empty
+ string as hex 00, which is of course not actually an empty
+ string. So we parse the provided length and catch this edge case.
+ """
+ msg = line.split(" = ")[1].encode("ascii") if length > 0 else b""
+ elif line.startswith("MD"):
+ md = line.split(" = ")[1]
+ # after MD is found the Msg+MD tuple is complete
+ vectors.append((msg, md))
+ else:
+ raise ValueError("Unknown line in hash vector")
+ return vectors
+
+
+def load_hash_vectors_from_file(filename):
+ base = os.path.join(
+ os.path.dirname(__file__), "primitives", "vectors"
+ )
+ with open(os.path.join(base, filename), "r") as vector_file:
+ return load_hash_vectors(vector_file)