my-log/formatters/new_test.go

49 lines
877 B
Go
Raw Normal View History

2024-03-07 10:10:54 -06:00
package formatters
import (
"fmt"
"os"
"slices"
2024-03-07 10:10:54 -06:00
"testing"
"codeberg.org/danjones000/my-log/config"
"github.com/nalgeon/be"
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 TestNewUnsupported(t *testing.T) {
f, err := New("nope")
be.Equal(t, f, nil)
be.Err(t, err)
2024-03-07 10:10:54 -06:00
}
func TestNewCantGetConfig(t *testing.T) {
f, _ := os.CreateTemp("", "test")
oldConf := config.ConfigPath
config.ConfigPath = f.Name()
defer f.Close()
defer func() {
config.ConfigPath = oldConf
}()
fmt.Fprint(f, `{"not":"toml"}`)
form, err := New("plain")
be.Equal(t, form, nil)
be.Err(t, err)
2024-03-09 16:05:59 -06:00
form, err = Preferred()
be.Equal(t, form, nil)
be.Err(t, err)
2024-03-09 16:05:59 -06:00
}
func TestPreferred(t *testing.T) {
form, err := Preferred()
be.Err(t, err, nil)
be.True(t, form != nil)
2024-03-07 10:10:54 -06:00
}