-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathvalidation_test.go
109 lines (97 loc) · 3.26 KB
/
validation_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
package httpsuite
import (
"testing"
"github.com/go-playground/validator/v10"
"github.com/stretchr/testify/assert"
)
type TestValidationRequest struct {
Name string `validate:"required"`
Age int `validate:"required,min=18"`
}
func TestNewValidationProblemDetails(t *testing.T) {
validate := validator.New()
request := TestValidationRequest{} // Missing required fields to trigger validation errors
err := validate.Struct(request)
if err == nil {
t.Fatal("Expected validation errors, but got none")
}
SetProblemBaseURL("https://example.com")
validationProblem := NewValidationProblemDetails(err)
expectedProblem := &ProblemDetails{
Type: "https://example.com/errors/validation-error",
Title: "Validation Error",
Status: 400,
Detail: "One or more fields failed validation.",
Extensions: map[string]interface{}{
"errors": []ValidationErrorDetail{
{Field: "Name", Message: "Name failed required validation"},
{Field: "Age", Message: "Age failed required validation"},
},
},
}
assert.Equal(t, expectedProblem.Type, validationProblem.Type)
assert.Equal(t, expectedProblem.Title, validationProblem.Title)
assert.Equal(t, expectedProblem.Status, validationProblem.Status)
assert.Equal(t, expectedProblem.Detail, validationProblem.Detail)
assert.ElementsMatch(t, expectedProblem.Extensions["errors"], validationProblem.Extensions["errors"])
}
func TestIsRequestValid(t *testing.T) {
tests := []struct {
name string
request TestValidationRequest
expectedProblem *ProblemDetails
}{
{
name: "Valid request",
request: TestValidationRequest{Name: "Alice", Age: 25},
expectedProblem: nil, // No errors expected for valid input
},
{
name: "Missing Name and Age below minimum",
request: TestValidationRequest{Age: 17},
expectedProblem: &ProblemDetails{
Type: "https://example.com/errors/validation-error",
Title: "Validation Error",
Status: 400,
Detail: "One or more fields failed validation.",
Extensions: map[string]interface{}{
"errors": []ValidationErrorDetail{
{Field: "Name", Message: "Name failed required validation"},
{Field: "Age", Message: "Age failed min validation"},
},
},
},
},
{
name: "Missing Age",
request: TestValidationRequest{Name: "Alice"},
expectedProblem: &ProblemDetails{
Type: "https://example.com/errors/validation-error",
Title: "Validation Error",
Status: 400,
Detail: "One or more fields failed validation.",
Extensions: map[string]interface{}{
"errors": []ValidationErrorDetail{
{Field: "Age", Message: "Age failed required validation"},
},
},
},
},
}
SetProblemBaseURL("https://example.com")
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
problem := IsRequestValid(tt.request)
if tt.expectedProblem == nil {
assert.Nil(t, problem)
} else {
assert.NotNil(t, problem)
assert.Equal(t, tt.expectedProblem.Type, problem.Type)
assert.Equal(t, tt.expectedProblem.Title, problem.Title)
assert.Equal(t, tt.expectedProblem.Status, problem.Status)
assert.Equal(t, tt.expectedProblem.Detail, problem.Detail)
assert.ElementsMatch(t, tt.expectedProblem.Extensions["errors"], problem.Extensions["errors"])
}
})
}
}