diff options
author | Kim Alvefur <zash@zash.se> | 2019-04-20 15:11:04 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2019-04-20 15:11:04 +0200 |
commit | 165ee3a5ef1247468e98d0d4cba6fc43e15f92d7 (patch) | |
tree | a472872759824855130084577e300a89a652254a /spec | |
parent | ffc422e2f6d8806dee551491feaac71f54adf0d7 (diff) | |
download | prosody-165ee3a5ef1247468e98d0d4cba6fc43e15f92d7.tar.gz prosody-165ee3a5ef1247468e98d0d4cba6fc43e15f92d7.zip |
util.hashes: Allow specifying output key length
This is not needed for SCRAM but PBKDF2 takes this argument.
Diffstat (limited to 'spec')
-rw-r--r-- | spec/util_hashes_spec.lua | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/spec/util_hashes_spec.lua b/spec/util_hashes_spec.lua index 1e6187bb..9099145a 100644 --- a/spec/util_hashes_spec.lua +++ b/spec/util_hashes_spec.lua @@ -33,5 +33,21 @@ describe("PBKDF2-SHA1", function () 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); |