2021-06-13 18:14:32 +02:00
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
2021-06-14 01:50:44 +02:00
|
|
|
"io/ioutil"
|
2021-06-13 18:14:32 +02:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestFilterAll(t *testing.T) {
|
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
2021-06-13 18:35:39 +02:00
|
|
|
log := NewHelper(NewFilter(logger,
|
2021-06-13 18:14:32 +02:00
|
|
|
FilterLevel(LevelDebug),
|
2021-06-13 19:11:24 +02:00
|
|
|
FilterKeys("username"),
|
|
|
|
FilterValues("hello"),
|
|
|
|
FilterHook(testFilterFunc),
|
2021-06-13 18:35:39 +02:00
|
|
|
))
|
2021-06-13 18:14:32 +02:00
|
|
|
log.Log(LevelDebug, "msg", "test debug")
|
|
|
|
log.Info("hello")
|
|
|
|
log.Infow("password", "123456")
|
2021-06-13 18:54:48 +02:00
|
|
|
log.Infow("username", "kratos")
|
2021-06-13 18:14:32 +02:00
|
|
|
log.Warn("warn log")
|
|
|
|
}
|
|
|
|
func TestFilterLevel(t *testing.T) {
|
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
2021-06-13 18:35:39 +02:00
|
|
|
log := NewHelper(NewFilter(NewFilter(logger, FilterLevel(LevelWarn))))
|
2021-06-13 18:14:32 +02:00
|
|
|
log.Log(LevelDebug, "msg1", "te1st debug")
|
|
|
|
log.Debug("test debug")
|
|
|
|
log.Debugf("test %s", "debug")
|
|
|
|
log.Debugw("log", "test debug")
|
|
|
|
log.Warn("warn log")
|
|
|
|
}
|
|
|
|
|
2021-06-13 19:11:24 +02:00
|
|
|
func TestFilterCaller(t *testing.T) {
|
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
2021-06-13 19:47:48 +02:00
|
|
|
log := NewFilter(logger)
|
2021-06-13 19:11:24 +02:00
|
|
|
log.Log(LevelDebug, "msg1", "te1st debug")
|
2021-06-14 01:50:44 +02:00
|
|
|
logHelper := NewHelper(NewFilter(logger))
|
2021-06-13 19:11:24 +02:00
|
|
|
logHelper.Log(LevelDebug, "msg1", "te1st debug")
|
|
|
|
}
|
|
|
|
|
2021-06-13 18:14:32 +02:00
|
|
|
func TestFilterKey(t *testing.T) {
|
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
2021-06-13 19:11:24 +02:00
|
|
|
log := NewHelper(NewFilter(logger, FilterKeys("password")))
|
2021-06-13 18:14:32 +02:00
|
|
|
log.Debugw("password", "123456")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFilterValue(t *testing.T) {
|
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
2021-06-13 19:11:24 +02:00
|
|
|
log := NewHelper(NewFilter(logger, FilterValues("debug")))
|
2021-06-13 18:14:32 +02:00
|
|
|
log.Debugf("test %s", "debug")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFilterFunc(t *testing.T) {
|
|
|
|
logger := With(DefaultLogger, "ts", DefaultTimestamp, "caller", DefaultCaller)
|
2021-06-13 19:11:24 +02:00
|
|
|
log := NewHelper(NewFilter(logger, FilterHook(testFilterFunc)))
|
2021-06-13 18:14:32 +02:00
|
|
|
log.Debug("debug level")
|
|
|
|
log.Infow("password", "123456")
|
|
|
|
}
|
|
|
|
|
2021-06-14 01:50:44 +02:00
|
|
|
func BenchmarkFilterKeys(b *testing.B) {
|
|
|
|
log := NewHelper(NewFilter(NewStdLogger(ioutil.Discard), FilterKeys("password")))
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
log.Infow("password", "123456")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkFilterValues(b *testing.B) {
|
|
|
|
log := NewHelper(NewFilter(NewStdLogger(ioutil.Discard), FilterValues("password")))
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
log.Infow("password")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkFilterHook(b *testing.B) {
|
|
|
|
log := NewHelper(NewFilter(NewStdLogger(ioutil.Discard), FilterHook(testFilterFunc)))
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
log.Info("password","123456")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-13 18:14:32 +02:00
|
|
|
func testFilterFunc(level Level, keyvals ...interface{}) bool {
|
|
|
|
if level == LevelWarn {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
for i := 0; i < len(keyvals); i++ {
|
|
|
|
if keyvals[i] == "password" {
|
|
|
|
keyvals[i+1] = "***"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
2021-06-13 19:47:48 +02:00
|
|
|
}
|