111 lines
1.9 KiB
Go
111 lines
1.9 KiB
Go
|
package logfmt
|
||
|
|
||
|
import (
|
||
|
"reflect"
|
||
|
"testing"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
type pair struct {
|
||
|
k, v string
|
||
|
}
|
||
|
|
||
|
type coll struct {
|
||
|
a []pair
|
||
|
}
|
||
|
|
||
|
func (c *coll) HandleLogfmt(key, val []byte) error {
|
||
|
c.a = append(c.a, pair{string(key), string(val)})
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func TestDecodeCustom(t *testing.T) {
|
||
|
data := []byte(`a=foo b=10ms c=cat E="123" d foo= emp=`)
|
||
|
|
||
|
g := new(coll)
|
||
|
if err := Unmarshal(data, g); err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
|
||
|
w := []pair{
|
||
|
{"a", "foo"},
|
||
|
{"b", "10ms"},
|
||
|
{"c", "cat"},
|
||
|
{"E", "123"},
|
||
|
{"d", ""},
|
||
|
{"foo", ""},
|
||
|
{"emp", ""},
|
||
|
}
|
||
|
|
||
|
if !reflect.DeepEqual(w, g.a) {
|
||
|
t.Errorf("\nwant %v\n got %v", w, g)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestDecodeDefault(t *testing.T) {
|
||
|
var g struct {
|
||
|
Float float64
|
||
|
NFloat *float64
|
||
|
String string
|
||
|
Int int
|
||
|
D time.Duration
|
||
|
NB *[]byte
|
||
|
Here bool
|
||
|
This int `logfmt:"that"`
|
||
|
}
|
||
|
|
||
|
em, err := NewStructHandler(&g)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
|
||
|
var tests = []struct {
|
||
|
name string
|
||
|
val string
|
||
|
want interface{}
|
||
|
}{
|
||
|
{"float", "3.14", 3.14},
|
||
|
{"nfloat", "123", float64(123)},
|
||
|
{"string", "foobar", "foobar"},
|
||
|
{"inT", "10", 10},
|
||
|
{"d", "1h", 1 * time.Hour},
|
||
|
{"nb", "bytes!", []byte("bytes!")},
|
||
|
{"here", "", true},
|
||
|
{"that", "5", 5},
|
||
|
}
|
||
|
|
||
|
rv := reflect.Indirect(reflect.ValueOf(&g))
|
||
|
for i, test := range tests {
|
||
|
err = em.HandleLogfmt([]byte(test.name), []byte(test.val))
|
||
|
if err != nil {
|
||
|
t.Error(err)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
fv := reflect.Indirect(rv.Field(i))
|
||
|
if !fv.IsValid() {
|
||
|
ft := rv.Type().Field(i)
|
||
|
t.Errorf("%s is invalid", ft.Name)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
gv := fv.Interface()
|
||
|
if !reflect.DeepEqual(gv, test.want) {
|
||
|
t.Errorf("want %T %#v, got %T %#v", test.want, test.want, gv, gv)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if g.Float != 3.14 {
|
||
|
t.Errorf("want %v, got %v", 3.14, g.Float)
|
||
|
}
|
||
|
|
||
|
err = em.HandleLogfmt([]byte("nfloat"), []byte("123"))
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
|
||
|
if g.NFloat == nil || *g.NFloat != 123 {
|
||
|
t.Errorf("want %v, got %v", 123, *g.NFloat)
|
||
|
}
|
||
|
}
|