add unit test cases
This commit is contained in:
parent
4fa797feaa
commit
86b0a3ba3f
@ -70,3 +70,44 @@ func TestContext_Session2(t *testing.T) {
|
|||||||
t.FailNow()
|
t.FailNow()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSetCookie(t *testing.T) {
|
||||||
|
type cookie struct {
|
||||||
|
Name string
|
||||||
|
Value string
|
||||||
|
MaxAge int64
|
||||||
|
Path string
|
||||||
|
Domain string
|
||||||
|
Secure bool
|
||||||
|
HttpOnly bool
|
||||||
|
SameSite string
|
||||||
|
}
|
||||||
|
type testItem struct {
|
||||||
|
item cookie
|
||||||
|
want string
|
||||||
|
}
|
||||||
|
cases := []struct {
|
||||||
|
request string
|
||||||
|
valueGp []testItem
|
||||||
|
}{
|
||||||
|
{"/", []testItem{{cookie{"name", "value", -1, "/", "", false, false, "Strict"}, "name=value; Max-Age=0; Path=/; SameSite=Strict"}}},
|
||||||
|
{"/", []testItem{{cookie{"name", "value", -1, "/", "", false, false, "Lax"}, "name=value; Max-Age=0; Path=/; SameSite=Lax"}}},
|
||||||
|
{"/", []testItem{{cookie{"name", "value", -1, "/", "", false, false, "None"}, "name=value; Max-Age=0; Path=/; SameSite=None"}}},
|
||||||
|
{"/", []testItem{{cookie{"name", "value", -1, "/", "", false, false, ""}, "name=value; Max-Age=0; Path=/"}}},
|
||||||
|
}
|
||||||
|
for _, c := range cases {
|
||||||
|
r, _ := http.NewRequest("GET", c.request, nil)
|
||||||
|
output := NewOutput()
|
||||||
|
output.Context = NewContext()
|
||||||
|
output.Context.Reset(httptest.NewRecorder(), r)
|
||||||
|
for _, item := range c.valueGp {
|
||||||
|
params := item.item
|
||||||
|
var others = []interface{}{params.MaxAge, params.Path, params.Domain, params.Secure, params.HttpOnly, params.SameSite}
|
||||||
|
output.Context.SetCookie(params.Name, params.Value, others...)
|
||||||
|
got := output.Context.ResponseWriter.Header().Get("Set-Cookie")
|
||||||
|
if got != item.want {
|
||||||
|
t.Fatalf("SetCookie error,should be:\n%v \ngot:\n%v", item.want, got)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user