minor performance updates

add benchmarks
pull/52/head
joeybloggs 10 years ago
parent 756455cce5
commit beaa9adf31
  1. 2
      .gitignore
  2. 9
      validator.go
  3. 30
      validator_test.go

2
.gitignore vendored

@ -22,3 +22,5 @@ _testmain.go
*.exe *.exe
*.test *.test
*.prof *.prof
*.test
*.out

@ -166,8 +166,6 @@ func (v *Validate) Struct(s interface{}) *StructErrors {
func (v *Validate) structRecursive(top interface{}, current interface{}, s interface{}) *StructErrors { func (v *Validate) structRecursive(top interface{}, current interface{}, s interface{}) *StructErrors {
structValue := reflect.ValueOf(s) structValue := reflect.ValueOf(s)
structType := reflect.TypeOf(s)
structName := structType.Name()
if structValue.Kind() == reflect.Ptr && !structValue.IsNil() { if structValue.Kind() == reflect.Ptr && !structValue.IsNil() {
return v.structRecursive(top, current, structValue.Elem().Interface()) return v.structRecursive(top, current, structValue.Elem().Interface())
@ -177,6 +175,9 @@ func (v *Validate) structRecursive(top interface{}, current interface{}, s inter
panic("interface passed for validation is not a struct") panic("interface passed for validation is not a struct")
} }
structType := reflect.TypeOf(s)
structName := structType.Name()
validationErrors := &StructErrors{ validationErrors := &StructErrors{
Struct: structName, Struct: structName,
Errors: map[string]*FieldError{}, Errors: map[string]*FieldError{},
@ -339,7 +340,7 @@ func (v *Validate) fieldWithNameAndValue(val interface{}, current interface{}, f
func (v *Validate) fieldWithNameAndSingleTag(val interface{}, current interface{}, f interface{}, name string, valTag string) (*FieldError, error) { func (v *Validate) fieldWithNameAndSingleTag(val interface{}, current interface{}, f interface{}, name string, valTag string) (*FieldError, error) {
vals := strings.Split(valTag, tagKeySeparator) vals := strings.Split(valTag, tagKeySeparator)
key := strings.Trim(vals[0], " ") key := strings.TrimSpace(vals[0])
if len(key) == 0 { if len(key) == 0 {
panic(fmt.Sprintf("Invalid validation tag on field %s", name)) panic(fmt.Sprintf("Invalid validation tag on field %s", name))
@ -364,7 +365,7 @@ func (v *Validate) fieldWithNameAndSingleTag(val interface{}, current interface{
param := "" param := ""
if len(vals) > 1 { if len(vals) > 1 {
param = strings.Trim(vals[1], " ") param = strings.TrimSpace(vals[1])
} }
if err := valFunc(val, current, f, param); !err { if err := valFunc(val, current, f, param); !err {

@ -13,6 +13,14 @@ import (
// - Run "go test" to run tests // - Run "go test" to run tests
// - Run "gocov test | gocov report" to report on test converage by file // - Run "gocov test | gocov report" to report on test converage by file
// - Run "gocov test | gocov annotate -" to report on all code and functions, those ,marked with "MISS" were never called // - Run "gocov test | gocov annotate -" to report on all code and functions, those ,marked with "MISS" were never called
//
//
// go test -cpuprofile cpu.out
// ./validator.test -test.bench=. -test.cpuprofile=cpu.prof
// go tool pprof validator.test cpu.prof
//
//
// go test -memprofile mem.out
type I interface { type I interface {
Foo() string Foo() string
@ -2310,3 +2318,25 @@ func TestInvalidValidatorFunction(t *testing.T) {
PanicMatches(t, func() { validate.Field(s.Test, "zzxxBadFunction") }, fmt.Sprintf("Undefined validation function on field %s", "")) PanicMatches(t, func() { validate.Field(s.Test, "zzxxBadFunction") }, fmt.Sprintf("Undefined validation function on field %s", ""))
} }
func BenchmarkValidateField(b *testing.B) {
for n := 0; n < b.N; n++ {
validate.Field("1", "len=1")
}
}
func BenchmarkValidateStruct(b *testing.B) {
type Test struct {
StringVal string `bson:"required,lt=10"`
Int64Val int64 `bson:"gt=0,lt=10"`
}
t := &Test{
StringVal: "test",
Int64Val: 5,
}
for n := 0; n < b.N; n++ {
validate.Struct(t)
}
}

Loading…
Cancel
Save