You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kratos/middleware/logging/logging_test.go

180 lines
3.8 KiB

package logging
import (
"bytes"
"context"
"errors"
"testing"
"github.com/go-kratos/kratos/v2/log"
"github.com/go-kratos/kratos/v2/middleware"
"github.com/go-kratos/kratos/v2/transport"
)
var _ transport.Transporter = (*Transport)(nil)
type Transport struct {
kind transport.Kind
endpoint string
operation string
}
func (tr *Transport) Kind() transport.Kind {
return tr.kind
}
func (tr *Transport) Endpoint() string {
return tr.endpoint
}
func (tr *Transport) Operation() string {
return tr.operation
}
func (tr *Transport) RequestHeader() transport.Header {
return nil
}
func (tr *Transport) ReplyHeader() transport.Header {
return nil
}
func TestHTTP(t *testing.T) {
err := errors.New("reply.error")
bf := bytes.NewBuffer(nil)
logger := log.NewStdLogger(bf)
tests := []struct {
name string
kind func(logger log.Logger) middleware.Middleware
err error
ctx context.Context
}{
{
"http-server@fail",
Server,
err,
func() context.Context {
return transport.NewServerContext(context.Background(), &Transport{kind: transport.KindHTTP, endpoint: "endpoint", operation: "/package.service/method"})
}(),
},
{
"http-server@succ",
Server,
nil,
func() context.Context {
return transport.NewServerContext(context.Background(), &Transport{kind: transport.KindHTTP, endpoint: "endpoint", operation: "/package.service/method"})
}(),
},
{
"http-client@succ",
Client,
nil,
func() context.Context {
return transport.NewClientContext(context.Background(), &Transport{kind: transport.KindHTTP, endpoint: "endpoint", operation: "/package.service/method"})
}(),
},
{
"http-client@fail",
Client,
err,
func() context.Context {
return transport.NewClientContext(context.Background(), &Transport{kind: transport.KindHTTP, endpoint: "endpoint", operation: "/package.service/method"})
}(),
},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
bf.Reset()
next := func(ctx context.Context, req interface{}) (interface{}, error) {
return "reply", test.err
}
next = test.kind(logger)(next)
v, e := next(test.ctx, "req.args")
t.Logf("[%s]reply: %v, error: %v", test.name, v, e)
t.Logf("[%s]log:%s", test.name, bf.String())
})
}
}
type (
dummy struct {
field string
}
dummyStringer struct {
field string
}
dummyStringerRedacter struct {
field string
}
)
func (d *dummyStringer) String() string {
return "my value"
}
func (d *dummyStringerRedacter) String() string {
return "my value"
}
func (d *dummyStringerRedacter) Redact() string {
return "my value redacted"
}
func TestExtractArgs(t *testing.T) {
tests := []struct {
name string
req interface{}
expected string
}{
{
name: "dummyStringer",
req: &dummyStringer{field: ""},
expected: "my value",
}, {
name: "dummy",
req: &dummy{field: "value"},
expected: "&{field:value}",
}, {
name: "dummyStringerRedacter",
req: &dummyStringerRedacter{field: ""},
expected: "my value redacted",
},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
if value := extractArgs(test.req); value != test.expected {
t.Errorf(`The stringified %s structure must be equal to "%s", %v given`, test.name, test.expected, value)
}
})
}
}
func TestExtractError(t *testing.T) {
tests := []struct {
name string
err error
wantLevel log.Level
wantErrStr string
}{
{
"no error", nil, log.LevelInfo, "",
},
{
"error", errors.New("test error"), log.LevelError, "test error",
},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
level, errStr := extractError(test.err)
if level != test.wantLevel {
t.Errorf("want: %d, got: %d", test.wantLevel, level)
}
if errStr != test.wantErrStr {
t.Errorf("want: %s, got: %s", test.wantErrStr, errStr)
}
})
}
}