forked from gookit/validate
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrule_test.go
115 lines (97 loc) · 2.43 KB
/
rule_test.go
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
package validate
import (
"net/url"
"testing"
"github.com/gookit/filter"
"github.com/gookit/goutil/testutil/assert"
)
func TestRule_basic(t *testing.T) {
is := assert.New(t)
data := url.Values{
"name": []string{"inhere"},
"age": []string{"10"},
"key0": []string{"val0"},
}
v := New(data)
// new rule
r := NewRule("name", "minLen", 6)
r.SetScene("test") // only validate on scene "test"
r.SetFilterFunc(func(val any) (any, error) {
return val.(string) + "-HI", nil
})
r.SetBeforeFunc(func(v *Validation) bool {
return true
})
is.Equal([]string{"name"}, r.Fields())
v.AppendRule(r)
v.AddRule("field0", "required").SetOptional(true)
v.AddRule("key0", "inRule").SetCheckFunc(func(s string) bool {
return s == "val0"
})
v.AddRule("name", "ltField", "key0")
// validate. will skip validate field "name"
v.Validate()
is.True(v.IsOK())
is.Equal("val0", v.SafeVal("key0"))
is.Equal(nil, v.SafeVal("not-exist"))
// validate on "test". will validate field "name"
v.ResetResult()
v.Validate("test")
is.True(v.IsOK())
is.Equal("val0", v.SafeVal("key0"))
is.Equal("inhere-HI", v.SafeVal("name"))
}
func TestRule_SetBeforeFunc(t *testing.T) {
is := assert.New(t)
mp := M{
"name": "inhere",
"avatar": "/some/file",
}
v := Map(mp)
v.AddRule("avatar", "isFile")
is.False(v.Validate())
is.Equal("avatar must be an uploaded file", v.Errors.One())
// use SetBeforeFunc
v = Map(mp)
v.AddRule("avatar", "isFile").
SetBeforeFunc(func(v *Validation) bool {
// return false for skip validate
return false
})
v.Validate()
is.True(v.IsOK())
}
func TestRule_SetFilterFunc(t *testing.T) {
is := assert.New(t)
v := Map(M{
"name": "inhere",
"age": "abc",
})
v.AddRule("age", "int", 1, 100).
SetFilterFunc(func(val any) (i any, e error) {
return filter.Int(val)
})
is.False(v.Validate())
is.Equal(`strconv.Atoi: parsing "abc": invalid syntax`, v.Errors.One())
}
func TestRule_SetSkipEmpty(t *testing.T) {
is := assert.New(t)
mp := M{
"name": "inhere",
"age": 0,
}
v := Map(mp)
v.AddRule("age", "int", 1)
v.AddRule("name", "string", 1, 10)
is.True(v.Validate())
sd := v.SafeData()
is.Contains(sd, "name")
is.NotContains(sd, "age")
is.Equal("inhere", v.GetSafe("name"))
is.Equal(nil, v.GetSafe("age"))
v = Map(mp)
v.AddRule("age", "int", 1).SetSkipEmpty(false)
v.AddRule("name", "string", 1, 10)
is.False(v.Validate())
is.Equal("age value must be an integer and mix value is 1", v.Errors.One())
}