2015-01-18 09:37:05 +02:00
|
|
|
package authboss
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestErrorList_Error(t *testing.T) {
|
2015-01-21 08:41:31 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2015-01-18 09:37:05 +02:00
|
|
|
errList := ErrorList{errors.New("one"), errors.New("two")}
|
|
|
|
if e := errList.Error(); e != "one, two" {
|
|
|
|
t.Error("Wrong value for error:", e)
|
|
|
|
}
|
|
|
|
}
|
2015-01-21 08:41:31 +02:00
|
|
|
|
|
|
|
func TestErrorList_Map(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
errNotLong := "not long enough"
|
|
|
|
errEmail := "should be an email"
|
|
|
|
errAsploded := "asploded"
|
|
|
|
|
|
|
|
errList := ErrorList{
|
2015-02-22 23:16:11 +02:00
|
|
|
FieldError{StoreUsername, errors.New(errNotLong)},
|
|
|
|
FieldError{StoreUsername, errors.New(errEmail)},
|
|
|
|
FieldError{StorePassword, errors.New(errNotLong)},
|
2015-01-21 08:41:31 +02:00
|
|
|
errors.New(errAsploded),
|
|
|
|
}
|
|
|
|
|
|
|
|
m := errList.Map()
|
|
|
|
if len(m) != 3 {
|
|
|
|
t.Error("Wrong number of fields:", len(m))
|
|
|
|
}
|
|
|
|
|
2015-02-22 23:16:11 +02:00
|
|
|
usernameErrs := m[StoreUsername]
|
2015-01-21 08:41:31 +02:00
|
|
|
if len(usernameErrs) != 2 {
|
|
|
|
t.Error("Wrong number of username errors:", len(usernameErrs))
|
|
|
|
}
|
|
|
|
if usernameErrs[0] != errNotLong {
|
|
|
|
t.Error("Wrong username error at 0:", usernameErrs[0])
|
|
|
|
}
|
|
|
|
if usernameErrs[1] != errEmail {
|
|
|
|
t.Error("Wrong username error at 1:", usernameErrs[1])
|
|
|
|
}
|
|
|
|
|
2015-02-22 23:16:11 +02:00
|
|
|
passwordErrs := m[StorePassword]
|
2015-01-21 08:41:31 +02:00
|
|
|
if len(passwordErrs) != 1 {
|
|
|
|
t.Error("Wrong number of password errors:", len(passwordErrs))
|
|
|
|
}
|
|
|
|
if passwordErrs[0] != errNotLong {
|
|
|
|
t.Error("Wrong password error at 0:", passwordErrs[0])
|
|
|
|
}
|
|
|
|
|
|
|
|
unknownErrs := m[""]
|
|
|
|
if len(unknownErrs) != 1 {
|
|
|
|
t.Error("Wrong number of unkown errors:", len(unknownErrs))
|
|
|
|
}
|
|
|
|
if unknownErrs[0] != errAsploded {
|
|
|
|
t.Error("Wrong unkown error at 0:", unknownErrs[0])
|
|
|
|
}
|
|
|
|
}
|
2015-01-25 02:07:41 +02:00
|
|
|
|
|
|
|
func TestValidate(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab := New()
|
|
|
|
ctx := mockRequestContext(ab, StoreUsername, "john", StoreEmail, "john@john.com")
|
2015-01-25 02:07:41 +02:00
|
|
|
|
|
|
|
errList := ctx.Validate([]Validator{
|
|
|
|
mockValidator{
|
2015-02-22 23:16:11 +02:00
|
|
|
FieldName: StoreUsername,
|
|
|
|
Errs: ErrorList{FieldError{StoreUsername, errors.New("must be longer than 4")}},
|
2015-01-25 02:07:41 +02:00
|
|
|
},
|
|
|
|
mockValidator{
|
2015-01-26 01:40:57 +02:00
|
|
|
FieldName: "missing_field",
|
|
|
|
Errs: ErrorList{FieldError{"missing_field", errors.New("Expected field to exist.")}},
|
2015-01-25 02:07:41 +02:00
|
|
|
},
|
|
|
|
mockValidator{
|
2015-02-22 23:16:11 +02:00
|
|
|
FieldName: StoreEmail, Errs: nil,
|
2015-01-25 02:07:41 +02:00
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
errs := errList.Map()
|
2015-02-22 23:16:11 +02:00
|
|
|
if errs[StoreUsername][0] != "must be longer than 4" {
|
|
|
|
t.Error("Expected a different error for username:", errs[StoreUsername][0])
|
2015-01-25 02:07:41 +02:00
|
|
|
}
|
|
|
|
if errs["missing_field"][0] != "Expected field to exist." {
|
|
|
|
t.Error("Expected a different error for missing_field:", errs["missing_field"][0])
|
|
|
|
}
|
2015-02-22 23:16:11 +02:00
|
|
|
if _, ok := errs[StoreEmail]; ok {
|
2015-01-25 02:07:41 +02:00
|
|
|
t.Error("Expected no errors for email.")
|
|
|
|
}
|
|
|
|
}
|
2015-01-26 08:58:50 +02:00
|
|
|
|
|
|
|
func TestValidate_Confirm(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab := New()
|
|
|
|
ctx := mockRequestContext(ab, StoreUsername, "john", "confirmUsername", "johnny")
|
2015-02-22 23:16:11 +02:00
|
|
|
errs := ctx.Validate(nil, StoreUsername, "confirmUsername").Map()
|
2015-01-26 08:58:50 +02:00
|
|
|
if errs["confirmUsername"][0] != "Does not match username" {
|
|
|
|
t.Error("Expected a different error for confirmUsername:", errs["confirmUsername"][0])
|
|
|
|
}
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ctx = mockRequestContext(ab, StoreUsername, "john", "confirmUsername", "john")
|
2015-02-22 23:16:11 +02:00
|
|
|
errs = ctx.Validate(nil, StoreUsername, "confirmUsername").Map()
|
2015-01-26 08:58:50 +02:00
|
|
|
if len(errs) != 0 {
|
|
|
|
t.Error("Expected no errors:", errs)
|
|
|
|
}
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ctx = mockRequestContext(ab, StoreUsername, "john", "confirmUsername", "john")
|
2015-02-22 23:16:11 +02:00
|
|
|
errs = ctx.Validate(nil, StoreUsername).Map()
|
2015-01-26 08:58:50 +02:00
|
|
|
if len(errs) != 0 {
|
|
|
|
t.Error("Expected no errors:", errs)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFilterValidators(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
validators := []Validator{
|
|
|
|
mockValidator{
|
2015-02-22 23:16:11 +02:00
|
|
|
FieldName: StoreUsername, Errs: ErrorList{FieldError{StoreUsername, errors.New("must be longer than 4")}},
|
2015-01-26 08:58:50 +02:00
|
|
|
},
|
|
|
|
mockValidator{
|
2015-02-22 23:16:11 +02:00
|
|
|
FieldName: StorePassword, Errs: ErrorList{FieldError{StorePassword, errors.New("must be longer than 4")}},
|
2015-01-26 08:58:50 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2015-02-22 23:16:11 +02:00
|
|
|
validators = FilterValidators(validators, StoreUsername)
|
2015-01-26 08:58:50 +02:00
|
|
|
|
|
|
|
if len(validators) != 1 {
|
|
|
|
t.Error("Expected length to be 1")
|
|
|
|
}
|
2015-02-22 23:16:11 +02:00
|
|
|
if validators[0].Field() != StoreUsername {
|
2015-01-26 08:58:50 +02:00
|
|
|
t.Error("Expcted validator for field username", validators[0].Field())
|
|
|
|
}
|
|
|
|
}
|