mirror of
https://github.com/go-kratos/kratos.git
synced 2025-01-16 02:47:03 +02:00
77b16286f8
The io/ioutil package has been deprecated as of Go 1.16, see https://golang.org/doc/go1.16#ioutil. This commit replaces the existing io/ioutil functions with their new definitions in io and os packages. Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
80 lines
1.7 KiB
Go
80 lines
1.7 KiB
Go
package log
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
"os"
|
|
"testing"
|
|
)
|
|
|
|
func TestHelper(t *testing.T) {
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
|
log := NewHelper(logger)
|
|
|
|
log.Log(LevelDebug, "msg", "test debug")
|
|
log.Debug("test debug")
|
|
log.Debugf("test %s", "debug")
|
|
log.Debugw("log", "test debug")
|
|
|
|
log.Warn("test warn")
|
|
log.Warnf("test %s", "warn")
|
|
log.Warnw("log", "test warn")
|
|
}
|
|
|
|
func TestHelperWithMsgKey(t *testing.T) {
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
|
log := NewHelper(logger, WithMessageKey("message"))
|
|
log.Debugf("test %s", "debug")
|
|
log.Debugw("log", "test debug")
|
|
}
|
|
|
|
func TestHelperLevel(t *testing.T) {
|
|
log := NewHelper(DefaultLogger)
|
|
log.Debug("test debug")
|
|
log.Info("test info")
|
|
log.Infof("test %s", "info")
|
|
log.Warn("test warn")
|
|
log.Error("test error")
|
|
log.Errorf("test %s", "error")
|
|
log.Errorw("log", "test error")
|
|
}
|
|
|
|
func BenchmarkHelperPrint(b *testing.B) {
|
|
log := NewHelper(NewStdLogger(io.Discard))
|
|
for i := 0; i < b.N; i++ {
|
|
log.Debug("test")
|
|
}
|
|
}
|
|
|
|
func BenchmarkHelperPrintf(b *testing.B) {
|
|
log := NewHelper(NewStdLogger(io.Discard))
|
|
for i := 0; i < b.N; i++ {
|
|
log.Debugf("%s", "test")
|
|
}
|
|
}
|
|
|
|
func BenchmarkHelperPrintw(b *testing.B) {
|
|
log := NewHelper(NewStdLogger(io.Discard))
|
|
for i := 0; i < b.N; i++ {
|
|
log.Debugw("key", "value")
|
|
}
|
|
}
|
|
|
|
type traceKey struct{}
|
|
|
|
func TestContext(t *testing.T) {
|
|
logger := With(NewStdLogger(os.Stdout),
|
|
"trace", Trace(),
|
|
)
|
|
log := NewHelper(logger)
|
|
ctx := context.WithValue(context.Background(), traceKey{}, "2233")
|
|
log.WithContext(ctx).Info("got trace!")
|
|
}
|
|
|
|
func Trace() Valuer {
|
|
return func(ctx context.Context) interface{} {
|
|
s := ctx.Value(traceKey{}).(string)
|
|
return s
|
|
}
|
|
}
|