-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhasher_test.go
79 lines (64 loc) · 1.49 KB
/
hasher_test.go
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package gocrypto_test
import (
"testing"
"github.com/mekramy/gocrypto"
)
func TestArgon2(t *testing.T) {
password := []byte("pass12341fadsfasf@!#@$")
hasher := gocrypto.NewArgon2Hasher(0, 0, 0, 0, 0)
hashed, err := hasher.Hash(password)
if err != nil {
t.Fatal(err)
}
same, err := hasher.Validate(hashed, password)
if err != nil {
t.Fatal(err)
} else if !same {
t.Error("validate failed")
}
}
func TestBCrypt(t *testing.T) {
password := []byte("pass12341fadsfasf@!#@$")
hasher := gocrypto.NewBcryptHasher(0)
hashed, err := hasher.Hash(password)
if err != nil {
t.Fatal(err)
}
same, err := hasher.Validate(hashed, password)
if err != nil {
t.Fatal(err)
} else if !same {
t.Error("validate failed")
}
}
func TestHMac(t *testing.T) {
password := []byte("pass12341fadsfasf@!#@$")
algos := []gocrypto.HashingAlgo{
gocrypto.MD5, gocrypto.SHA1,
gocrypto.SHA224, gocrypto.SHA256,
gocrypto.SHA384, gocrypto.SHA512,
gocrypto.SHA3224, gocrypto.SHA3256,
gocrypto.SHA3384, gocrypto.SHA3512,
}
// Generate random key
key, err := gocrypto.NewSimpleKey(gocrypto.Simple32)
if err != nil {
t.Fatal(err)
}
// Test all algos
for _, algo := range algos {
t.Run(string(algo), func(t *testing.T) {
hasher := gocrypto.HMacHasher(key, algo)
hashed, err := hasher.Hash(password)
if err != nil {
t.Fatal(err)
}
same, err := hasher.Validate(hashed, password)
if err != nil {
t.Fatal(err)
} else if !same {
t.Error("validate failed")
}
})
}
}