Files
quic-go/qlog/event_test.go
2020-03-27 20:22:47 +07:00

53 lines
1.4 KiB
Go

package qlog
import (
"bytes"
"encoding/json"
"time"
"github.com/francoispqt/gojay"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
)
type mevent struct{}
var _ eventDetails = mevent{}
func (mevent) Category() category { return categoryConnectivity }
func (mevent) Name() string { return "mevent" }
func (mevent) IsNil() bool { return false }
func (mevent) MarshalJSONObject(enc *gojay.Encoder) { enc.StringKey("event", "details") }
var _ = Describe("Events", func() {
It("marshals the fields before the event details", func() {
buf := &bytes.Buffer{}
enc := gojay.NewEncoder(buf)
Expect(enc.Encode(event{
RelativeTime: 1337 * time.Microsecond,
eventDetails: mevent{},
})).To(Succeed())
var decoded []interface{}
Expect(json.Unmarshal(buf.Bytes(), &decoded)).To(Succeed())
Expect(decoded).To(HaveLen(4))
// 1st field
Expect(eventFields[0]).To(Equal("relative_time"))
Expect(decoded[0].(float64)).To(Equal(1.337))
// 2nd field
Expect(eventFields[1]).To(Equal("category"))
Expect(decoded[1].(string)).To(Equal(categoryConnectivity.String()))
// 3rd field
Expect(eventFields[2]).To(Equal("event"))
Expect(decoded[2].(string)).To(Equal("mevent"))
// 4th field
Expect(eventFields[3]).To(Equal("data"))
Expect(decoded[3].(map[string]interface{})["event"]).To(Equal("details"))
})
})