mirror of
https://github.com/bjc/prosody.git
synced 2025-03-31 11:47:40 +03:00
util.hashes: Add test vectors from RFC 6070 for PBKDF2 (aka SCRAM Hi())
Number 4 is disabled by default beacuse of how long time it takes
This commit is contained in:
parent
70bbc77e68
commit
43bb3d5756
2 changed files with 38 additions and 1 deletions
2
.busted
2
.busted
|
@ -2,7 +2,7 @@ return {
|
|||
_all = {
|
||||
},
|
||||
default = {
|
||||
["exclude-tags"] = "mod_bosh,storage";
|
||||
["exclude-tags"] = "mod_bosh,storage,SLOW";
|
||||
};
|
||||
bosh = {
|
||||
tags = "mod_bosh";
|
||||
|
|
37
spec/util_hashes_spec.lua
Normal file
37
spec/util_hashes_spec.lua
Normal file
|
@ -0,0 +1,37 @@
|
|||
-- 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);
|
||||
end);
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue