]> git.openstreetmap.org Git - rails.git/blob - test/lib/password_hash_test.rb
Merge pull request #5932 from tomhughes/frozen-strings
[rails.git] / test / lib / password_hash_test.rb
1 # frozen_string_literal: true
2
3 require "test_helper"
4
5 class PasswordHashTest < ActiveSupport::TestCase
6   def test_md5_without_salt
7     assert PasswordHash.check("5f4dcc3b5aa765d61d8327deb882cf99", nil, "password")
8     assert_not PasswordHash.check("5f4dcc3b5aa765d61d8327deb882cf99", nil, "wrong")
9     assert PasswordHash.upgrade?("5f4dcc3b5aa765d61d8327deb882cf99", nil)
10   end
11
12   def test_md5_with_salt
13     assert PasswordHash.check("67a1e09bb1f83f5007dc119c14d663aa", "salt", "password")
14     assert_not PasswordHash.check("67a1e09bb1f83f5007dc119c14d663aa", "salt", "wrong")
15     assert_not PasswordHash.check("67a1e09bb1f83f5007dc119c14d663aa", "wrong", "password")
16     assert PasswordHash.upgrade?("67a1e09bb1f83f5007dc119c14d663aa", "salt")
17   end
18
19   def test_pbkdf2_1000_32_sha512
20     assert PasswordHash.check("ApT/28+FsTBLa/J8paWfgU84SoRiTfeY8HjKWhgHy08=", "sha512!1000!HR4z+hAvKV2ra1gpbRybtoNzm/CNKe4cf7bPKwdUNrk=", "password")
21     assert_not PasswordHash.check("ApT/28+FsTBLa/J8paWfgU84SoRiTfeY8HjKWhgHy08=", "sha512!1000!HR4z+hAvKV2ra1gpbRybtoNzm/CNKe4cf7bPKwdUNrk=", "wrong")
22     assert_not PasswordHash.check("ApT/28+FsTBLa/J8paWfgU84SoRiTfeY8HjKWhgHy08=", "sha512!1000!HR4z+hAvKV2ra1gwrongtoNzm/CNKe4cf7bPKwdUNrk=", "password")
23     assert PasswordHash.upgrade?("ApT/28+FsTBLa/J8paWfgU84SoRiTfeY8HjKWhgHy08=", "sha512!1000!HR4z+hAvKV2ra1gpbRybtoNzm/CNKe4cf7bPKwdUNrk=")
24   end
25
26   def test_pbkdf2_10000_32_sha512
27     assert PasswordHash.check("3wYbPiOxk/tU0eeIDjUhdvi8aDP3AbFtwYKKxF1IhGg=", "sha512!10000!OUQLgtM7eD8huvanFT5/WtWaCwdOdrir8QOtFwxhO0A=", "password")
28     assert_not PasswordHash.check("3wYbPiOxk/tU0eeIDjUhdvi8aDP3AbFtwYKKxF1IhGg=", "sha512!10000!OUQLgtM7eD8huvanFT5/WtWaCwdOdrir8QOtFwxhO0A=", "wrong")
29     assert_not PasswordHash.check("3wYbPiOxk/tU0eeIDjUhdvi8aDP3AbFtwYKKxF1IhGg=", "sha512!10000!OUQLgtMwronguvanFT5/WtWaCwdOdrir8QOtFwxhO0A=", "password")
30     assert PasswordHash.upgrade?("3wYbPiOxk/tU0eeIDjUhdvi8aDP3AbFtwYKKxF1IhGg=", "sha512!10000!OUQLgtM7eD8huvanFT5/WtWaCwdOdrir8QOtFwxhO0A=")
31   end
32
33   def test_argon2_t2_m16_p1
34     assert PasswordHash.check("$argon2id$v=19$m=65536,t=2,p=1$b2E7zSvjT6TC5DXrqvfxwg$P4hly807ckgYc+kfvaf3rqmJcmKStzw+kV14oMaz8PQ", nil, "password")
35     assert_not PasswordHash.check("$argon2id$v=19$m=65536,t=2,p=1$b2E7zSvjT6TC5DXrqvfxwg$P4hly807ckgYc+kfvaf3rqmJcmKStzw+kV14oMaz8PQ", nil, "wrong")
36     assert_not PasswordHash.check("$argon2id$v=19$m=65536,t=2,p=1$b2E7zSvwrong5DXrqvfxwg$P4hly807ckgYc+kfvaf3rqmJcmKStzw+kV14oMaz8PQ", nil, "password")
37     assert PasswordHash.upgrade?("$argon2id$v=19$m=65536,t=2,p=1$b2E7zSvjT6TC5DXrqvfxwg$P4hly807ckgYc+kfvaf3rqmJcmKStzw+kV14oMaz8PQ", nil)
38   end
39
40   def test_argon2_t3_m16_p4
41     assert PasswordHash.check("$argon2id$v=19$m=65536,t=3,p=4$uxzL4aYTEDTRr2+KNA1qNQ$yuNOtH+IsCwWUbE4OGu+hIC0e4iyZ2wGhaCsQY1mJpI", nil, "password")
42     assert_not PasswordHash.check("$argon2id$v=19$m=65536,t=3,p=4$uxzL4aYTEDTRr2+KNA1qNQ$yuNOtH+IsCwWUbE4OGu+hIC0e4iyZ2wGhaCsQY1mJpI", nil, "wrong")
43     assert_not PasswordHash.check("$argon2id$v=19$m=65536,t=3,p=4$uxzL4aYwrongr2+KNA1qNQ$yuNOtH+IsCwWUbE4OGu+hIC0e4iyZ2wGhaCsQY1mJpI", nil, "password")
44     assert_not PasswordHash.upgrade?("$argon2id$v=19$m=65536,t=3,p=4$uxzL4aYTEDTRr2+KNA1qNQ$yuNOtH+IsCwWUbE4OGu+hIC0e4iyZ2wGhaCsQY1mJpI", nil)
45   end
46
47   def test_default
48     hash1, salt1 = PasswordHash.create("password")
49     hash2, salt2 = PasswordHash.create("password")
50     assert_not_equal hash1, hash2
51     assert_nil salt1
52     assert_nil salt2
53     assert PasswordHash.check(hash1, salt1, "password")
54     assert_not PasswordHash.check(hash1, salt1, "wrong")
55     assert PasswordHash.check(hash2, salt2, "password")
56     assert_not PasswordHash.check(hash2, salt2, "wrong")
57     assert_not PasswordHash.upgrade?(hash1, salt1)
58     assert_not PasswordHash.upgrade?(hash2, salt2)
59   end
60
61   def test_format
62     hash, _salt = PasswordHash.create("password")
63     format = Argon2::HashFormat.new(hash)
64
65     assert_equal "argon2id", format.variant
66     assert_operator format.version, :<=, 19
67   end
68 end