my-log/formatters/new_test.go

41 lines
827 B
Go
Raw Normal View History

2024-03-07 10:10:54 -06:00
package formatters
import (
"context"
"slices"
2024-03-07 10:10:54 -06:00
"testing"
"codeberg.org/danjones000/my-log/config"
"github.com/nalgeon/be"
"github.com/spf13/viper"
2024-03-07 10:10:54 -06:00
)
func TestKinds(t *testing.T) {
kinds := Kinds()
for _, kind := range []string{"plain", "json", "zero"} {
be.True(t, slices.Contains(kinds, kind))
}
2024-03-07 10:10:54 -06:00
}
func setupNewTest(t *testing.T) context.Context {
t.Helper()
v := viper.New()
v.SetConfigType("toml")
v.Set("output.stdout.config.format", "plain")
v.Set("formatters.json.pretty_print", false)
return config.AddToContext(t.Context(), v)
}
2024-03-07 10:10:54 -06:00
func TestNewUnsupported(t *testing.T) {
ctx := setupNewTest(t)
f, err := New(ctx, "nope")
be.Equal(t, f, nil)
be.Err(t, err)
2024-03-07 10:10:54 -06:00
}
2024-03-09 16:05:59 -06:00
func TestPreferred(t *testing.T) {
ctx := setupNewTest(t)
form, err := Preferred(ctx)
be.Err(t, err, nil)
be.True(t, form != nil)
2024-03-07 10:10:54 -06:00
}