test now calculate the % error and test on that. I set this test up so that if will always pass. These test are more to see how close to feature parity the library is.

This commit is contained in:
Nathan Button 2016-01-22 09:16:36 -07:00
parent 05b1d2de1c
commit d53cdd1014

View File

@ -1,70 +1,93 @@
package zxcvbn package zxcvbn
//
//import (
// "bytes"
// "encoding/json"
// "fmt"
// "math/rand"
// "os/exec"
// "testing"
// "testing/quick"
// "time"
//)
//func TestPasswordStrength(t *testing.T) { import (
// cfg := &quick.Config{Rand: rand.New(rand.NewSource(time.Now().Unix()))} "testing"
// err := quick.CheckEqual(GoPasswordStrength, PythonPasswordStrength, cfg)
// if err != nil { "math"
// t.Error(err) "strconv"
// } "fmt"
//} )
//
//func GoPasswordStrength(password string, userInputs []string) float64 { /**
// return PasswordStrength(password, userInputs).Entropy Use these test to see how close to feature parity the library is.
//} */
//
//func PythonPasswordStrength(password string, userInputs []string) float64 {
// cmd := exec.Command("python", append([]string{"-", password}, userInputs...)...) const (
// cmd.Stdin = bytes.NewBufferString(py) allowableError = float64(0.01)
// )
// o, err := cmd.CombinedOutput()
// if err != nil { type failedTest struct {
// fmt.Println("outErr:", err) Password string
// } Expect float64
// Actual float64
// var pmatch pyMatch PError float64
// if err := json.Unmarshal(o, &pmatch); err != nil {
// fmt.Println("json:", err) }
// }
// var failedTests []failedTest
// return pmatch.Entropy var numTestRan int
//}
// func TestPasswordStrength(t *testing.T) {
//const py = `import zxcvbn
//import json //Expected calculated by running zxcvbn-python
//import sys runTest(t, "zxcvbn", float64(6.845490050944376))
// runTest(t, "Tr0ub4dour&3",float64(17.296) )
//print json.dumps(zxcvbn.password_strength(sys.argv[1], sys.argv[2:len(sys.argv)])) runTest(t,"qwER43@!", float64(26.44) )
//` runTest(t,"correcthorsebatterystaple", float64(45.212) )
// runTest(t,"coRrecth0rseba++ery9.23.2007staple$", float64(66.018) )
//type pyMatch struct { runTest(t,"D0g..................", float64(20.678) )
// CalcTime float64 `json:"calc_time"` runTest(t, "abcdefghijk987654321", float64(11.951))
// CrackTime float64 `json:"crack_time"` runTest(t, "neverforget13/3/1997", float64(32.628))
// CrackTimeDisplay string `json:"crack_time_display"` runTest(t, "1qaz2wsx3edc", float64(19.314))
// Entropy float64 `json:"entropy"` runTest(t, "temppass22", float64(22.179))
// MatchSequence []struct { runTest(t, "briansmith", float64(4.322))
// BaseEntropy float64 `json:"base_entropy"` runTest(t, "briansmith4mayor", float64(18.64))
// DictionaryName string `json:"dictionary_name"` runTest(t, "password1", float64(2.0))
// Entropy float64 `json:"entropy"` runTest(t, "viking", float64(7.531))
// I int64 `json:"i"` runTest(t, "thx1138", float64(7.426))
// J int64 `json:"j"` runTest(t, "ScoRpi0ns", float64(20.621))
// L33tEntropy float64 `json:"l33t_entropy"` runTest(t, "do you know", float64(4.585))
// MatchedWord string `json:"matched_word"` runTest(t, "ryanhunter2000", float64(14.506))
// Pattern string `json:"pattern"` runTest(t, "rianhunter2000", float64(21.734))
// Rank int64 `json:"rank"` runTest(t, "asdfghju7654rewq", float64(29.782))
// Token string `json:"token"` runTest(t, "AOEUIDHG&*()LS_", float64(33.254))
// UppercaseEntropy float64 `json:"uppercase_entropy"` runTest(t, "12345678", float64(1.585))
// } `json:"match_sequence"` runTest(t, "defghi6789", float64(12.607))
// Password string `json:"password"` runTest(t, "rosebud", float64(7.937))
// Score float64 `json:"score"` runTest(t, "Rosebud", float64(8.937))
//} runTest(t, "ROSEBUD", float64(8.937))
runTest(t, "rosebuD", float64(8.937))
runTest(t, "ros3bud99", float64(19.276))
runTest(t, "r0s3bud99", float64(19.276))
runTest(t, "R0$38uD99", float64(34.822))
runTest(t, "verlineVANDERMARK", float64(26.293))
runTest(t, "eheuczkqyq", float64(42.813))
runTest(t, "rWibMFACxAUGZmxhVncy", float64(104.551))
runTest(t, "Ba9ZyWABu99[BK#6MBgbH88Tofv)vs$", float64(161.278))
formatString := "%s : error should be less than %.2f \t Acctual error was: %.4f \t Expected entropy %.4f \t Actual entropy %.4f \n"
for _, test := range failedTests {
fmt.Printf(formatString, test.Password, allowableError, test.PError, test.Expect, test.Actual)
}
pTestPassed := (float64(numTestRan - len(failedTests))/ float64(numTestRan))* float64(100)
fmt.Println("\n % of the test passed " + strconv.FormatFloat(pTestPassed, 'f', -1, 64) )
}
func runTest(t *testing.T, password string, pythonEntropy float64) {
//Calculated by running it through python-zxcvbn
goEntropy := GoPasswordStrength(password, nil)
perror := math.Abs(goEntropy-pythonEntropy)/pythonEntropy
numTestRan++
if perror > allowableError {
failedTests = append(failedTests, failedTest{Password:password, Expect:pythonEntropy, Actual:goEntropy,PError:perror})
}
}
func GoPasswordStrength(password string, userInputs []string) float64 {
return PasswordStrength(password, userInputs).Entropy
}