2017-02-10 16:21:32 +09:00
|
|
|
package middleware
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"testing"
|
|
|
|
|
2019-01-30 12:56:56 +02:00
|
|
|
"github.com/labstack/echo/v4"
|
2017-02-10 16:21:32 +09:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRequestID(t *testing.T) {
|
|
|
|
e := echo.New()
|
2018-10-14 17:16:58 +02:00
|
|
|
req := httptest.NewRequest(http.MethodGet, "/", nil)
|
2017-02-10 16:21:32 +09:00
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
c := e.NewContext(req, rec)
|
2017-03-18 01:22:58 +09:00
|
|
|
handler := func(c echo.Context) error {
|
2017-02-10 16:21:32 +09:00
|
|
|
return c.String(http.StatusOK, "test")
|
2017-03-18 01:22:58 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
rid := RequestIDWithConfig(RequestIDConfig{})
|
|
|
|
h := rid(handler)
|
2017-02-10 16:21:32 +09:00
|
|
|
h(c)
|
2017-03-06 13:16:05 -08:00
|
|
|
assert.Len(t, rec.Header().Get(echo.HeaderXRequestID), 32)
|
2017-03-18 01:22:58 +09:00
|
|
|
|
2021-06-23 01:04:23 +09:00
|
|
|
// Custom generator and handler
|
|
|
|
customID := "customGenerator"
|
|
|
|
calledHandler := false
|
2017-03-18 01:22:58 +09:00
|
|
|
rid = RequestIDWithConfig(RequestIDConfig{
|
2021-06-23 01:04:23 +09:00
|
|
|
Generator: func() string { return customID },
|
|
|
|
RequestIDHandler: func(_ echo.Context, id string) {
|
|
|
|
calledHandler = true
|
|
|
|
assert.Equal(t, customID, id)
|
|
|
|
},
|
2017-03-18 01:22:58 +09:00
|
|
|
})
|
|
|
|
h = rid(handler)
|
|
|
|
h(c)
|
|
|
|
assert.Equal(t, rec.Header().Get(echo.HeaderXRequestID), "customGenerator")
|
2021-06-23 01:04:23 +09:00
|
|
|
assert.True(t, calledHandler)
|
2017-02-10 16:21:32 +09:00
|
|
|
}
|
2020-12-14 19:06:25 +01:00
|
|
|
|
|
|
|
func TestRequestID_IDNotAltered(t *testing.T) {
|
|
|
|
e := echo.New()
|
|
|
|
req := httptest.NewRequest(http.MethodGet, "/", nil)
|
|
|
|
req.Header.Add(echo.HeaderXRequestID, "<sample-request-id>")
|
|
|
|
|
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
c := e.NewContext(req, rec)
|
|
|
|
handler := func(c echo.Context) error {
|
|
|
|
return c.String(http.StatusOK, "test")
|
|
|
|
}
|
|
|
|
|
|
|
|
rid := RequestIDWithConfig(RequestIDConfig{})
|
|
|
|
h := rid(handler)
|
|
|
|
_ = h(c)
|
|
|
|
assert.Equal(t, rec.Header().Get(echo.HeaderXRequestID), "<sample-request-id>")
|
|
|
|
}
|
2021-12-07 10:56:32 +00:00
|
|
|
|
|
|
|
func TestRequestIDConfigDifferentHeader(t *testing.T) {
|
|
|
|
e := echo.New()
|
|
|
|
req := httptest.NewRequest(http.MethodGet, "/", nil)
|
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
c := e.NewContext(req, rec)
|
|
|
|
handler := func(c echo.Context) error {
|
|
|
|
return c.String(http.StatusOK, "test")
|
|
|
|
}
|
|
|
|
|
|
|
|
rid := RequestIDWithConfig(RequestIDConfig{TargetHeader: echo.HeaderXCorrelationID})
|
|
|
|
h := rid(handler)
|
|
|
|
h(c)
|
|
|
|
assert.Len(t, rec.Header().Get(echo.HeaderXCorrelationID), 32)
|
|
|
|
|
|
|
|
// Custom generator and handler
|
|
|
|
customID := "customGenerator"
|
|
|
|
calledHandler := false
|
|
|
|
rid = RequestIDWithConfig(RequestIDConfig{
|
|
|
|
Generator: func() string { return customID },
|
|
|
|
TargetHeader: echo.HeaderXCorrelationID,
|
|
|
|
RequestIDHandler: func(_ echo.Context, id string) {
|
|
|
|
calledHandler = true
|
|
|
|
assert.Equal(t, customID, id)
|
|
|
|
},
|
|
|
|
})
|
|
|
|
h = rid(handler)
|
|
|
|
h(c)
|
|
|
|
assert.Equal(t, rec.Header().Get(echo.HeaderXCorrelationID), "customGenerator")
|
|
|
|
assert.True(t, calledHandler)
|
|
|
|
}
|