From 70f4636522d4c66712a37a364f6d0d1bb731cf4f Mon Sep 17 00:00:00 2001 From: Joel Wetzell Date: Sun, 28 Dec 2025 16:25:57 -0600 Subject: [PATCH] add test for json.encode --- internal/processor/json-encode_test.go | 45 ++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 internal/processor/json-encode_test.go diff --git a/internal/processor/json-encode_test.go b/internal/processor/json-encode_test.go new file mode 100644 index 0000000..501f0c4 --- /dev/null +++ b/internal/processor/json-encode_test.go @@ -0,0 +1,45 @@ +package processor_test + +import ( + "slices" + "testing" + + "github.com/jwetzell/osc-go" + "github.com/jwetzell/showbridge-go/internal/processor" +) + +func TestGoodJsonEncode(t *testing.T) { + stringEncoder := processor.JsonEncode{} + tests := []struct { + processor processor.Processor + name string + payload any + expected []byte + }{ + { + processor: &stringEncoder, + name: "hello", + payload: osc.OSCMessage{ + Address: "/hello", + }, + expected: []byte("{\"address\":\"/hello\",\"args\":null}"), + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + got, err := test.processor.Process(t.Context(), test.payload) + + gotBytes, ok := got.([]byte) + if !ok { + t.Fatalf("json.encode returned a %T payload: %s", got, got) + } + if err != nil { + t.Fatalf("json.encode failed: %s", err) + } + if !slices.Equal(gotBytes, test.expected) { + t.Fatalf("json.encode got %x, expected %s", got, test.expected) + } + }) + } +}