2020-09-13 11:20:11 +02:00
|
|
|
package requestid
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http/httptest"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
2020-09-14 12:12:29 +02:00
|
|
|
"github.com/gofiber/fiber/v2/utils"
|
2020-09-13 11:20:11 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// go test -run Test_RequestID
|
|
|
|
func Test_RequestID(t *testing.T) {
|
|
|
|
app := fiber.New()
|
|
|
|
|
|
|
|
app.Use(New())
|
|
|
|
|
|
|
|
app.Get("/", func(c *fiber.Ctx) error {
|
|
|
|
return c.SendString("Hello, World 👋!")
|
|
|
|
})
|
|
|
|
|
|
|
|
resp, err := app.Test(httptest.NewRequest("GET", "/", nil))
|
|
|
|
utils.AssertEqual(t, nil, err)
|
|
|
|
utils.AssertEqual(t, fiber.StatusOK, resp.StatusCode)
|
|
|
|
|
|
|
|
reqid := resp.Header.Get(fiber.HeaderXRequestID)
|
|
|
|
utils.AssertEqual(t, 36, len(reqid))
|
|
|
|
|
|
|
|
req := httptest.NewRequest("GET", "/", nil)
|
|
|
|
req.Header.Add(fiber.HeaderXRequestID, reqid)
|
|
|
|
|
|
|
|
resp, err = app.Test(req)
|
|
|
|
utils.AssertEqual(t, nil, err)
|
|
|
|
utils.AssertEqual(t, fiber.StatusOK, resp.StatusCode)
|
|
|
|
utils.AssertEqual(t, reqid, resp.Header.Get(fiber.HeaderXRequestID))
|
|
|
|
}
|
2020-09-16 09:44:05 +08:00
|
|
|
|
|
|
|
// go test -run Test_RequestID_Next
|
|
|
|
func Test_RequestID_Next(t *testing.T) {
|
2020-09-17 13:41:06 +08:00
|
|
|
app := fiber.New()
|
2020-09-16 09:44:05 +08:00
|
|
|
app.Use(New(Config{
|
|
|
|
Next: func(_ *fiber.Ctx) bool {
|
|
|
|
return true
|
|
|
|
},
|
|
|
|
}))
|
|
|
|
|
|
|
|
resp, err := app.Test(httptest.NewRequest("GET", "/", nil))
|
|
|
|
utils.AssertEqual(t, nil, err)
|
2020-10-12 19:05:48 +03:00
|
|
|
utils.AssertEqual(t, resp.Header.Get(fiber.HeaderXRequestID), "")
|
2020-09-16 09:44:05 +08:00
|
|
|
utils.AssertEqual(t, fiber.StatusNotFound, resp.StatusCode)
|
|
|
|
}
|
2020-10-21 20:14:12 +01:00
|
|
|
|
|
|
|
// go test -run Test_RequestID_Locals
|
|
|
|
func Test_RequestID_Locals(t *testing.T) {
|
|
|
|
reqId := "ThisIsARequestId"
|
|
|
|
ctxKey := "ThisIsAContextKey"
|
|
|
|
|
|
|
|
app := fiber.New()
|
|
|
|
app.Use(New(Config{
|
|
|
|
Generator: func() string {
|
|
|
|
return reqId
|
|
|
|
},
|
|
|
|
ContextKey: ctxKey,
|
|
|
|
}))
|
|
|
|
|
|
|
|
var ctxVal string
|
|
|
|
|
2020-11-01 00:32:01 +08:00
|
|
|
app.Use(func(c *fiber.Ctx) error {
|
2020-10-21 20:14:12 +01:00
|
|
|
ctxVal = c.Locals(ctxKey).(string)
|
|
|
|
return c.Next()
|
|
|
|
})
|
|
|
|
|
|
|
|
_, err := app.Test(httptest.NewRequest("GET", "/", nil))
|
|
|
|
utils.AssertEqual(t, nil, err)
|
|
|
|
utils.AssertEqual(t, reqId, ctxVal)
|
2020-11-01 00:32:01 +08:00
|
|
|
}
|