2021-02-17 17:14:47 +08:00
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
2021-06-03 16:56:55 +08:00
|
|
|
"context"
|
2021-03-14 15:36:00 +08:00
|
|
|
"io/ioutil"
|
2021-06-03 16:56:55 +08:00
|
|
|
"os"
|
2021-02-17 17:14:47 +08:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestHelper(t *testing.T) {
|
2021-05-17 16:34:28 +08:00
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
|
|
|
log := NewHelper(logger)
|
2021-03-14 15:36:00 +08:00
|
|
|
|
2021-05-17 16:34:28 +08:00
|
|
|
log.Log(LevelDebug, "msg", "test debug")
|
2021-02-17 17:14:47 +08:00
|
|
|
log.Debug("test debug")
|
|
|
|
log.Debugf("test %s", "debug")
|
|
|
|
log.Debugw("log", "test debug")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHelperLevel(t *testing.T) {
|
2021-05-17 16:34:28 +08:00
|
|
|
log := NewHelper(DefaultLogger)
|
2021-02-17 17:14:47 +08:00
|
|
|
log.Debug("test debug")
|
|
|
|
log.Info("test info")
|
|
|
|
log.Warn("test warn")
|
|
|
|
log.Error("test error")
|
|
|
|
}
|
2021-03-14 15:36:00 +08:00
|
|
|
|
|
|
|
func BenchmarkHelperPrint(b *testing.B) {
|
2021-05-17 16:34:28 +08:00
|
|
|
log := NewHelper(NewStdLogger(ioutil.Discard))
|
2021-03-14 15:36:00 +08:00
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
log.Debug("test")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkHelperPrintf(b *testing.B) {
|
2021-05-17 16:34:28 +08:00
|
|
|
log := NewHelper(NewStdLogger(ioutil.Discard))
|
2021-03-14 15:36:00 +08:00
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
log.Debugf("%s", "test")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkHelperPrintw(b *testing.B) {
|
2021-05-17 16:34:28 +08:00
|
|
|
log := NewHelper(NewStdLogger(ioutil.Discard))
|
2021-03-14 15:36:00 +08:00
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
log.Debugw("key", "value")
|
|
|
|
}
|
|
|
|
}
|
2021-06-03 16:56:55 +08:00
|
|
|
|
|
|
|
func TestContext(t *testing.T) {
|
|
|
|
logger := With(NewStdLogger(os.Stdout),
|
|
|
|
"trace", Trace(),
|
|
|
|
)
|
|
|
|
log := NewHelper(logger)
|
|
|
|
ctx := context.WithValue(context.Background(), "trace_id", "2233")
|
|
|
|
log.WithContext(ctx).Info("got trace!")
|
|
|
|
}
|
|
|
|
|
|
|
|
func Trace() Valuer {
|
|
|
|
return func(ctx context.Context) interface{} {
|
|
|
|
s := ctx.Value("trace_id").(string)
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
}
|