my-log/formatters/json_test.go

82 lines
1.8 KiB
Go
Raw Normal View History

2024-03-10 11:33:51 -05:00
package formatters
import (
"fmt"
"testing"
"time"
"codeberg.org/danjones000/my-log/internal/testutil/bep"
2024-03-10 11:33:51 -05:00
"codeberg.org/danjones000/my-log/models"
"github.com/nalgeon/be"
2024-03-10 11:33:51 -05:00
)
func TestJsonName(t *testing.T) {
f, _ := New("json")
be.Equal(t, f.Name(), "json")
2024-03-10 11:33:51 -05:00
}
func TestJsonMeta(t *testing.T) {
f, _ := New("json")
m := models.Meta{Key: "foo", Value: 42}
2024-03-10 11:33:51 -05:00
exp := `{"foo":42}`
o, err := f.Meta(m)
be.Err(t, err, nil)
bep.JSON(t, o, []byte(exp))
2024-03-10 11:33:51 -05:00
}
func TestJsonEntry(t *testing.T) {
when := time.Now()
f, _ := New("json")
m := models.Meta{Key: "foo", Value: 42}
2024-03-10 11:33:51 -05:00
e := models.Entry{
Title: "Homer",
Date: when,
Fields: []models.Meta{m},
}
exp := fmt.Sprintf(`{"title":"%s","date":"%s","foo":42}`, e.Title, when.Format(time.RFC3339))
o, err := f.Entry(e)
be.Err(t, err, nil)
bep.JSON(t, o, []byte(exp))
2024-03-10 11:33:51 -05:00
}
func TestJsonLog(t *testing.T) {
when := time.Now()
f, _ := New("json")
m := models.Meta{Key: "foo", Value: 42}
2024-03-10 11:33:51 -05:00
e := models.Entry{
Title: "Homer",
Date: when,
Fields: []models.Meta{m},
}
l := models.Log{Name: "stuff", Entries: []models.Entry{e}}
2024-03-10 11:33:51 -05:00
exp := fmt.Sprintf(`{"%s":[{"title":"%s","date":"%s","foo":42}]}`, l.Name, e.Title, when.Format(time.RFC3339))
o, err := f.Log(l)
be.Err(t, err, nil)
bep.JSON(t, o, []byte(exp))
2024-03-10 11:33:51 -05:00
}
func TestJsonNoLogs(t *testing.T) {
f, _ := New("json")
o, err := f.Logs([]models.Log{})
var exp []byte
be.Err(t, err, nil)
be.Equal(t, o, exp)
2024-03-10 11:33:51 -05:00
}
2024-03-10 12:14:21 -05:00
func TestJsonErr(t *testing.T) {
f, _ := New("json")
o, err := f.Meta(models.Meta{Key: "foo", Value: make(chan bool)})
2024-03-10 12:14:21 -05:00
var exp []byte
be.Err(t, err)
be.Equal(t, o, exp)
2024-03-10 12:14:21 -05:00
}
func TestJsonPretty(t *testing.T) {
f := Json{true}
o, err := f.Meta(models.Meta{Key: "foo", Value: 42})
2024-03-10 12:14:21 -05:00
exp := `{
"foo": 42
}`
be.Err(t, err, nil)
be.Equal(t, string(o), exp)
2024-03-10 12:14:21 -05:00
}