aboutsummaryrefslogtreecommitdiffstats
path: root/spec/util_hashes_spec.lua
blob: 9099145a5cd957287cb902235884bf6f53970fcf (plain)
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
-- Test vectors from RFC 6070
local hashes = require "util.hashes";
local hex = require "util.hex";

-- Also see spec for util.hmac where HMAC test cases reside

describe("PBKDF2-SHA1", function ()
	it("test vector 1", function ()
		local P = "password"
		local S = "salt"
		local c = 1
		local DK = "0c60c80f961f0e71f3a9b524af6012062fe037a6";
		assert.equal(DK, hex.to(hashes.scram_Hi_sha1(P, S, c)));
	end);
	it("test vector 2", function ()
		local P = "password"
		local S = "salt"
		local c = 2
		local DK = "ea6c014dc72d6f8ccd1ed92ace1d41f0d8de8957";
		assert.equal(DK, hex.to(hashes.scram_Hi_sha1(P, S, c)));
	end);
	it("test vector 3", function ()
		local P = "password"
		local S = "salt"
		local c = 4096
		local DK = "4b007901b765489abead49d926f721d065a429c1";
		assert.equal(DK, hex.to(hashes.scram_Hi_sha1(P, S, c)));
	end);
	it("test vector 4 #SLOW", function ()
		local P = "password"
		local S = "salt"
		local c = 16777216
		local DK = "eefe3d61cd4da4e4e9945b3d6ba2158c2634e984";
		assert.equal(DK, hex.to(hashes.scram_Hi_sha1(P, S, c)));
	end);
	it("test vector 5", function ()
		local P = "passwordPASSWORDpassword"
		local S = "saltSALTsaltSALTsaltSALTsaltSALTsalt"
		local c = 4096
		local dkLen = 25
		local DK = "3d2eec4fe41c849b80c8d83662c0e44a8b291a964cf2f07038"
		assert.equal(DK, hex.to(hashes.scram_Hi_sha1(P, S, c, dkLen)));
	end);
	it("works", function ()
		local P = "pass\0word"
		local S = "sa\0lt"
		local c = 4096
		local dkLen = 16
		local DK = "56fa6aa75548099dcc37d7f03425e0c3"
		assert.equal(DK, hex.to(hashes.scram_Hi_sha1(P, S, c, dkLen)));
	end);
end);