Merge pull request #167 from truenull/master
Tarsnap test vectors tested on Windows
This commit is contained in:
commit
6afdc96783
1
.gitignore
vendored
1
.gitignore
vendored
@ -82,6 +82,7 @@ test/default/onetimeauth
|
|||||||
test/default/onetimeauth2
|
test/default/onetimeauth2
|
||||||
test/default/onetimeauth7
|
test/default/onetimeauth7
|
||||||
test/default/pwhash
|
test/default/pwhash
|
||||||
|
test/default/pwhash_scrypt_ll
|
||||||
test/default/randombytes
|
test/default/randombytes
|
||||||
test/default/scalarmult
|
test/default/scalarmult
|
||||||
test/default/scalarmult2
|
test/default/scalarmult2
|
||||||
|
@ -32,6 +32,7 @@ EXTRA_DIST = \
|
|||||||
onetimeauth2.exp \
|
onetimeauth2.exp \
|
||||||
onetimeauth7.exp \
|
onetimeauth7.exp \
|
||||||
pwhash.exp \
|
pwhash.exp \
|
||||||
|
pwhash_scrypt_ll.exp \
|
||||||
scalarmult.exp \
|
scalarmult.exp \
|
||||||
scalarmult2.exp \
|
scalarmult2.exp \
|
||||||
scalarmult5.exp \
|
scalarmult5.exp \
|
||||||
@ -88,6 +89,7 @@ DISTCLEANFILES = \
|
|||||||
onetimeauth2.res \
|
onetimeauth2.res \
|
||||||
onetimeauth7.res \
|
onetimeauth7.res \
|
||||||
pwhash.res \
|
pwhash.res \
|
||||||
|
pwhash_scrypt_ll.res \
|
||||||
scalarmult.res \
|
scalarmult.res \
|
||||||
scalarmult2.res \
|
scalarmult2.res \
|
||||||
scalarmult5.res \
|
scalarmult5.res \
|
||||||
@ -151,6 +153,7 @@ TESTS_TARGETS = \
|
|||||||
onetimeauth2 \
|
onetimeauth2 \
|
||||||
onetimeauth7 \
|
onetimeauth7 \
|
||||||
pwhash \
|
pwhash \
|
||||||
|
pwhash_scrypt_ll \
|
||||||
randombytes \
|
randombytes \
|
||||||
scalarmult \
|
scalarmult \
|
||||||
scalarmult2 \
|
scalarmult2 \
|
||||||
@ -271,6 +274,9 @@ onetimeauth7_LDADD = $(TESTS_LDADD)
|
|||||||
pwhash_SOURCE = cmptest.h pwhash.c
|
pwhash_SOURCE = cmptest.h pwhash.c
|
||||||
pwhash_LDADD = $(TESTS_LDADD)
|
pwhash_LDADD = $(TESTS_LDADD)
|
||||||
|
|
||||||
|
pwhash_scrypt_ll_SOURCE = cmptest.h pwhash_scrypt_ll.c
|
||||||
|
pwhash_scrypt_ll_LDADD = $(TESTS_LDADD)
|
||||||
|
|
||||||
randombytes_SOURCE = randombytes.c
|
randombytes_SOURCE = randombytes.c
|
||||||
randombytes_LDADD = $(TESTS_LDADD)
|
randombytes_LDADD = $(TESTS_LDADD)
|
||||||
|
|
||||||
|
73
test/default/pwhash_scrypt_ll.c
Normal file
73
test/default/pwhash_scrypt_ll.c
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#define TEST_NAME "pwhash_scrypt_ll"
|
||||||
|
#include "cmptest.h"
|
||||||
|
|
||||||
|
/* Tarsnap test vectors, see: https://www.tarsnap.com/scrypt/scrypt.pdf */
|
||||||
|
|
||||||
|
uint8_t password1[] = "";
|
||||||
|
uint8_t salt1[] = "";
|
||||||
|
uint64_t N1 = 16ul;
|
||||||
|
uint32_t r1 = 1ul;
|
||||||
|
uint32_t p1 = 1ul;
|
||||||
|
|
||||||
|
uint8_t password2[] = "password";
|
||||||
|
uint8_t salt2[] = "NaCl";
|
||||||
|
uint64_t N2 = 1024ul;
|
||||||
|
uint32_t r2 = 8ul;
|
||||||
|
uint32_t p2 = 16ul;
|
||||||
|
|
||||||
|
uint8_t password3[] = "pleaseletmein";
|
||||||
|
uint8_t salt3[] = "SodiumChloride";
|
||||||
|
uint64_t N3 = 16384ul;
|
||||||
|
uint32_t r3 = 8ul;
|
||||||
|
uint32_t p3 = 1ul;
|
||||||
|
|
||||||
|
uint8_t password4[] = "pleaseletmein";
|
||||||
|
uint8_t salt4[] = "SodiumChloride";
|
||||||
|
size_t N4 = 1048576ul;
|
||||||
|
size_t r4 = 8ul;
|
||||||
|
size_t p4 = 1ul;
|
||||||
|
|
||||||
|
void test_vector(uint8_t * password, uint8_t * salt, uint64_t N, uint32_t r, uint32_t p)
|
||||||
|
{
|
||||||
|
const size_t olen = 64;
|
||||||
|
uint8_t data[64];
|
||||||
|
size_t passwordLength = strlen((const char*) password);
|
||||||
|
size_t saltLenght = strlen((const char*) salt);
|
||||||
|
int lineitems = 0;
|
||||||
|
const int lineitemsLimit = 15;
|
||||||
|
|
||||||
|
int i = crypto_pwhash_scryptsalsa208sha256_ll(password, passwordLength, salt, saltLenght, N, r, p, data, olen);
|
||||||
|
if(i != 0)
|
||||||
|
{
|
||||||
|
printf("crypto_scrypt_compat failed!");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Print header
|
||||||
|
printf("scrypt('");
|
||||||
|
printf("%s", password);
|
||||||
|
printf("', '");
|
||||||
|
printf("%s", salt);
|
||||||
|
printf("', %llu, %lu, %lu, %lu) =", N, r, p, olen);
|
||||||
|
printf("\n");
|
||||||
|
|
||||||
|
// Print test result
|
||||||
|
for(i = 0; i < olen; ++i)
|
||||||
|
{
|
||||||
|
printf("%02x", data[i]);
|
||||||
|
printf((lineitems < lineitemsLimit)? " " : "\n");
|
||||||
|
lineitems = (lineitems < lineitemsLimit)? lineitems+1 : 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
test_vector(password1, salt1, N1, r1, p1);
|
||||||
|
test_vector(password2, salt2, N2, r2, p2);
|
||||||
|
test_vector(password3, salt3, N3, r3, p3);
|
||||||
|
test_vector(password4, salt4, N4, r4, p4);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
20
test/default/pwhash_scrypt_ll.exp
Normal file
20
test/default/pwhash_scrypt_ll.exp
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
scrypt('', '', 16, 1, 1, 64) =
|
||||||
|
77 d6 57 62 38 65 7b 20 3b 19 ca 42 c1 8a 04 97
|
||||||
|
f1 6b 48 44 e3 07 4a e8 df df fa 3f ed e2 14 42
|
||||||
|
fc d0 06 9d ed 09 48 f8 32 6a 75 3a 0f c8 1f 17
|
||||||
|
e8 d3 e0 fb 2e 0d 36 28 cf 35 e2 0c 38 d1 89 06
|
||||||
|
scrypt('password', 'NaCl', 1024, 8, 16, 64) =
|
||||||
|
fd ba be 1c 9d 34 72 00 78 56 e7 19 0d 01 e9 fe
|
||||||
|
7c 6a d7 cb c8 23 78 30 e7 73 76 63 4b 37 31 62
|
||||||
|
2e af 30 d9 2e 22 a3 88 6f f1 09 27 9d 98 30 da
|
||||||
|
c7 27 af b9 4a 83 ee 6d 83 60 cb df a2 cc 06 40
|
||||||
|
scrypt('pleaseletmein', 'SodiumChloride', 16384, 8, 1, 64) =
|
||||||
|
70 23 bd cb 3a fd 73 48 46 1c 06 cd 81 fd 38 eb
|
||||||
|
fd a8 fb ba 90 4f 8e 3e a9 b5 43 f6 54 5d a1 f2
|
||||||
|
d5 43 29 55 61 3f 0f cf 62 d4 97 05 24 2a 9a f9
|
||||||
|
e6 1e 85 dc 0d 65 1e 40 df cf 01 7b 45 57 58 87
|
||||||
|
scrypt('pleaseletmein', 'SodiumChloride', 1048576, 8, 1, 64) =
|
||||||
|
21 01 cb 9b 6a 51 1a ae ad db be 09 cf 70 f8 81
|
||||||
|
ec 56 8d 57 4a 2f fd 4d ab e5 ee 98 20 ad aa 47
|
||||||
|
8e 56 fd 8f 4b a5 d0 9f fa 1c 6d 92 7c 40 f4 c3
|
||||||
|
37 30 40 49 e8 a9 52 fb cb f4 5c 6f a7 7a 41 a4
|
Loading…
Reference in New Issue
Block a user