1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-11 17:18:28 +02:00
go-micro/plugins/logger/zerolog/zerolog_test.go
2020-12-26 15:32:45 +00:00

83 lines
2.0 KiB
Go

package zerolog
import (
"errors"
"os"
"testing"
"time"
"github.com/micro/go-micro/v2/logger"
"github.com/rs/zerolog"
)
func TestName(t *testing.T) {
l := NewLogger()
if l.String() != "zerolog" {
t.Errorf("error: name expected 'zerolog' actual: %s", l.String())
}
t.Logf("testing logger name: %s", l.String())
}
func TestWithOutput(t *testing.T) {
logger.DefaultLogger = NewLogger(logger.WithOutput(os.Stdout))
logger.Logf(logger.InfoLevel, "testing: %s", "WithOutput")
}
func TestSetLevel(t *testing.T) {
logger.DefaultLogger = NewLogger()
logger.Init(logger.WithLevel(logger.DebugLevel))
logger.Logf(logger.DebugLevel, "test show debug: %s", "debug msg")
logger.Init(logger.WithLevel(logger.InfoLevel))
logger.Logf(logger.DebugLevel, "test non-show debug: %s", "debug msg")
}
func TestWithReportCaller(t *testing.T) {
logger.DefaultLogger = NewLogger(ReportCaller())
logger.Logf(logger.InfoLevel, "testing: %s", "WithReportCaller")
}
func TestWithOut(t *testing.T) {
logger.DefaultLogger = NewLogger(logger.WithOutput(os.Stdout))
logger.Logf(logger.InfoLevel, "testing: %s", "WithOut")
}
func TestWithDevelopmentMode(t *testing.T) {
logger.DefaultLogger = NewLogger(WithDevelopmentMode(), WithTimeFormat(time.Kitchen))
logger.Logf(logger.InfoLevel, "testing: %s", "DevelopmentMode")
}
func TestWithFields(t *testing.T) {
logger.DefaultLogger = NewLogger()
logger.Fields(map[string]interface{}{
"sumo": "demo",
"human": true,
"age": 99,
}).Logf(logger.InfoLevel, "testing: %s", "WithFields")
}
func TestWithError(t *testing.T) {
logger.DefaultLogger = NewLogger()
logger.Fields(map[string]interface{}{"error": errors.New("I am Error")}).Logf(logger.ErrorLevel, "testing: %s", "WithError")
}
func TestWithHooks(t *testing.T) {
simpleHook := zerolog.HookFunc(func(e *zerolog.Event, level zerolog.Level, msg string) {
e.Bool("has_level", level != zerolog.NoLevel)
e.Str("test", "logged")
})
logger.DefaultLogger = NewLogger(WithHooks([]zerolog.Hook{simpleHook}))
logger.Logf(logger.InfoLevel, "testing: %s", "WithHooks")
}