Added tests for entity and log middleware.

This commit is contained in:
mikestefanello 2021-12-21 21:02:25 -05:00
parent ac93e0f366
commit fc3fee1306
4 changed files with 57 additions and 7 deletions

View file

@ -11,12 +11,13 @@ import (
"github.com/labstack/echo/v4" "github.com/labstack/echo/v4"
) )
// LoadUser loads the user based on the ID provided as a path parameter
func LoadUser(orm *ent.Client) echo.MiddlewareFunc { func LoadUser(orm *ent.Client) echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc { return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error { return func(c echo.Context) error {
userID, err := strconv.Atoi(c.Param("user")) userID, err := strconv.Atoi(c.Param("user"))
if err != nil { if err != nil {
return echo.NewHTTPError(http.StatusNotFound, "Not found") return echo.NewHTTPError(http.StatusNotFound)
} }
u, err := orm.User. u, err := orm.User.
@ -26,16 +27,14 @@ func LoadUser(orm *ent.Client) echo.MiddlewareFunc {
switch err.(type) { switch err.(type) {
case nil: case nil:
c.Set(context.UserKey, u)
return next(c)
case *ent.NotFoundError: case *ent.NotFoundError:
return echo.NewHTTPError(http.StatusNotFound, "Not found") return echo.NewHTTPError(http.StatusNotFound)
default: default:
c.Logger().Error(err) c.Logger().Error(err)
return echo.NewHTTPError(http.StatusInternalServerError, "Internal server error") return echo.NewHTTPError(http.StatusInternalServerError)
} }
c.Set(context.UserKey, u)
return next(c)
} }
} }
} }

23
middleware/entity_test.go Normal file
View file

@ -0,0 +1,23 @@
package middleware
import (
"fmt"
"testing"
"goweb/context"
"goweb/ent"
"goweb/tests"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestLoadUser(t *testing.T) {
ctx, _ := tests.NewContext(c.Web, "/")
ctx.SetParamNames("user")
ctx.SetParamValues(fmt.Sprintf("%d", usr.ID))
_ = tests.ExecuteMiddleware(ctx, LoadUser(c.ORM))
ctxUsr, ok := ctx.Get(context.UserKey).(*ent.User)
require.True(t, ok)
assert.Equal(t, usr.ID, ctxUsr.ID)
}

View file

@ -7,6 +7,7 @@ import (
) )
// LogRequestID includes the request ID in all logs for the given request // LogRequestID includes the request ID in all logs for the given request
// This requires that middleware that includes the request ID first execute
func LogRequestID() echo.MiddlewareFunc { func LogRequestID() echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc { return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error { return func(c echo.Context) error {

27
middleware/log_test.go Normal file
View file

@ -0,0 +1,27 @@
package middleware
import (
"bytes"
"fmt"
"testing"
"goweb/tests"
"github.com/labstack/echo/v4"
"github.com/stretchr/testify/assert"
echomw "github.com/labstack/echo/v4/middleware"
)
func TestLogRequestID(t *testing.T) {
ctx, _ := tests.NewContext(c.Web, "/")
_ = tests.ExecuteMiddleware(ctx, echomw.RequestID())
_ = tests.ExecuteMiddleware(ctx, LogRequestID())
var buf bytes.Buffer
ctx.Logger().SetOutput(&buf)
ctx.Logger().Info("test")
rID := ctx.Response().Header().Get(echo.HeaderXRequestID)
assert.Contains(t, buf.String(), fmt.Sprintf(`id":"%s"`, rID))
}