package logger_test import ( "errors" "testing" "github.com/stretchr/testify/require" "gh.tarampamp.am/error-pages/internal/logger" ) 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"}, "": {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 }{ "": {giveBytes: []byte(""), wantLevel: logger.InfoLevel}, " (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) { require.Equal(t, []string{"debug", "info", "warn", "error"}, logger.LevelStrings()) }