tendermint/log/tm_logger_test.go

45 lines
1.1 KiB
Go
Raw Normal View History

package log_test
import (
2017-11-06 11:18:42 -08:00
"bytes"
"io/ioutil"
2017-11-06 11:18:42 -08:00
"strings"
"testing"
2017-11-06 11:18:42 -08:00
"github.com/go-logfmt/logfmt"
"github.com/tendermint/tmlibs/log"
)
2017-11-06 11:18:42 -08:00
func TestLoggerLogsItsErrors(t *testing.T) {
var buf bytes.Buffer
logger := log.NewTMLogger(&buf)
logger.Info("foo", "baz baz", "bar")
msg := strings.TrimSpace(buf.String())
if !strings.Contains(msg, logfmt.ErrInvalidKey.Error()) {
t.Errorf("Expected logger msg to contain ErrInvalidKey, got %s", msg)
}
}
2017-05-02 11:26:00 -07:00
func BenchmarkTMLoggerSimple(b *testing.B) {
benchmarkRunner(b, log.NewTMLogger(ioutil.Discard), baseInfoMessage)
}
2017-05-02 11:26:00 -07:00
func BenchmarkTMLoggerContextual(b *testing.B) {
benchmarkRunner(b, log.NewTMLogger(ioutil.Discard), withInfoMessage)
}
func benchmarkRunner(b *testing.B, logger log.Logger, f func(log.Logger)) {
2017-05-04 08:39:16 -07:00
lc := logger.With("common_key", "common_value")
b.ReportAllocs()
b.ResetTimer()
for i := 0; i < b.N; i++ {
f(lc)
}
}
var (
baseInfoMessage = func(logger log.Logger) { logger.Info("foo_message", "foo_key", "foo_value") }
2017-05-04 08:39:16 -07:00
withInfoMessage = func(logger log.Logger) { logger.With("a", "b").Info("c", "d", "f") }
)