2015-10-05 13:56:21 -06:00
|
|
|
package matching
|
2016-01-13 15:02:53 -07:00
|
|
|
|
2015-10-05 13:56:21 -06:00
|
|
|
import (
|
2016-06-19 22:33:56 +09:00
|
|
|
"log"
|
2016-01-19 11:59:29 -07:00
|
|
|
"strings"
|
2015-10-05 13:56:21 -06:00
|
|
|
"testing"
|
2018-05-09 17:19:29 -03:00
|
|
|
|
|
|
|
"github.com/nbutton23/zxcvbn-go/match"
|
|
|
|
"github.com/stretchr/testify/assert"
|
2015-10-05 13:56:21 -06:00
|
|
|
)
|
2016-01-13 15:02:53 -07:00
|
|
|
|
2015-10-05 13:56:21 -06:00
|
|
|
//DateSepMatch("1991-09-11jibjab11.9.1991")
|
2016-01-13 15:02:53 -07:00
|
|
|
//[{date 16 25 . 9 11 1991} {date 0 10 - 9 11 1991}]
|
2015-10-05 13:56:21 -06:00
|
|
|
|
2017-11-02 08:15:20 -07:00
|
|
|
//TODO think about how to write this test. . .
|
|
|
|
//func TestDateSepMatch(t *testing.T) {
|
|
|
|
// matches := dateSepMatchHelper("1991-09-11jibjab11.9.1991")
|
|
|
|
//
|
|
|
|
// assert.Len(t, matches, 2, "Length should be 2")
|
|
|
|
//
|
|
|
|
// for _, match := range matches {
|
|
|
|
// if match.Separator == "." {
|
|
|
|
// assert.Equal(t, 16, match.I)
|
|
|
|
// assert.Equal(t, 25, match.J)
|
|
|
|
// assert.Equal(t, int64(9), match.Day)
|
|
|
|
// assert.Equal(t, int64(11), match.Month)
|
|
|
|
// assert.Equal(t, int64(1991), match.Year)
|
|
|
|
// } else {
|
|
|
|
// assert.Equal(t, 0, match.I)
|
|
|
|
// assert.Equal(t, 10, match.J)
|
|
|
|
// assert.Equal(t, int64(9), match.Day)
|
|
|
|
// assert.Equal(t, int64(11), match.Month)
|
|
|
|
// assert.Equal(t, int64(1991), match.Year)
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
//}
|
|
|
|
//
|
2016-01-19 11:59:29 -07:00
|
|
|
func TestRepeatMatch(t *testing.T) {
|
|
|
|
//aaaBbBb
|
2016-03-08 09:57:50 -07:00
|
|
|
matches := repeatMatch("aaabBbB")
|
2016-01-19 11:59:29 -07:00
|
|
|
|
|
|
|
assert.Len(t, matches, 2, "Lenght should be 2")
|
|
|
|
|
|
|
|
for _, match := range matches {
|
2016-01-21 15:26:33 -07:00
|
|
|
if strings.ToLower(match.DictionaryName) == "b" {
|
2016-01-19 11:59:29 -07:00
|
|
|
assert.Equal(t, 3, match.I)
|
|
|
|
assert.Equal(t, 6, match.J)
|
|
|
|
assert.Equal(t, "bBbB", match.Token)
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, match.Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
} else {
|
|
|
|
assert.Equal(t, 0, match.I)
|
|
|
|
assert.Equal(t, 2, match.J)
|
|
|
|
assert.Equal(t, "aaa", match.Token)
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, match.Entropy, "Entropy should be set")
|
|
|
|
|
2016-01-19 11:59:29 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSequenceMatch(t *testing.T) {
|
|
|
|
//abcdjibjacLMNOPjibjac1234 => abcd LMNOP 1234
|
|
|
|
|
2016-03-08 09:57:50 -07:00
|
|
|
matches := sequenceMatch("abcdjibjacLMNOPjibjac1234")
|
2017-11-02 08:15:20 -07:00
|
|
|
assert.Len(t, matches, 3, "Lenght should be 3")
|
2016-01-19 11:59:29 -07:00
|
|
|
|
|
|
|
for _, match := range matches {
|
|
|
|
if match.DictionaryName == "lower" {
|
|
|
|
assert.Equal(t, 0, match.I)
|
|
|
|
assert.Equal(t, 3, match.J)
|
|
|
|
assert.Equal(t, "abcd", match.Token)
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, match.Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
} else if match.DictionaryName == "upper" {
|
|
|
|
assert.Equal(t, 10, match.I)
|
|
|
|
assert.Equal(t, 14, match.J)
|
|
|
|
assert.Equal(t, "LMNOP", match.Token)
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, match.Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
} else if match.DictionaryName == "digits" {
|
|
|
|
assert.Equal(t, 21, match.I)
|
|
|
|
assert.Equal(t, 24, match.J)
|
|
|
|
assert.Equal(t, "1234", match.Token)
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, match.Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
} else {
|
|
|
|
assert.True(t, false, "Unknow dictionary")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSpatialMatchQwerty(t *testing.T) {
|
2016-03-08 09:57:50 -07:00
|
|
|
matches := spatialMatch("qwerty")
|
2016-01-19 11:59:29 -07:00
|
|
|
assert.Len(t, matches, 1, "Lenght should be 1")
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, matches[0].Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
|
2016-03-08 09:57:50 -07:00
|
|
|
matches = spatialMatch("asdf")
|
2016-01-19 11:59:29 -07:00
|
|
|
assert.Len(t, matches, 1, "Lenght should be 1")
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, matches[0].Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSpatialMatchDvorak(t *testing.T) {
|
2016-03-08 09:57:50 -07:00
|
|
|
matches := spatialMatch("aoeuidhtns")
|
2016-01-19 11:59:29 -07:00
|
|
|
assert.Len(t, matches, 1, "Lenght should be 1")
|
2016-01-21 15:26:33 -07:00
|
|
|
assert.NotZero(t, matches[0].Entropy, "Entropy should be set")
|
2016-01-19 11:59:29 -07:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDictionaryMatch(t *testing.T) {
|
|
|
|
var matches []match.Match
|
2018-08-28 20:30:34 -06:00
|
|
|
for _, dicMatcher := range dictionaryMatchers {
|
2017-11-02 08:15:20 -07:00
|
|
|
matchesTemp := dicMatcher.MatchingFunc("first")
|
2016-01-19 11:59:29 -07:00
|
|
|
matches = append(matches, matchesTemp...)
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.Len(t, matches, 4, "Lenght should be 4")
|
2016-01-21 15:26:33 -07:00
|
|
|
for _, match := range matches {
|
|
|
|
assert.NotZero(t, match.Entropy, "Entropy should be set")
|
|
|
|
|
|
|
|
}
|
2016-01-19 11:59:29 -07:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDateWithoutSepMatch(t *testing.T) {
|
|
|
|
matches := dateWithoutSepMatch("11091991")
|
|
|
|
assert.Len(t, matches, 1, "Lenght should be 1")
|
2016-05-29 18:11:57 -06:00
|
|
|
|
|
|
|
matches = dateWithoutSepMatch("20010911")
|
|
|
|
assert.Len(t, matches, 1, "Lenght should be 1")
|
|
|
|
log.Println(matches)
|
|
|
|
|
|
|
|
//matches := dateWithoutSepMatch("110991")
|
|
|
|
//assert.Len(t, matches, 21, "Lenght should be blarg")
|
2016-01-19 11:59:29 -07:00
|
|
|
}
|