2023-01-29 10:54:56 +00:00
|
|
|
package logger_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2023-02-23 17:49:45 +00:00
|
|
|
"gh.tarampamp.am/error-pages/internal/logger"
|
2023-01-29 10:54:56 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestLevel_String(t *testing.T) {
|
|
|
|
for name, tt := range map[string]struct {
|
|
|
|
giveLevel logger.Level
|
|
|
|
wantString string
|
|
|
|
}{
|
|
|
|
"debug": {giveLevel: logger.DebugLevel, wantString: "debug"},
|
|
|
|
"info": {giveLevel: logger.InfoLevel, wantString: "info"},
|
|
|
|
"warn": {giveLevel: logger.WarnLevel, wantString: "warn"},
|
|
|
|
"error": {giveLevel: logger.ErrorLevel, wantString: "error"},
|
|
|
|
"<unknown>": {giveLevel: logger.Level(127), wantString: "level(127)"},
|
|
|
|
} {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
require.Equal(t, tt.wantString, tt.giveLevel.String())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseLevel(t *testing.T) {
|
|
|
|
for name, tt := range map[string]struct {
|
|
|
|
giveBytes []byte
|
|
|
|
giveString string
|
|
|
|
wantLevel logger.Level
|
|
|
|
wantError error
|
|
|
|
}{
|
|
|
|
"<empty value>": {giveBytes: []byte(""), wantLevel: logger.InfoLevel},
|
|
|
|
"<empty value> (string)": {giveString: "", wantLevel: logger.InfoLevel},
|
|
|
|
"trace": {giveBytes: []byte("debug"), wantLevel: logger.DebugLevel},
|
|
|
|
"verbose": {giveBytes: []byte("debug"), wantLevel: logger.DebugLevel},
|
|
|
|
"debug": {giveBytes: []byte("debug"), wantLevel: logger.DebugLevel},
|
|
|
|
"debug (string)": {giveString: "debug", wantLevel: logger.DebugLevel},
|
|
|
|
"info": {giveBytes: []byte("info"), wantLevel: logger.InfoLevel},
|
|
|
|
"warn": {giveBytes: []byte("warn"), wantLevel: logger.WarnLevel},
|
|
|
|
"error": {giveBytes: []byte("error"), wantLevel: logger.ErrorLevel},
|
|
|
|
"foobar": {giveBytes: []byte("foobar"), wantError: errors.New("unrecognized logging level: \"foobar\"")}, //nolint:lll
|
|
|
|
} {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
var (
|
|
|
|
l logger.Level
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
|
|
|
|
if tt.giveString != "" {
|
|
|
|
l, err = logger.ParseLevel(tt.giveString)
|
|
|
|
} else {
|
|
|
|
l, err = logger.ParseLevel(tt.giveBytes)
|
|
|
|
}
|
|
|
|
|
|
|
|
if tt.wantError == nil {
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, tt.wantLevel, l)
|
|
|
|
} else {
|
|
|
|
require.EqualError(t, err, tt.wantError.Error())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLevels(t *testing.T) {
|
|
|
|
require.Equal(t, []logger.Level{
|
|
|
|
logger.DebugLevel,
|
|
|
|
logger.InfoLevel,
|
|
|
|
logger.WarnLevel,
|
|
|
|
logger.ErrorLevel,
|
|
|
|
}, logger.Levels())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLevelStrings(t *testing.T) {
|
2024-07-03 14:12:13 +00:00
|
|
|
require.Equal(t, []string{"debug", "info", "warn", "error"}, logger.LevelStrings())
|
2023-01-29 10:54:56 +00:00
|
|
|
}
|