-
Notifications
You must be signed in to change notification settings - Fork 2
/
scrypt_kdf_tests.ml
66 lines (60 loc) · 1.93 KB
/
scrypt_kdf_tests.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
let test_scrypt_kdf ~password ~salt ~n ~r ~p ~dk_len ~dk =
let open Cstruct in
let password = of_string password
and salt = of_string salt
and dk = to_string (of_hex dk) in
(fun () ->
let edk = Scrypt_kdf.scrypt_kdf ~password ~salt ~n ~r ~p ~dk_len in
let sedk = to_string edk in
Alcotest.check Alcotest.string "Scrypt test" sedk dk)
let scrypt_kdf_test1 =
test_scrypt_kdf
~password:""
~salt:""
~n:16
~r:1
~p:1
~dk_len:64l
~dk:"77d6576238657b203b19ca42c18a0497f16b4844e3074ae8dfdffa3fede21442fcd0069ded0948f8326a753a0fc81f17e8d3e0fb2e0d3628cf35e20c38d18906"
let scrypt_kdf_test2 =
test_scrypt_kdf
~password:"password"
~salt:"NaCl"
~n:1024
~r:8
~p:16
~dk_len:64l
~dk:"fdbabe1c9d3472007856e7190d01e9fe7c6ad7cbc8237830e77376634b3731622eaf30d92e22a3886ff109279d9830dac727afb94a83ee6d8360cbdfa2cc0640"
let scrypt_kdf_test3 =
test_scrypt_kdf
~password:"pleaseletmein"
~salt:"SodiumChloride"
~n:16384
~r:8
~p:1
~dk_len:64l
~dk:"7023bdcb3afd7348461c06cd81fd38ebfda8fbba904f8e3ea9b543f6545da1f2d5432955613f0fcf62d49705242a9af9e61e85dc0d651e40dfcf017b45575887"
let scrypt_kdf_test4 =
test_scrypt_kdf
~password:"pleaseletmein"
~salt:"SodiumChloride"
~n:1048576
~r:8
~p:1
~dk_len:64l
~dk:"2101cb9b6a511aaeaddbbe09cf70f881ec568d574a2ffd4dabe5ee9820adaa478e56fd8f4ba5d09ffa1c6d927c40f4c337304049e8a952fbcbf45c6fa77a41a4"
let scrypt_kdf_tests () =
let tests = [
"Test Case 1", `Quick, scrypt_kdf_test1;
"Test Case 2", `Quick, scrypt_kdf_test2;
"Test Case 3", `Quick, scrypt_kdf_test3;
] in
(* Skip test case 4 for architectures with 31 bit sizes or less, as it requires a buffer larger than Int.max_size in those cases *)
if Sys.int_size <= 31 then
tests
else
tests @ [ "Test Case 4", `Slow, scrypt_kdf_test4; ]
let () =
Alcotest.run "Scrypt kdf Tests" [
"Scrypt kdf tests", scrypt_kdf_tests ();
]