summary refs log tree commit diff stats
path: root/auth/checkpass_test.go
blob: c8afaee93bbe363ad8c5531a143a821d54c7f72a (plain) (blame)
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
package auth

import "testing"

// TestCheckPass tests the checkPass function.
func TestCheckPass(t *testing.T) {
	var err error
	passhash := make(map[string]string)

	// First we check with static values, these should always pass.
	passhash["ter4cQ=="] = "$2a$10$ANkaNEFFQ4zxDwTwvAUfoOCqpVIdgtPFopFOTMSrFy39WkaMAYLIC"
	passhash["G29J6A=="] = "$2a$10$1oH1PyhncIHcHJWbLt3Gv.OjClUoFoaEDaFpQ9E9atfRbIrVxsbwm"
	passhash["Z1S/kQ=="] = "$2a$10$fZ05kKmb7bh4vBLebpK1u.3bUNQ6eeX5ghT/GZaekgS.5bx4.Ru1e"
	passhash["J861dQ=="] = "$2a$10$nXb6Btn6n3AWMAUkDh9bFObvQw5V9FLKhfX.E1EzRWgVDuqIp99u2"

	// We also check with values generated with hashPass, this may
	// fail if hashPass itself fails in that case it's not
	// checkPass error so the test shouldn't fail but warning
	// should be sent. We use genID func to generate random inputs
	// for this test.
	for i := 1; i <= 4; i++ {
		p := genID(8)
		passhash[p], err = hashPass(p)
		if err != nil {
			t.Log("hashPass func failed")
		}
	}

	// We test the checkPass func by ranging over all values of
	// passhash. We assume that hashPass func returns correct
	// hashes.
	for p, h := range passhash {
		err = checkPass(p, h)
		if err != nil {
			t.Errorf("password: %s, hash: %s didn't match.",
				p, h)
		}
	}

}