8 "github.com/tendermint/tmlibs/log"
11 func TestVariousLevels(t *testing.T) {
12 testCases := []struct {
20 strings.Join([]string{
21 `{"_msg":"here","level":"debug","this is":"debug log"}`,
22 `{"_msg":"here","level":"info","this is":"info log"}`,
23 `{"_msg":"here","level":"error","this is":"error log"}`,
29 strings.Join([]string{
30 `{"_msg":"here","level":"debug","this is":"debug log"}`,
31 `{"_msg":"here","level":"info","this is":"info log"}`,
32 `{"_msg":"here","level":"error","this is":"error log"}`,
38 strings.Join([]string{
39 `{"_msg":"here","level":"info","this is":"info log"}`,
40 `{"_msg":"here","level":"error","this is":"error log"}`,
46 strings.Join([]string{
47 `{"_msg":"here","level":"error","this is":"error log"}`,
57 for _, tc := range testCases {
58 t.Run(tc.name, func(t *testing.T) {
60 logger := log.NewFilter(log.NewTMJSONLogger(&buf), tc.allowed)
62 logger.Debug("here", "this is", "debug log")
63 logger.Info("here", "this is", "info log")
64 logger.Error("here", "this is", "error log")
66 if want, have := tc.want, strings.TrimSpace(buf.String()); want != have {
67 t.Errorf("\nwant:\n%s\nhave:\n%s", want, have)
73 func TestLevelContext(t *testing.T) {
76 logger := log.NewTMJSONLogger(&buf)
77 logger = log.NewFilter(logger, log.AllowError())
78 logger = logger.With("context", "value")
80 logger.Error("foo", "bar", "baz")
81 if want, have := `{"_msg":"foo","bar":"baz","context":"value","level":"error"}`, strings.TrimSpace(buf.String()); want != have {
82 t.Errorf("\nwant '%s'\nhave '%s'", want, have)
86 logger.Info("foo", "bar", "baz")
87 if want, have := ``, strings.TrimSpace(buf.String()); want != have {
88 t.Errorf("\nwant '%s'\nhave '%s'", want, have)
92 func TestVariousAllowWith(t *testing.T) {
95 logger := log.NewTMJSONLogger(&buf)
97 logger1 := log.NewFilter(logger, log.AllowError(), log.AllowInfoWith("context", "value"))
98 logger1.With("context", "value").Info("foo", "bar", "baz")
99 if want, have := `{"_msg":"foo","bar":"baz","context":"value","level":"info"}`, strings.TrimSpace(buf.String()); want != have {
100 t.Errorf("\nwant '%s'\nhave '%s'", want, have)
105 logger2 := log.NewFilter(logger, log.AllowError(), log.AllowInfoWith("context", "value"), log.AllowNoneWith("user", "Sam"))
106 logger2.With("context", "value", "user", "Sam").Info("foo", "bar", "baz")
107 if want, have := ``, strings.TrimSpace(buf.String()); want != have {
108 t.Errorf("\nwant '%s'\nhave '%s'", want, have)
113 logger3 := log.NewFilter(logger, log.AllowError(), log.AllowInfoWith("context", "value"), log.AllowNoneWith("user", "Sam"))
114 logger3.With("user", "Sam").With("context", "value").Info("foo", "bar", "baz")
115 if want, have := `{"_msg":"foo","bar":"baz","context":"value","level":"info","user":"Sam"}`, strings.TrimSpace(buf.String()); want != have {
116 t.Errorf("\nwant '%s'\nhave '%s'", want, have)