2020-02-14 22:56:46 -08:00
|
|
|
package zerolog
|
2020-02-11 02:49:33 -08:00
|
|
|
|
|
|
|
import (
|
2020-02-14 22:56:46 -08:00
|
|
|
"errors"
|
2020-02-11 02:49:33 -08:00
|
|
|
"os"
|
|
|
|
"testing"
|
2020-02-14 22:56:46 -08:00
|
|
|
"time"
|
2020-02-11 02:49:33 -08:00
|
|
|
|
|
|
|
"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())
|
|
|
|
}
|
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
func TestWithOutput(t *testing.T) {
|
|
|
|
logger.DefaultLogger = NewLogger(logger.WithOutput(os.Stdout))
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Logf(logger.InfoLevel, "testing: %s", "WithOutput")
|
|
|
|
}
|
2020-02-11 02:49:33 -08:00
|
|
|
|
|
|
|
func TestSetLevel(t *testing.T) {
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger()
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Init(logger.WithLevel(logger.DebugLevel))
|
|
|
|
logger.Logf(logger.DebugLevel, "test show debug: %s", "debug msg")
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Init(logger.WithLevel(logger.InfoLevel))
|
|
|
|
logger.Logf(logger.DebugLevel, "test non-show debug: %s", "debug msg")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestWithReportCaller(t *testing.T) {
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger(ReportCaller())
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Logf(logger.InfoLevel, "testing: %s", "WithReportCaller")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|
2020-02-14 22:56:46 -08:00
|
|
|
|
2020-02-11 02:49:33 -08:00
|
|
|
func TestWithOut(t *testing.T) {
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger(logger.WithOutput(os.Stdout))
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Logf(logger.InfoLevel, "testing: %s", "WithOut")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|
|
|
|
|
2020-02-14 22:56:46 -08:00
|
|
|
func TestWithDevelopmentMode(t *testing.T) {
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger(WithDevelopmentMode(), WithTimeFormat(time.Kitchen))
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Logf(logger.InfoLevel, "testing: %s", "DevelopmentMode")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|
|
|
|
|
2020-02-14 22:56:46 -08:00
|
|
|
func TestWithFields(t *testing.T) {
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger()
|
2020-02-14 22:56:46 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Fields(map[string]interface{}{
|
2020-02-14 22:56:46 -08:00
|
|
|
"sumo": "demo",
|
|
|
|
"human": true,
|
|
|
|
"age": 99,
|
|
|
|
}).Logf(logger.InfoLevel, "testing: %s", "WithFields")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|
|
|
|
|
2020-02-14 22:56:46 -08:00
|
|
|
func TestWithError(t *testing.T) {
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger()
|
2020-03-18 00:57:10 +03:00
|
|
|
logger.Fields(map[string]interface{}{"error": errors.New("I am Error")}).Logf(logger.ErrorLevel, "testing: %s", "WithError")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
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")
|
|
|
|
})
|
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.DefaultLogger = NewLogger(WithHooks([]zerolog.Hook{simpleHook}))
|
2020-02-11 02:49:33 -08:00
|
|
|
|
2020-02-21 01:31:16 -08:00
|
|
|
logger.Logf(logger.InfoLevel, "testing: %s", "WithHooks")
|
2020-02-11 02:49:33 -08:00
|
|
|
}
|