mirror of
https://github.com/labstack/echo.git
synced 2025-09-16 09:16:29 +02:00
@@ -155,18 +155,18 @@ func (r *Request) Cookie(name string) (engine.Cookie, error) {
|
|||||||
if b == nil {
|
if b == nil {
|
||||||
return nil, echo.ErrCookieNotFound
|
return nil, echo.ErrCookieNotFound
|
||||||
}
|
}
|
||||||
c.ParseBytes(b)
|
|
||||||
c.SetKey(name)
|
c.SetKey(name)
|
||||||
|
c.SetValueBytes(b)
|
||||||
return &Cookie{c}, nil
|
return &Cookie{c}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cookies implements `engine.Request#Cookies` function.
|
// Cookies implements `engine.Request#Cookies` function.
|
||||||
func (r *Request) Cookies() []engine.Cookie {
|
func (r *Request) Cookies() []engine.Cookie {
|
||||||
cookies := make([]engine.Cookie, 0)
|
cookies := []engine.Cookie{}
|
||||||
r.Request.Header.VisitAllCookie(func(name, value []byte) {
|
r.Request.Header.VisitAllCookie(func(name, value []byte) {
|
||||||
c := new(fasthttp.Cookie)
|
c := new(fasthttp.Cookie)
|
||||||
c.SetKey(string(name))
|
c.SetKeyBytes(name)
|
||||||
c.ParseBytes(value)
|
c.SetValueBytes(value)
|
||||||
cookies = append(cookies, &Cookie{c})
|
cookies = append(cookies, &Cookie{c})
|
||||||
})
|
})
|
||||||
return cookies
|
return cookies
|
||||||
|
@@ -22,12 +22,10 @@ func (a fakeAddr) String() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestRequest(t *testing.T) {
|
func TestRequest(t *testing.T) {
|
||||||
var ctx fast.RequestCtx
|
ctx := new(fast.RequestCtx)
|
||||||
|
|
||||||
url, _ := url.Parse("http://github.com/labstack/echo")
|
url, _ := url.Parse("http://github.com/labstack/echo")
|
||||||
ctx.Init(&fast.Request{}, fakeAddr{addr: "127.0.0.1"}, nil)
|
ctx.Init(&fast.Request{}, fakeAddr{addr: "127.0.0.1"}, nil)
|
||||||
ctx.Request.Read(bufio.NewReader(bytes.NewBufferString(test.MultipartRequest)))
|
ctx.Request.Read(bufio.NewReader(bytes.NewBufferString(test.MultipartRequest)))
|
||||||
ctx.Request.SetRequestURI(url.String())
|
ctx.Request.SetRequestURI(url.String())
|
||||||
|
test.RequestTest(t, NewRequest(ctx, log.New("echo")))
|
||||||
test.RequestTest(t, NewRequest(&ctx, log.New("echo")))
|
|
||||||
}
|
}
|
||||||
|
@@ -19,7 +19,6 @@ func TestRequest(t *testing.T) {
|
|||||||
httpReq.RemoteAddr = "127.0.0.1"
|
httpReq.RemoteAddr = "127.0.0.1"
|
||||||
req := NewRequest(httpReq, log.New("echo"))
|
req := NewRequest(httpReq, log.New("echo"))
|
||||||
test.RequestTest(t, req)
|
test.RequestTest(t, req)
|
||||||
|
|
||||||
nr, _ := http.NewRequest("GET", "/", nil)
|
nr, _ := http.NewRequest("GET", "/", nil)
|
||||||
req.reset(nr, nil, nil)
|
req.reset(nr, nil, nil)
|
||||||
assert.Equal(t, "", req.Host())
|
assert.Equal(t, "", req.Host())
|
||||||
|
@@ -86,5 +86,12 @@ func RequestTest(t *testing.T, request engine.Request) {
|
|||||||
_, err := request.Cookie("foo")
|
_, err := request.Cookie("foo")
|
||||||
assert.Error(t, err)
|
assert.Error(t, err)
|
||||||
|
|
||||||
assert.Equal(t, 2, len(request.Cookies()))
|
// Cookies
|
||||||
|
cs := request.Cookies()
|
||||||
|
if assert.Len(t, cs, 2) {
|
||||||
|
assert.Equal(t, "session", cs[0].Name())
|
||||||
|
assert.Equal(t, "securetoken", cs[0].Value())
|
||||||
|
assert.Equal(t, "user", cs[1].Name())
|
||||||
|
assert.Equal(t, "123", cs[1].Value())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user