test_KDF.py 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733
  1. # -*- coding: utf-8 -*-
  2. #
  3. # SelfTest/Protocol/test_KDF.py: Self-test for key derivation functions
  4. #
  5. # ===================================================================
  6. # The contents of this file are dedicated to the public domain. To
  7. # the extent that dedication to the public domain is not available,
  8. # everyone is granted a worldwide, perpetual, royalty-free,
  9. # non-exclusive license to exercise all rights associated with the
  10. # contents of this file for any purpose whatsoever.
  11. # No rights are reserved.
  12. #
  13. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  14. # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  15. # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  16. # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  17. # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  18. # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  19. # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  20. # SOFTWARE.
  21. # ===================================================================
  22. import unittest
  23. from binascii import unhexlify
  24. from Cryptodome.Util.py3compat import b, bchr
  25. from Cryptodome.SelfTest.st_common import list_test_cases
  26. from Cryptodome.SelfTest.loader import load_test_vectors_wycheproof
  27. from Cryptodome.Hash import SHA1, HMAC, SHA256, MD5, SHA224, SHA384, SHA512
  28. from Cryptodome.Cipher import AES, DES3
  29. from Cryptodome.Protocol.KDF import (PBKDF1, PBKDF2, _S2V, HKDF, scrypt,
  30. bcrypt, bcrypt_check)
  31. from Cryptodome.Protocol.KDF import _bcrypt_decode
  32. def t2b(t):
  33. if t is None:
  34. return None
  35. t2 = t.replace(" ", "").replace("\n", "")
  36. return unhexlify(b(t2))
  37. class TestVector(object):
  38. pass
  39. class PBKDF1_Tests(unittest.TestCase):
  40. # List of tuples with test data.
  41. # Each tuple is made up by:
  42. # Item #0: a pass phrase
  43. # Item #1: salt (8 bytes encoded in hex)
  44. # Item #2: output key length
  45. # Item #3: iterations to use
  46. # Item #4: expected result (encoded in hex)
  47. _testData = (
  48. # From http://www.di-mgt.com.au/cryptoKDFs.html#examplespbkdf
  49. ("password", "78578E5A5D63CB06", 16, 1000, "DC19847E05C64D2FAF10EBFB4A3D2A20"),
  50. )
  51. def test1(self):
  52. v = self._testData[0]
  53. res = PBKDF1(v[0], t2b(v[1]), v[2], v[3], SHA1)
  54. self.assertEqual(res, t2b(v[4]))
  55. class PBKDF2_Tests(unittest.TestCase):
  56. # List of tuples with test data.
  57. # Each tuple is made up by:
  58. # Item #0: a pass phrase
  59. # Item #1: salt (encoded in hex)
  60. # Item #2: output key length
  61. # Item #3: iterations to use
  62. # Item #4: hash module
  63. # Item #5: expected result (encoded in hex)
  64. _testData = (
  65. # From http://www.di-mgt.com.au/cryptoKDFs.html#examplespbkdf
  66. ("password","78578E5A5D63CB06",24,2048, SHA1, "BFDE6BE94DF7E11DD409BCE20A0255EC327CB936FFE93643"),
  67. # From RFC 6050
  68. ("password","73616c74", 20, 1, SHA1, "0c60c80f961f0e71f3a9b524af6012062fe037a6"),
  69. ("password","73616c74", 20, 2, SHA1, "ea6c014dc72d6f8ccd1ed92ace1d41f0d8de8957"),
  70. ("password","73616c74", 20, 4096, SHA1, "4b007901b765489abead49d926f721d065a429c1"),
  71. ("passwordPASSWORDpassword","73616c7453414c5473616c7453414c5473616c7453414c5473616c7453414c5473616c74",
  72. 25, 4096, SHA1, "3d2eec4fe41c849b80c8d83662c0e44a8b291a964cf2f07038"),
  73. ( 'pass\x00word',"7361006c74",16,4096, SHA1, "56fa6aa75548099dcc37d7f03425e0c3"),
  74. # From draft-josefsson-scrypt-kdf-01, Chapter 10
  75. ( 'passwd', '73616c74', 64, 1, SHA256, "55ac046e56e3089fec1691c22544b605f94185216dde0465e68b9d57c20dacbc49ca9cccf179b645991664b39d77ef317c71b845b1e30bd509112041d3a19783"),
  76. ( 'Password', '4e61436c', 64, 80000, SHA256, "4ddcd8f60b98be21830cee5ef22701f9641a4418d04c0414aeff08876b34ab56a1d425a1225833549adb841b51c9b3176a272bdebba1d078478f62b397f33c8d"),
  77. )
  78. def test1(self):
  79. # Test only for HMAC-SHA1 as PRF
  80. def prf_SHA1(p,s):
  81. return HMAC.new(p,s,SHA1).digest()
  82. def prf_SHA256(p,s):
  83. return HMAC.new(p,s,SHA256).digest()
  84. for i in range(len(self._testData)):
  85. v = self._testData[i]
  86. password = v[0]
  87. salt = t2b(v[1])
  88. out_len = v[2]
  89. iters = v[3]
  90. hash_mod = v[4]
  91. expected = t2b(v[5])
  92. if hash_mod is SHA1:
  93. res = PBKDF2(password, salt, out_len, iters)
  94. self.assertEqual(res, expected)
  95. res = PBKDF2(password, salt, out_len, iters, prf_SHA1)
  96. self.assertEqual(res, expected)
  97. else:
  98. res = PBKDF2(password, salt, out_len, iters, prf_SHA256)
  99. self.assertEqual(res, expected)
  100. def test2(self):
  101. # Verify that prf and hmac_hash_module are mutual exclusive
  102. def prf_SHA1(p,s):
  103. return HMAC.new(p,s,SHA1).digest()
  104. self.assertRaises(ValueError, PBKDF2, b("xxx"), b("yyy"), 16, 100,
  105. prf=prf_SHA1, hmac_hash_module=SHA1)
  106. def test3(self):
  107. # Verify that hmac_hash_module works like prf
  108. password = b("xxx")
  109. salt = b("yyy")
  110. for hashmod in (MD5, SHA1, SHA224, SHA256, SHA384, SHA512):
  111. pr1 = PBKDF2(password, salt, 16, 100,
  112. prf=lambda p, s: HMAC.new(p,s,hashmod).digest())
  113. pr2 = PBKDF2(password, salt, 16, 100, hmac_hash_module=hashmod)
  114. self.assertEqual(pr1, pr2)
  115. def test4(self):
  116. # Verify that PBKDF2 can take bytes or strings as password or salt
  117. k1 = PBKDF2("xxx", b("yyy"), 16, 10)
  118. k2 = PBKDF2(b("xxx"), b("yyy"), 16, 10)
  119. self.assertEqual(k1, k2)
  120. k1 = PBKDF2(b("xxx"), "yyy", 16, 10)
  121. k2 = PBKDF2(b("xxx"), b("yyy"), 16, 10)
  122. self.assertEqual(k1, k2)
  123. class S2V_Tests(unittest.TestCase):
  124. # Sequence of test vectors.
  125. # Each test vector is made up by:
  126. # Item #0: a tuple of strings
  127. # Item #1: an AES key
  128. # Item #2: the result
  129. # Item #3: the cipher module S2V is based on
  130. # Everything is hex encoded
  131. _testData = [
  132. # RFC5297, A.1
  133. (
  134. ( '101112131415161718191a1b1c1d1e1f2021222324252627',
  135. '112233445566778899aabbccddee' ),
  136. 'fffefdfcfbfaf9f8f7f6f5f4f3f2f1f0',
  137. '85632d07c6e8f37f950acd320a2ecc93',
  138. AES
  139. ),
  140. # RFC5297, A.2
  141. (
  142. ( '00112233445566778899aabbccddeeffdeaddadadeaddadaffeeddcc'+
  143. 'bbaa99887766554433221100',
  144. '102030405060708090a0',
  145. '09f911029d74e35bd84156c5635688c0',
  146. '7468697320697320736f6d6520706c61'+
  147. '696e7465787420746f20656e63727970'+
  148. '74207573696e67205349562d414553'),
  149. '7f7e7d7c7b7a79787776757473727170',
  150. '7bdb6e3b432667eb06f4d14bff2fbd0f',
  151. AES
  152. ),
  153. ]
  154. def test1(self):
  155. """Verify correctness of test vector"""
  156. for tv in self._testData:
  157. s2v = _S2V.new(t2b(tv[1]), tv[3])
  158. for s in tv[0]:
  159. s2v.update(t2b(s))
  160. result = s2v.derive()
  161. self.assertEqual(result, t2b(tv[2]))
  162. def test2(self):
  163. """Verify that no more than 127(AES) and 63(TDES)
  164. components are accepted."""
  165. key = bchr(0) * 8 + bchr(255) * 8
  166. for module in (AES, DES3):
  167. s2v = _S2V.new(key, module)
  168. max_comps = module.block_size*8-1
  169. for i in range(max_comps):
  170. s2v.update(b("XX"))
  171. self.assertRaises(TypeError, s2v.update, b("YY"))
  172. class HKDF_Tests(unittest.TestCase):
  173. # Test vectors from RFC5869, Appendix A
  174. # Each tuple is made up by:
  175. # Item #0: hash module
  176. # Item #1: secret
  177. # Item #2: salt
  178. # Item #3: context
  179. # Item #4: expected result
  180. _test_vector = (
  181. (
  182. SHA256,
  183. "0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b",
  184. "000102030405060708090a0b0c",
  185. "f0f1f2f3f4f5f6f7f8f9",
  186. 42,
  187. "3cb25f25faacd57a90434f64d0362f2a" +
  188. "2d2d0a90cf1a5a4c5db02d56ecc4c5bf" +
  189. "34007208d5b887185865"
  190. ),
  191. (
  192. SHA256,
  193. "000102030405060708090a0b0c0d0e0f" +
  194. "101112131415161718191a1b1c1d1e1f" +
  195. "202122232425262728292a2b2c2d2e2f" +
  196. "303132333435363738393a3b3c3d3e3f" +
  197. "404142434445464748494a4b4c4d4e4f",
  198. "606162636465666768696a6b6c6d6e6f" +
  199. "707172737475767778797a7b7c7d7e7f" +
  200. "808182838485868788898a8b8c8d8e8f" +
  201. "909192939495969798999a9b9c9d9e9f" +
  202. "a0a1a2a3a4a5a6a7a8a9aaabacadaeaf",
  203. "b0b1b2b3b4b5b6b7b8b9babbbcbdbebf" +
  204. "c0c1c2c3c4c5c6c7c8c9cacbcccdcecf" +
  205. "d0d1d2d3d4d5d6d7d8d9dadbdcdddedf" +
  206. "e0e1e2e3e4e5e6e7e8e9eaebecedeeef" +
  207. "f0f1f2f3f4f5f6f7f8f9fafbfcfdfeff",
  208. 82,
  209. "b11e398dc80327a1c8e7f78c596a4934" +
  210. "4f012eda2d4efad8a050cc4c19afa97c" +
  211. "59045a99cac7827271cb41c65e590e09" +
  212. "da3275600c2f09b8367793a9aca3db71" +
  213. "cc30c58179ec3e87c14c01d5c1f3434f" +
  214. "1d87"
  215. ),
  216. (
  217. SHA256,
  218. "0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b",
  219. None,
  220. None,
  221. 42,
  222. "8da4e775a563c18f715f802a063c5a31" +
  223. "b8a11f5c5ee1879ec3454e5f3c738d2d" +
  224. "9d201395faa4b61a96c8"
  225. ),
  226. (
  227. SHA1,
  228. "0b0b0b0b0b0b0b0b0b0b0b",
  229. "000102030405060708090a0b0c",
  230. "f0f1f2f3f4f5f6f7f8f9",
  231. 42,
  232. "085a01ea1b10f36933068b56efa5ad81" +
  233. "a4f14b822f5b091568a9cdd4f155fda2" +
  234. "c22e422478d305f3f896"
  235. ),
  236. (
  237. SHA1,
  238. "000102030405060708090a0b0c0d0e0f" +
  239. "101112131415161718191a1b1c1d1e1f" +
  240. "202122232425262728292a2b2c2d2e2f" +
  241. "303132333435363738393a3b3c3d3e3f" +
  242. "404142434445464748494a4b4c4d4e4f",
  243. "606162636465666768696a6b6c6d6e6f" +
  244. "707172737475767778797a7b7c7d7e7f" +
  245. "808182838485868788898a8b8c8d8e8f" +
  246. "909192939495969798999a9b9c9d9e9f" +
  247. "a0a1a2a3a4a5a6a7a8a9aaabacadaeaf",
  248. "b0b1b2b3b4b5b6b7b8b9babbbcbdbebf" +
  249. "c0c1c2c3c4c5c6c7c8c9cacbcccdcecf" +
  250. "d0d1d2d3d4d5d6d7d8d9dadbdcdddedf" +
  251. "e0e1e2e3e4e5e6e7e8e9eaebecedeeef" +
  252. "f0f1f2f3f4f5f6f7f8f9fafbfcfdfeff",
  253. 82,
  254. "0bd770a74d1160f7c9f12cd5912a06eb" +
  255. "ff6adcae899d92191fe4305673ba2ffe" +
  256. "8fa3f1a4e5ad79f3f334b3b202b2173c" +
  257. "486ea37ce3d397ed034c7f9dfeb15c5e" +
  258. "927336d0441f4c4300e2cff0d0900b52" +
  259. "d3b4"
  260. ),
  261. (
  262. SHA1,
  263. "0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b",
  264. "",
  265. "",
  266. 42,
  267. "0ac1af7002b3d761d1e55298da9d0506" +
  268. "b9ae52057220a306e07b6b87e8df21d0" +
  269. "ea00033de03984d34918"
  270. ),
  271. (
  272. SHA1,
  273. "0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c",
  274. None,
  275. "",
  276. 42,
  277. "2c91117204d745f3500d636a62f64f0a" +
  278. "b3bae548aa53d423b0d1f27ebba6f5e5" +
  279. "673a081d70cce7acfc48"
  280. )
  281. )
  282. def test1(self):
  283. for tv in self._test_vector:
  284. secret, salt, info, exp = [ t2b(tv[x]) for x in (1,2,3,5) ]
  285. key_len, hashmod = [ tv[x] for x in (4,0) ]
  286. output = HKDF(secret, key_len, salt, hashmod, 1, info)
  287. self.assertEqual(output, exp)
  288. def test2(self):
  289. ref = HKDF(b("XXXXXX"), 12, b("YYYY"), SHA1)
  290. # Same output, but this time split over 2 keys
  291. key1, key2 = HKDF(b("XXXXXX"), 6, b("YYYY"), SHA1, 2)
  292. self.assertEqual((ref[:6], ref[6:]), (key1, key2))
  293. # Same output, but this time split over 3 keys
  294. key1, key2, key3 = HKDF(b("XXXXXX"), 4, b("YYYY"), SHA1, 3)
  295. self.assertEqual((ref[:4], ref[4:8], ref[8:]), (key1, key2, key3))
  296. class scrypt_Tests(unittest.TestCase):
  297. # Test vectors taken from
  298. # https://tools.ietf.org/html/rfc7914
  299. # - password
  300. # - salt
  301. # - N
  302. # - r
  303. # - p
  304. data = (
  305. (
  306. "",
  307. "",
  308. 16, # 2K
  309. 1,
  310. 1,
  311. """
  312. 77 d6 57 62 38 65 7b 20 3b 19 ca 42 c1 8a 04 97
  313. f1 6b 48 44 e3 07 4a e8 df df fa 3f ed e2 14 42
  314. fc d0 06 9d ed 09 48 f8 32 6a 75 3a 0f c8 1f 17
  315. e8 d3 e0 fb 2e 0d 36 28 cf 35 e2 0c 38 d1 89 06
  316. """
  317. ),
  318. (
  319. "password",
  320. "NaCl",
  321. 1024, # 1M
  322. 8,
  323. 16,
  324. """
  325. fd ba be 1c 9d 34 72 00 78 56 e7 19 0d 01 e9 fe
  326. 7c 6a d7 cb c8 23 78 30 e7 73 76 63 4b 37 31 62
  327. 2e af 30 d9 2e 22 a3 88 6f f1 09 27 9d 98 30 da
  328. c7 27 af b9 4a 83 ee 6d 83 60 cb df a2 cc 06 40
  329. """
  330. ),
  331. (
  332. "pleaseletmein",
  333. "SodiumChloride",
  334. 16384, # 16M
  335. 8,
  336. 1,
  337. """
  338. 70 23 bd cb 3a fd 73 48 46 1c 06 cd 81 fd 38 eb
  339. fd a8 fb ba 90 4f 8e 3e a9 b5 43 f6 54 5d a1 f2
  340. d5 43 29 55 61 3f 0f cf 62 d4 97 05 24 2a 9a f9
  341. e6 1e 85 dc 0d 65 1e 40 df cf 01 7b 45 57 58 87
  342. """
  343. ),
  344. (
  345. "pleaseletmein",
  346. "SodiumChloride",
  347. 1048576, # 1G
  348. 8,
  349. 1,
  350. """
  351. 21 01 cb 9b 6a 51 1a ae ad db be 09 cf 70 f8 81
  352. ec 56 8d 57 4a 2f fd 4d ab e5 ee 98 20 ad aa 47
  353. 8e 56 fd 8f 4b a5 d0 9f fa 1c 6d 92 7c 40 f4 c3
  354. 37 30 40 49 e8 a9 52 fb cb f4 5c 6f a7 7a 41 a4
  355. """
  356. ),
  357. )
  358. def setUp(self):
  359. new_test_vectors = []
  360. for tv in self.data:
  361. new_tv = TestVector()
  362. new_tv.P = b(tv[0])
  363. new_tv.S = b(tv[1])
  364. new_tv.N = tv[2]
  365. new_tv.r = tv[3]
  366. new_tv.p = tv[4]
  367. new_tv.output = t2b(tv[5])
  368. new_tv.dkLen = len(new_tv.output)
  369. new_test_vectors.append(new_tv)
  370. self.data = new_test_vectors
  371. def test2(self):
  372. for tv in self.data:
  373. try:
  374. output = scrypt(tv.P, tv.S, tv.dkLen, tv.N, tv.r, tv.p)
  375. except ValueError as e:
  376. if " 2 " in str(e) and tv.N >= 1048576:
  377. import warnings
  378. warnings.warn("Not enough memory to unit test scrypt() with N=1048576", RuntimeWarning)
  379. continue
  380. else:
  381. raise e
  382. self.assertEqual(output, tv.output)
  383. def test3(self):
  384. ref = scrypt(b("password"), b("salt"), 12, 16, 1, 1)
  385. # Same output, but this time split over 2 keys
  386. key1, key2 = scrypt(b("password"), b("salt"), 6, 16, 1, 1, 2)
  387. self.assertEqual((ref[:6], ref[6:]), (key1, key2))
  388. # Same output, but this time split over 3 keys
  389. key1, key2, key3 = scrypt(b("password"), b("salt"), 4, 16, 1, 1, 3)
  390. self.assertEqual((ref[:4], ref[4:8], ref[8:]), (key1, key2, key3))
  391. class bcrypt_Tests(unittest.TestCase):
  392. def test_negative_cases(self):
  393. self.assertRaises(ValueError, bcrypt, b"1" * 73, 10)
  394. self.assertRaises(ValueError, bcrypt, b"1" * 10, 3)
  395. self.assertRaises(ValueError, bcrypt, b"1" * 10, 32)
  396. self.assertRaises(ValueError, bcrypt, b"1" * 10, 4, salt=b"")
  397. self.assertRaises(ValueError, bcrypt, b"1" * 10, 4, salt=b"1")
  398. self.assertRaises(ValueError, bcrypt, b"1" * 10, 4, salt=b"1" * 17)
  399. self.assertRaises(ValueError, bcrypt, b"1\x00" * 10, 4)
  400. def test_bytearray_mismatch(self):
  401. ref = bcrypt("pwd", 4)
  402. bcrypt_check("pwd", ref)
  403. bref = bytearray(ref)
  404. bcrypt_check("pwd", bref)
  405. wrong = ref[:-1] + bchr(bref[-1] ^ 0x01)
  406. self.assertRaises(ValueError, bcrypt_check, "pwd", wrong)
  407. wrong = b"x" + ref[1:]
  408. self.assertRaises(ValueError, bcrypt_check, "pwd", wrong)
  409. # https://github.com/patrickfav/bcrypt/wiki/Published-Test-Vectors
  410. def test_empty_password(self):
  411. # password, cost, salt, bcrypt hash
  412. tvs = [
  413. (b"", 4, b"zVHmKQtGGQob.b/Nc7l9NO", b"$2a$04$zVHmKQtGGQob.b/Nc7l9NO8UlrYcW05FiuCj/SxsFO/ZtiN9.mNzy"),
  414. (b"", 5, b"zVHmKQtGGQob.b/Nc7l9NO", b"$2a$05$zVHmKQtGGQob.b/Nc7l9NOWES.1hkVBgy5IWImh9DOjKNU8atY4Iy"),
  415. (b"", 6, b"zVHmKQtGGQob.b/Nc7l9NO", b"$2a$06$zVHmKQtGGQob.b/Nc7l9NOjOl7l4oz3WSh5fJ6414Uw8IXRAUoiaO"),
  416. (b"", 7, b"zVHmKQtGGQob.b/Nc7l9NO", b"$2a$07$zVHmKQtGGQob.b/Nc7l9NOBsj1dQpBA1HYNGpIETIByoNX9jc.hOi"),
  417. (b"", 8, b"zVHmKQtGGQob.b/Nc7l9NO", b"$2a$08$zVHmKQtGGQob.b/Nc7l9NOiLTUh/9MDpX86/DLyEzyiFjqjBFePgO"),
  418. ]
  419. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  420. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  421. self.assertEqual(x, result)
  422. bcrypt_check(password, result)
  423. def test_random_password_and_salt_short_pw(self):
  424. # password, cost, salt, bcrypt hash
  425. tvs = [
  426. (b"<.S.2K(Zq'", 4, b"VYAclAMpaXY/oqAo9yUpku", b"$2a$04$VYAclAMpaXY/oqAo9yUpkuWmoYywaPzyhu56HxXpVltnBIfmO9tgu"),
  427. (b"5.rApO%5jA", 5, b"kVNDrnYKvbNr5AIcxNzeIu", b"$2a$05$kVNDrnYKvbNr5AIcxNzeIuRcyIF5cZk6UrwHGxENbxP5dVv.WQM/G"),
  428. (b"oW++kSrQW^", 6, b"QLKkRMH9Am6irtPeSKN5sO", b"$2a$06$QLKkRMH9Am6irtPeSKN5sObJGr3j47cO6Pdf5JZ0AsJXuze0IbsNm"),
  429. (b"ggJ\\KbTnDG", 7, b"4H896R09bzjhapgCPS/LYu", b"$2a$07$4H896R09bzjhapgCPS/LYuMzAQluVgR5iu/ALF8L8Aln6lzzYXwbq"),
  430. (b"49b0:;VkH/", 8, b"hfvO2retKrSrx5f2RXikWe", b"$2a$08$hfvO2retKrSrx5f2RXikWeFWdtSesPlbj08t/uXxCeZoHRWDz/xFe"),
  431. (b">9N^5jc##'", 9, b"XZLvl7rMB3EvM0c1.JHivu", b"$2a$09$XZLvl7rMB3EvM0c1.JHivuIDPJWeNJPTVrpjZIEVRYYB/mF6cYgJK"),
  432. (b"\\$ch)s4WXp", 10, b"aIjpMOLK5qiS9zjhcHR5TO", b"$2a$10$aIjpMOLK5qiS9zjhcHR5TOU7v2NFDmcsBmSFDt5EHOgp/jeTF3O/q"),
  433. (b"RYoj\\_>2P7", 12, b"esIAHiQAJNNBrsr5V13l7.", b"$2a$12$esIAHiQAJNNBrsr5V13l7.RFWWJI2BZFtQlkFyiWXjou05GyuREZa"),
  434. ]
  435. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  436. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  437. self.assertEqual(x, result)
  438. bcrypt_check(password, result)
  439. def test_random_password_and_salt_long_pw(self):
  440. # password, cost, salt, bcrypt hash
  441. tvs = [
  442. (b"^Q&\"]A`%/A(BVGt>QaX0M-#<Q148&f", 4, b"vrRP5vQxyD4LrqiLd/oWRO", b"$2a$04$vrRP5vQxyD4LrqiLd/oWROgrrGINsw3gb4Ga5x2sn01jNmiLVECl6"),
  443. (b"nZa!rRf\\U;OL;R?>1ghq_+\":Y0CRmY", 5, b"YuQvhokOGVnevctykUYpKu", b"$2a$05$YuQvhokOGVnevctykUYpKutZD2pWeGGYn3auyLOasguMY3/0BbIyq"),
  444. (b"F%uN/j>[GuB7-jB'_Yj!Tnb7Y!u^6)", 6, b"5L3vpQ0tG9O7k5gQ8nAHAe", b"$2a$06$5L3vpQ0tG9O7k5gQ8nAHAe9xxQiOcOLh8LGcI0PLWhIznsDt.S.C6"),
  445. (b"Z>BobP32ub\"Cfe*Q<<WUq3rc=[GJr-", 7, b"hp8IdLueqE6qFh1zYycUZ.", b"$2a$07$hp8IdLueqE6qFh1zYycUZ.twmUH8eSTPQAEpdNXKMlwms9XfKqfea"),
  446. (b"Ik&8N['7*[1aCc1lOm8\\jWeD*H$eZM", 8, b"2ANDTYCB9m7vf0Prh7rSru", b"$2a$08$2ANDTYCB9m7vf0Prh7rSrupqpO3jJOkIz2oW/QHB4lCmK7qMytGV6"),
  447. (b"O)=%3[E$*q+>-q-=tRSjOBh8\\mLNW.", 9, b"nArqOfdCsD9kIbVnAixnwe", b"$2a$09$nArqOfdCsD9kIbVnAixnwe6s8QvyPYWtQBpEXKir2OJF9/oNBsEFe"),
  448. (b"/MH51`!BP&0tj3%YCA;Xk%e3S`o\\EI", 10, b"ePiAc.s.yoBi3B6p1iQUCe", b"$2a$10$ePiAc.s.yoBi3B6p1iQUCezn3mraLwpVJ5XGelVyYFKyp5FZn/y.u"),
  449. (b"ptAP\"mcg6oH.\";c0U2_oll.OKi<!ku", 12, b"aroG/pwwPj1tU5fl9a9pkO", b"$2a$12$aroG/pwwPj1tU5fl9a9pkO4rydAmkXRj/LqfHZOSnR6LGAZ.z.jwa"),
  450. ]
  451. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  452. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  453. self.assertEqual(x, result)
  454. bcrypt_check(password, result)
  455. def test_same_password_and_random_salt(self):
  456. # password, cost, salt, bcrypt hash
  457. tvs = [
  458. (b"Q/A:k3DP;X@=<0\"hg&9c", 4, b"wbgDTvLMtyjQlNK7fjqwyO", b"$2a$04$wbgDTvLMtyjQlNK7fjqwyOakBoACQuYh11.VsKNarF4xUIOBWgD6S"),
  459. (b"Q/A:k3DP;X@=<0\"hg&9c", 5, b"zbAaOmloOhxiKItjznRqru", b"$2a$05$zbAaOmloOhxiKItjznRqrunRqHlu3MAa7pMGv26Rr3WwyfGcwoRm6"),
  460. (b"Q/A:k3DP;X@=<0\"hg&9c", 6, b"aOK0bWUvLI0qLkc3ti5jyu", b"$2a$06$aOK0bWUvLI0qLkc3ti5jyuAIQoqRzuqoK09kQqQ6Ou/YKDhW50/qa"),
  461. ]
  462. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  463. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  464. self.assertEqual(x, result)
  465. bcrypt_check(password, result)
  466. def test_same_password_and_salt_increasing_cost_factor(self):
  467. # password, cost, salt, bcrypt hash
  468. tvs = [
  469. (b"o<&+X'F4AQ8H,LU,N`&r", 4, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$04$BK5u.QHk1Driey7bvnFTH.3smGwxd91PtoK2GxH5nZ7pcBsYX4lMq"),
  470. (b"o<&+X'F4AQ8H,LU,N`&r", 5, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$05$BK5u.QHk1Driey7bvnFTH.t5P.jZvFBMzDB1IY4PwkkRPOyVbEtFG"),
  471. (b"o<&+X'F4AQ8H,LU,N`&r", 6, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$06$BK5u.QHk1Driey7bvnFTH.6Ea1Z5db2p25CPXZbxb/3OyKQagg3pa"),
  472. (b"o<&+X'F4AQ8H,LU,N`&r", 7, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$07$BK5u.QHk1Driey7bvnFTH.sruuQi8Lhv/0LWKDvNp3AGFk7ltdkm6"),
  473. (b"o<&+X'F4AQ8H,LU,N`&r", 8, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$08$BK5u.QHk1Driey7bvnFTH.IE7KsaUzc4m7gzAMlyUPUeiYyACWe0q"),
  474. (b"o<&+X'F4AQ8H,LU,N`&r", 9, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$09$BK5u.QHk1Driey7bvnFTH.1v4Xj1dwkp44QNg0cVAoQt4FQMMrvnS"),
  475. (b"o<&+X'F4AQ8H,LU,N`&r", 10, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$10$BK5u.QHk1Driey7bvnFTH.ESINe9YntUMcVgFDfkC.Vbhc9vMhNX2"),
  476. (b"o<&+X'F4AQ8H,LU,N`&r", 12, b"BK5u.QHk1Driey7bvnFTH.", b"$2a$12$BK5u.QHk1Driey7bvnFTH.QM1/nnGe/f5cTzb6XTTi/vMzcAnycqG"),
  477. ]
  478. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  479. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  480. self.assertEqual(x, result)
  481. bcrypt_check(password, result)
  482. def test_long_passwords(self):
  483. # password, cost, salt, bcrypt hash
  484. tvs = [
  485. (b"g*3Q45=\"8NNgpT&mbMJ$Omfr.#ZeW?FP=CE$#roHd?97uL0F-]`?u73c\"\\[.\"*)qU34@VG",
  486. 4, b"T2XJ5MOWvHQZRijl8LIKkO", b"$2a$04$T2XJ5MOWvHQZRijl8LIKkOQKIyX75KBfuLsuRYOJz5OjwBNF2lM8a"),
  487. (b"\\M+*8;&QE=Ll[>5?Ui\"^ai#iQH7ZFtNMfs3AROnIncE9\"BNNoEgO[[*Yk8;RQ(#S,;I+aT",
  488. 5, b"wgkOlGNXIVE2fWkT3gyRoO", b"$2a$05$wgkOlGNXIVE2fWkT3gyRoOqWi4gbi1Wv2Q2Jx3xVs3apl1w.Wtj8C"),
  489. (b"M.E1=dt<.L0Q&p;94NfGm_Oo23+Kpl@M5?WIAL.[@/:'S)W96G8N^AWb7_smmC]>7#fGoB",
  490. 6, b"W9zTCl35nEvUukhhFzkKMe", b"$2a$06$W9zTCl35nEvUukhhFzkKMekjT9/pj7M0lihRVEZrX3m8/SBNZRX7i"),
  491. ]
  492. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  493. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  494. self.assertEqual(x, result)
  495. bcrypt_check(password, result)
  496. def test_increasing_password_length(self):
  497. # password, cost, salt, bcrypt hash
  498. tvs = [
  499. (b"a", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.l4WvgHIVg17ZawDIrDM2IjlE64GDNQS"),
  500. (b"aa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.AyUxBk.ThHlsLvRTH7IqcG7yVHJ3SXq"),
  501. (b"aaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.BxOVac5xPB6XFdRc/ZrzM9FgZkqmvbW"),
  502. (b"aaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.Qbr209bpCtfl5hN7UQlG/L4xiD3AKau"),
  503. (b"aaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.oWszihPjDZI0ypReKsaDOW1jBl7oOii"),
  504. (b"aaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ./k.Xxn9YiqtV/sxh3EHbnOHd0Qsq27K"),
  505. (b"aaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.PYJqRFQbgRbIjMd5VNKmdKS4sBVOyDe"),
  506. (b"aaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ..VMYfzaw1wP/SGxowpLeGf13fxCCt.q"),
  507. (b"aaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.5B0p054nO5WgAD1n04XslDY/bqY9RJi"),
  508. (b"aaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.INBTgqm7sdlBJDg.J5mLMSRK25ri04y"),
  509. (b"aaaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.s3y7CdFD0OR5p6rsZw/eZ.Dla40KLfm"),
  510. (b"aaaaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.Jx742Djra6Q7PqJWnTAS.85c28g.Siq"),
  511. (b"aaaaaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.oKMXW3EZcPHcUV0ib5vDBnh9HojXnLu"),
  512. (b"aaaaaaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.w6nIjWpDPNSH5pZUvLjC1q25ONEQpeS"),
  513. (b"aaaaaaaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.k1b2/r9A/hxdwKEKurg6OCn4MwMdiGq"),
  514. (b"aaaaaaaaaaaaaaaa", 4, b"5DCebwootqWMCp59ISrMJ.", b"$2a$04$5DCebwootqWMCp59ISrMJ.3prCNHVX1Ws.7Hm2bJxFUnQOX9f7DFa"),
  515. ]
  516. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  517. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  518. self.assertEqual(x, result)
  519. bcrypt_check(password, result)
  520. def test_non_ascii_characters(self):
  521. # password, cost, salt, bcrypt hash
  522. tvs = [
  523. ("àèìòùÀÈÌÒÙáéíóúýÁÉÍÓÚÝðÐ", 4, b"D3qS2aoTVyqM7z8v8crLm.", b"$2a$04$D3qS2aoTVyqM7z8v8crLm.3nKt4CzBZJbyFB.ZebmfCvRw7BGs.Xm"),
  524. ("àèìòùÀÈÌÒÙáéíóúýÁÉÍÓÚÝðÐ", 5, b"VA1FujiOCMPkUHQ8kF7IaO", b"$2a$05$VA1FujiOCMPkUHQ8kF7IaOg7NGaNvpxwWzSluQutxEVmbZItRTsAa"),
  525. ("àèìòùÀÈÌÒÙáéíóúýÁÉÍÓÚÝðÐ", 6, b"TXiaNrPeBSz5ugiQlehRt.", b"$2a$06$TXiaNrPeBSz5ugiQlehRt.gwpeDQnXWteQL4z2FulouBr6G7D9KUi"),
  526. ("âêîôûÂÊÎÔÛãñõÃÑÕäëïöüÿ", 4, b"YTn1Qlvps8e1odqMn6G5x.", b"$2a$04$YTn1Qlvps8e1odqMn6G5x.85pqKql6w773EZJAExk7/BatYAI4tyO"),
  527. ("âêîôûÂÊÎÔÛãñõÃÑÕäëïöüÿ", 5, b"C.8k5vJKD2NtfrRI9o17DO", b"$2a$05$C.8k5vJKD2NtfrRI9o17DOfIW0XnwItA529vJnh2jzYTb1QdoY0py"),
  528. ("âêîôûÂÊÎÔÛãñõÃÑÕäëïöüÿ", 6, b"xqfRPj3RYAgwurrhcA6uRO", b"$2a$06$xqfRPj3RYAgwurrhcA6uROtGlXDp/U6/gkoDYHwlubtcVcNft5.vW"),
  529. ("ÄËÏÖÜŸåÅæÆœŒßçÇøØ¢¿¡€", 4, b"y8vGgMmr9EdyxP9rmMKjH.", b"$2a$04$y8vGgMmr9EdyxP9rmMKjH.wv2y3r7yRD79gykQtmb3N3zrwjKsyay"),
  530. ("ÄËÏÖÜŸåÅæÆœŒßçÇøØ¢¿¡€", 5, b"iYH4XIKAOOm/xPQs7xKP1u", b"$2a$05$iYH4XIKAOOm/xPQs7xKP1upD0cWyMn3Jf0ZWiizXbEkVpS41K1dcO"),
  531. ("ÄËÏÖÜŸåÅæÆœŒßçÇøØ¢¿¡€", 6, b"wCOob.D0VV8twafNDB2ape", b"$2a$06$wCOob.D0VV8twafNDB2apegiGD5nqF6Y1e6K95q6Y.R8C4QGd265q"),
  532. ("ΔημοσιεύθηκεστηνΕφημερίδατης", 4, b"E5SQtS6P4568MDXW7cyUp.", b"$2a$04$E5SQtS6P4568MDXW7cyUp.18wfDisKZBxifnPZjAI1d/KTYMfHPYO"),
  533. ("АБбВвГгДдЕеЁёЖжЗзИиЙйКкЛлМмН", 4, b"03e26gQFHhQwRNf81/ww9.", b"$2a$04$03e26gQFHhQwRNf81/ww9.p1UbrNwxpzWjLuT.zpTLH4t/w5WhAhC"),
  534. ("нОоПпРрСсТтУуФфХхЦцЧчШшЩщЪъЫыЬьЭэЮю", 4, b"PHNoJwpXCfe32nUtLv2Upu", b"$2a$04$PHNoJwpXCfe32nUtLv2UpuhJXOzd4k7IdFwnEpYwfJVCZ/f/.8Pje"),
  535. ("電电電島岛島兔兔兎龜龟亀國国国區区区", 4, b"wU4/0i1TmNl2u.1jIwBX.u", b"$2a$04$wU4/0i1TmNl2u.1jIwBX.uZUaOL3Rc5ID7nlQRloQh6q5wwhV/zLW"),
  536. ("诶比伊艾弗豆贝尔维吾艾尺开艾丝维贼德", 4, b"P4kreGLhCd26d4WIy7DJXu", b"$2a$04$P4kreGLhCd26d4WIy7DJXusPkhxLvBouzV6OXkL5EB0jux0osjsry"),
  537. ]
  538. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  539. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  540. self.assertEqual(x, result)
  541. bcrypt_check(password, result)
  542. def test_special_case_salt(self):
  543. # password, cost, salt, bcrypt hash
  544. tvs = [
  545. ("-O_=*N!2JP", 4, b"......................", b"$2a$04$......................JjuKLOX9OOwo5PceZZXSkaLDvdmgb82"),
  546. ("7B[$Q<4b>U", 5, b"......................", b"$2a$05$......................DRiedDQZRL3xq5A5FL8y7/6NM8a2Y5W"),
  547. (">d5-I_8^.h", 6, b"......................", b"$2a$06$......................5Mq1Ng8jgDY.uHNU4h5p/x6BedzNH2W"),
  548. (")V`/UM/]1t", 4, b".OC/.OC/.OC/.OC/.OC/.O", b"$2a$04$.OC/.OC/.OC/.OC/.OC/.OQIvKRDAam.Hm5/IaV/.hc7P8gwwIbmi"),
  549. (":@t2.bWuH]", 5, b".OC/.OC/.OC/.OC/.OC/.O", b"$2a$05$.OC/.OC/.OC/.OC/.OC/.ONDbUvdOchUiKmQORX6BlkPofa/QxW9e"),
  550. ("b(#KljF5s\"", 6, b".OC/.OC/.OC/.OC/.OC/.O", b"$2a$06$.OC/.OC/.OC/.OC/.OC/.OHfTd9e7svOu34vi1PCvOcAEq07ST7.K"),
  551. ("@3YaJ^Xs]*", 4, b"eGA.eGA.eGA.eGA.eGA.e.", b"$2a$04$eGA.eGA.eGA.eGA.eGA.e.stcmvh.R70m.0jbfSFVxlONdj1iws0C"),
  552. ("'\"5\\!k*C(p", 5, b"eGA.eGA.eGA.eGA.eGA.e.", b"$2a$05$eGA.eGA.eGA.eGA.eGA.e.vR37mVSbfdHwu.F0sNMvgn8oruQRghy"),
  553. ("edEu7C?$'W", 6, b"eGA.eGA.eGA.eGA.eGA.e.", b"$2a$06$eGA.eGA.eGA.eGA.eGA.e.tSq0FN8MWHQXJXNFnHTPQKtA.n2a..G"),
  554. ("N7dHmg\\PI^", 4, b"999999999999999999999u", b"$2a$04$999999999999999999999uCZfA/pLrlyngNDMq89r1uUk.bQ9icOu"),
  555. ("\"eJuHh!)7*", 5, b"999999999999999999999u", b"$2a$05$999999999999999999999uj8Pfx.ufrJFAoWFLjapYBS5vVEQQ/hK"),
  556. ("ZeDRJ:_tu:", 6, b"999999999999999999999u", b"$2a$06$999999999999999999999u6RB0P9UmbdbQgjoQFEJsrvrKe.BoU6q"),
  557. ]
  558. for (idx, (password, cost, salt64, result)) in enumerate(tvs):
  559. x = bcrypt(password, cost, salt=_bcrypt_decode(salt64))
  560. self.assertEqual(x, result)
  561. bcrypt_check(password, result)
  562. class TestVectorsHKDFWycheproof(unittest.TestCase):
  563. def __init__(self, wycheproof_warnings):
  564. unittest.TestCase.__init__(self)
  565. self._wycheproof_warnings = wycheproof_warnings
  566. self._id = "None"
  567. def add_tests(self, filename):
  568. def filter_algo(root):
  569. algo_name = root['algorithm']
  570. if algo_name == "HKDF-SHA-1":
  571. return SHA1
  572. elif algo_name == "HKDF-SHA-256":
  573. return SHA256
  574. elif algo_name == "HKDF-SHA-384":
  575. return SHA384
  576. elif algo_name == "HKDF-SHA-512":
  577. return SHA512
  578. else:
  579. raise ValueError("Unknown algorithm " + algo_name)
  580. def filter_size(unit):
  581. return int(unit['size'])
  582. result = load_test_vectors_wycheproof(("Protocol", "wycheproof"),
  583. filename,
  584. "Wycheproof HMAC (%s)" % filename,
  585. root_tag={'hash_module': filter_algo},
  586. unit_tag={'size': filter_size})
  587. return result
  588. def setUp(self):
  589. self.tv = []
  590. self.add_tests("hkdf_sha1_test.json")
  591. self.add_tests("hkdf_sha256_test.json")
  592. self.add_tests("hkdf_sha384_test.json")
  593. self.add_tests("hkdf_sha512_test.json")
  594. def shortDescription(self):
  595. return self._id
  596. def warn(self, tv):
  597. if tv.warning and self._wycheproof_warnings:
  598. import warnings
  599. warnings.warn("Wycheproof warning: %s (%s)" % (self._id, tv.comment))
  600. def test_verify(self, tv):
  601. self._id = "Wycheproof HKDF Test #%d (%s, %s)" % (tv.id, tv.comment, tv.filename)
  602. try:
  603. key = HKDF(tv.ikm, tv.size, tv.salt, tv.hash_module, 1, tv.info)
  604. except ValueError:
  605. assert not tv.valid
  606. else:
  607. if key != tv.okm:
  608. assert not tv.valid
  609. else:
  610. assert tv.valid
  611. self.warn(tv)
  612. def runTest(self):
  613. for tv in self.tv:
  614. self.test_verify(tv)
  615. def get_tests(config={}):
  616. wycheproof_warnings = config.get('wycheproof_warnings')
  617. if not config.get('slow_tests'):
  618. PBKDF2_Tests._testData = PBKDF2_Tests._testData[:3]
  619. scrypt_Tests.data = scrypt_Tests.data[:3]
  620. tests = []
  621. tests += list_test_cases(PBKDF1_Tests)
  622. tests += list_test_cases(PBKDF2_Tests)
  623. tests += list_test_cases(S2V_Tests)
  624. tests += list_test_cases(HKDF_Tests)
  625. tests += [TestVectorsHKDFWycheproof(wycheproof_warnings)]
  626. tests += list_test_cases(scrypt_Tests)
  627. tests += list_test_cases(bcrypt_Tests)
  628. return tests
  629. if __name__ == '__main__':
  630. suite = lambda: unittest.TestSuite(get_tests())
  631. unittest.main(defaultTest='suite')