2017-07-17 16:42:51 +02:00
|
|
|
// black-box testing
|
|
|
|
package router_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"net/http"
|
|
|
|
"testing"
|
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12"
|
|
|
|
"github.com/kataras/iris/v12/context"
|
2017-07-17 16:42:51 +02:00
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/httptest"
|
2017-07-17 16:42:51 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var defaultErrHandler = func(ctx context.Context) {
|
|
|
|
text := http.StatusText(ctx.GetStatusCode())
|
|
|
|
ctx.WriteString(text)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOnAnyErrorCode(t *testing.T) {
|
|
|
|
app := iris.New()
|
|
|
|
app.Configure(iris.WithFireMethodNotAllowed)
|
|
|
|
|
|
|
|
buff := &bytes.Buffer{}
|
|
|
|
expectedPrintBeforeExecuteErr := "printed before error"
|
|
|
|
|
|
|
|
// with a middleware
|
|
|
|
app.OnAnyErrorCode(func(ctx context.Context) {
|
|
|
|
buff.WriteString(expectedPrintBeforeExecuteErr)
|
|
|
|
ctx.Next()
|
|
|
|
}, defaultErrHandler)
|
|
|
|
|
|
|
|
expectedFoundResponse := "found"
|
|
|
|
app.Get("/found", func(ctx context.Context) {
|
|
|
|
ctx.WriteString(expectedFoundResponse)
|
|
|
|
})
|
|
|
|
|
2020-06-08 04:16:55 +02:00
|
|
|
expected407 := "this should be sent, we manage the response response by ourselves"
|
|
|
|
app.Get("/407", func(ctx context.Context) {
|
2017-07-17 16:42:51 +02:00
|
|
|
ctx.Record()
|
2020-06-08 04:16:55 +02:00
|
|
|
ctx.WriteString(expected407)
|
|
|
|
ctx.StatusCode(iris.StatusProxyAuthRequired)
|
2017-07-17 16:42:51 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
e := httptest.New(t, app)
|
|
|
|
|
|
|
|
e.GET("/found").Expect().Status(iris.StatusOK).
|
|
|
|
Body().Equal(expectedFoundResponse)
|
|
|
|
|
|
|
|
e.GET("/notfound").Expect().Status(iris.StatusNotFound).
|
|
|
|
Body().Equal(http.StatusText(iris.StatusNotFound))
|
|
|
|
|
|
|
|
checkAndClearBuf(t, buff, expectedPrintBeforeExecuteErr)
|
|
|
|
|
|
|
|
e.POST("/found").Expect().Status(iris.StatusMethodNotAllowed).
|
|
|
|
Body().Equal(http.StatusText(iris.StatusMethodNotAllowed))
|
|
|
|
|
|
|
|
checkAndClearBuf(t, buff, expectedPrintBeforeExecuteErr)
|
|
|
|
|
2020-06-08 04:16:55 +02:00
|
|
|
e.GET("/407").Expect().Status(iris.StatusProxyAuthRequired).
|
|
|
|
Body().Equal(expected407)
|
|
|
|
|
|
|
|
// Test Configuration.ResetOnFireErrorCode.
|
|
|
|
app2 := iris.New()
|
|
|
|
app2.Configure(iris.WithResetOnFireErrorCode)
|
|
|
|
|
|
|
|
app2.OnAnyErrorCode(func(ctx context.Context) {
|
|
|
|
buff.WriteString(expectedPrintBeforeExecuteErr)
|
|
|
|
ctx.Next()
|
|
|
|
}, defaultErrHandler)
|
|
|
|
|
|
|
|
app2.Get("/406", func(ctx context.Context) {
|
|
|
|
ctx.Record()
|
|
|
|
ctx.WriteString("this should not be sent, only status text will be sent")
|
|
|
|
ctx.WriteString("the handler can handle 'rollback' of the text when error code fired because of the recorder")
|
|
|
|
ctx.StatusCode(iris.StatusNotAcceptable)
|
|
|
|
})
|
|
|
|
|
|
|
|
httptest.New(t, app2).GET("/406").Expect().Status(iris.StatusNotAcceptable).
|
2017-07-17 16:42:51 +02:00
|
|
|
Body().Equal(http.StatusText(iris.StatusNotAcceptable))
|
|
|
|
|
|
|
|
checkAndClearBuf(t, buff, expectedPrintBeforeExecuteErr)
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkAndClearBuf(t *testing.T, buff *bytes.Buffer, expected string) {
|
2020-05-10 23:44:54 +02:00
|
|
|
t.Helper()
|
|
|
|
|
2017-07-17 16:42:51 +02:00
|
|
|
if got, expected := buff.String(), expected; got != expected {
|
2020-05-10 23:44:54 +02:00
|
|
|
t.Fatalf("expected middleware to run before the error handler, expected: '%s' but got: '%s'", expected, got)
|
2017-07-17 16:42:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
buff.Reset()
|
|
|
|
}
|
2020-05-10 23:44:54 +02:00
|
|
|
|
|
|
|
func TestPartyOnErrorCode(t *testing.T) {
|
|
|
|
app := iris.New()
|
|
|
|
app.Configure(iris.WithFireMethodNotAllowed)
|
|
|
|
|
|
|
|
globalNotFoundResponse := "custom not found"
|
|
|
|
app.OnErrorCode(iris.StatusNotFound, func(ctx iris.Context) {
|
|
|
|
ctx.WriteString(globalNotFoundResponse)
|
|
|
|
})
|
|
|
|
|
|
|
|
globalMethodNotAllowedResponse := "global: method not allowed"
|
|
|
|
app.OnErrorCode(iris.StatusMethodNotAllowed, func(ctx iris.Context) {
|
|
|
|
ctx.WriteString(globalMethodNotAllowedResponse)
|
|
|
|
})
|
|
|
|
|
|
|
|
app.Get("/path", h)
|
|
|
|
|
|
|
|
usersResponse := "users: method allowed"
|
|
|
|
users := app.Party("/users")
|
|
|
|
users.OnErrorCode(iris.StatusMethodNotAllowed, func(ctx iris.Context) {
|
|
|
|
ctx.WriteString(usersResponse)
|
|
|
|
})
|
|
|
|
users.Get("/", h)
|
2020-05-11 10:11:27 +02:00
|
|
|
write400 := func(ctx iris.Context) { ctx.StatusCode(iris.StatusBadRequest) }
|
2020-05-10 23:44:54 +02:00
|
|
|
// test setting the error code from a handler.
|
2020-05-11 10:11:27 +02:00
|
|
|
users.Get("/badrequest", write400)
|
2020-05-10 23:44:54 +02:00
|
|
|
|
|
|
|
usersuserResponse := "users:user: method allowed"
|
|
|
|
user := users.Party("/{id:int}")
|
|
|
|
user.OnErrorCode(iris.StatusMethodNotAllowed, func(ctx iris.Context) {
|
|
|
|
ctx.WriteString(usersuserResponse)
|
|
|
|
})
|
2020-05-11 10:11:27 +02:00
|
|
|
usersuserNotFoundResponse := "users:user: not found"
|
|
|
|
user.OnErrorCode(iris.StatusNotFound, func(ctx iris.Context) {
|
|
|
|
ctx.WriteString(usersuserNotFoundResponse)
|
|
|
|
})
|
2020-05-10 23:44:54 +02:00
|
|
|
user.Get("/", h)
|
2020-05-11 10:11:27 +02:00
|
|
|
user.Get("/ab/badrequest", write400)
|
|
|
|
|
|
|
|
friends := users.Party("/friends")
|
|
|
|
friends.Get("/{id:int}", h)
|
2020-05-10 23:44:54 +02:00
|
|
|
|
|
|
|
e := httptest.New(t, app)
|
|
|
|
|
|
|
|
e.GET("/notfound").Expect().Status(iris.StatusNotFound).Body().Equal(globalNotFoundResponse)
|
|
|
|
e.POST("/path").Expect().Status(iris.StatusMethodNotAllowed).Body().Equal(globalMethodNotAllowedResponse)
|
|
|
|
e.GET("/path").Expect().Status(iris.StatusOK).Body().Equal("/path")
|
|
|
|
|
|
|
|
e.POST("/users").Expect().Status(iris.StatusMethodNotAllowed).
|
|
|
|
Body().Equal(usersResponse)
|
|
|
|
|
|
|
|
e.POST("/users/42").Expect().Status(iris.StatusMethodNotAllowed).
|
|
|
|
Body().Equal(usersuserResponse)
|
|
|
|
|
|
|
|
e.GET("/users/42").Expect().Status(iris.StatusOK).
|
|
|
|
Body().Equal("/users/42")
|
2020-05-11 10:11:27 +02:00
|
|
|
e.GET("/users/ab").Expect().Status(iris.StatusNotFound).Body().Equal(usersuserNotFoundResponse)
|
|
|
|
// inherit the parent.
|
|
|
|
e.GET("/users/42/friends/dsa").Expect().Status(iris.StatusNotFound).Body().Equal(usersuserNotFoundResponse)
|
2020-05-10 23:44:54 +02:00
|
|
|
|
|
|
|
// if not registered to the party, then the root is taking action.
|
2020-05-11 10:11:27 +02:00
|
|
|
e.GET("/users/42/ab/badrequest").Expect().Status(iris.StatusBadRequest).Body().Equal(http.StatusText(iris.StatusBadRequest))
|
2020-05-10 23:44:54 +02:00
|
|
|
|
|
|
|
// if not registered to the party, and not in root, then just write the status text (fallback behavior)
|
|
|
|
e.GET("/users/badrequest").Expect().Status(iris.StatusBadRequest).
|
|
|
|
Body().Equal(http.StatusText(iris.StatusBadRequest))
|
|
|
|
}
|