1
0
mirror of https://github.com/labstack/echo.git synced 2025-01-18 02:58:38 +02:00

Merge pull request #62 from labstack/middleware

Refactored tests
This commit is contained in:
Vishal Rana 2015-05-16 13:06:01 -07:00
commit 561bfc59ad
3 changed files with 21 additions and 14 deletions

View File

@ -27,25 +27,26 @@ func TestBasicAuth(t *testing.T) {
auth := Basic + " " + base64.StdEncoding.EncodeToString([]byte("joe:secret"))
req.Header.Set(echo.Authorization, auth)
if ba(c) != nil {
t.Error("basic auth should pass")
t.Error("expected `pass`")
}
// Case insensitive
auth = "basic " + base64.StdEncoding.EncodeToString([]byte("joe:secret"))
req.Header.Set(echo.Authorization, auth)
if ba(c) != nil {
t.Error("basic auth should ignore case and pass")
t.Error("expected `pass` with case insensitive header")
}
//---------------------
// Invalid credentials
//---------------------
auth = Basic + " " + base64.StdEncoding.EncodeToString([]byte(" joe: secret"))
// Incorrect password
auth = Basic + " " + base64.StdEncoding.EncodeToString([]byte("joe: password"))
req.Header.Set(echo.Authorization, auth)
ba = BasicAuth(fn)
if ba(c) == nil {
t.Error("basic auth should fail")
t.Error("expected `fail` with incorrect password")
}
// Invalid header
@ -53,7 +54,7 @@ func TestBasicAuth(t *testing.T) {
req.Header.Set(echo.Authorization, auth)
ba = BasicAuth(fn)
if ba(c) == nil {
t.Error("basic auth should fail for invalid scheme")
t.Error("expected `fail` with invalid auth header")
}
// Invalid scheme
@ -61,13 +62,13 @@ func TestBasicAuth(t *testing.T) {
req.Header.Set(echo.Authorization, auth)
ba = BasicAuth(fn)
if ba(c) == nil {
t.Error("basic auth should fail for invalid scheme")
t.Error("expected `fail` with invalid scheme")
}
// Empty auth header
req.Header.Set(echo.Authorization, "")
ba = BasicAuth(fn)
if ba(c) == nil {
t.Error("basic auth should fail for empty auth header")
t.Error("expected `fail` with empty auth header")
}
}

View File

@ -21,7 +21,7 @@ func TestGzip(t *testing.T) {
})(c)
if w.Header().Get(echo.ContentEncoding) != "gzip" {
t.Errorf("expected Content-Encoding: gzip, got %d", w.Header().Get(echo.ContentEncoding))
t.Errorf("expected Content-Encoding header `gzip`, got %d.", w.Header().Get(echo.ContentEncoding))
}
r, err := gzip.NewReader(w.Body)
@ -37,6 +37,6 @@ func TestGzip(t *testing.T) {
s := string(b)
if s != "test" {
t.Errorf(`expected "test", got "%s"`, s)
t.Errorf("expected `test`, got %s.", s)
}
}

View File

@ -13,8 +13,9 @@ func TestStripTrailingSlash(t *testing.T) {
res := &echo.Response{Writer: httptest.NewRecorder()}
c := echo.NewContext(req, res, echo.New())
StripTrailingSlash()(c)
if c.Request.URL.Path != "/users" {
t.Error("it should strip the trailing slash")
p := c.Request.URL.Path
if p != "/users" {
t.Errorf("expected path `/users` got, %s.", p)
}
}
@ -23,10 +24,15 @@ func TestRedirectToSlash(t *testing.T) {
res := &echo.Response{Writer: httptest.NewRecorder()}
c := echo.NewContext(req, res, echo.New())
RedirectToSlash(RedirectToSlashOptions{Code: http.StatusTemporaryRedirect})(c)
// Status code
if res.Status() != http.StatusTemporaryRedirect {
t.Errorf("status code should be 307, found %d", res.Status())
t.Errorf("expected status `307`, got %d.", res.Status())
}
if c.Response.Header().Get("Location") != "/users/" {
t.Error("Location header should be /users/")
// Location header
l := c.Response.Header().Get("Location")
if l != "/users/" {
t.Errorf("expected Location header `/users/`, got %s.", l)
}
}