123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- package sarama
- import (
- "bytes"
- "reflect"
- "testing"
- "github.com/davecgh/go-spew/spew"
- )
- // not specific to request tests, just helper functions for testing structures that
- // implement the encoder or decoder interfaces that needed somewhere to live
- func testEncodable(t *testing.T, name string, in encoder, expect []byte) {
- packet, err := encode(in, nil)
- if err != nil {
- t.Error(err)
- } else if !bytes.Equal(packet, expect) {
- t.Error("Encoding", name, "failed\ngot ", packet, "\nwant", expect)
- }
- }
- func testDecodable(t *testing.T, name string, out decoder, in []byte) {
- err := decode(in, out)
- if err != nil {
- t.Error("Decoding", name, "failed:", err)
- }
- }
- func testVersionDecodable(t *testing.T, name string, out versionedDecoder, in []byte, version int16) {
- err := versionedDecode(in, out, version)
- if err != nil {
- t.Error("Decoding", name, "version", version, "failed:", err)
- }
- }
- func testRequest(t *testing.T, name string, rb protocolBody, expected []byte) {
- if !rb.requiredVersion().IsAtLeast(MinVersion) {
- t.Errorf("Request %s has invalid required version", name)
- }
- packet := testRequestEncode(t, name, rb, expected)
- testRequestDecode(t, name, rb, packet)
- }
- func testRequestEncode(t *testing.T, name string, rb protocolBody, expected []byte) []byte {
- req := &request{correlationID: 123, clientID: "foo", body: rb}
- packet, err := encode(req, nil)
- headerSize := 14 + len("foo")
- if err != nil {
- t.Error(err)
- } else if !bytes.Equal(packet[headerSize:], expected) {
- t.Error("Encoding", name, "failed\ngot ", packet[headerSize:], "\nwant", expected)
- }
- return packet
- }
- func testRequestDecode(t *testing.T, name string, rb protocolBody, packet []byte) {
- decoded, n, err := decodeRequest(bytes.NewReader(packet))
- if err != nil {
- t.Error("Failed to decode request", err)
- } else if decoded.correlationID != 123 || decoded.clientID != "foo" {
- t.Errorf("Decoded header %q is not valid: %+v", name, decoded)
- } else if !reflect.DeepEqual(rb, decoded.body) {
- t.Error(spew.Sprintf("Decoded request %q does not match the encoded one\nencoded: %+v\ndecoded: %+v", name, rb, decoded.body))
- } else if n != len(packet) {
- t.Errorf("Decoded request %q bytes: %d does not match the encoded one: %d\n", name, n, len(packet))
- } else if rb.version() != decoded.body.version() {
- t.Errorf("Decoded request %q version: %d does not match the encoded one: %d\n", name, decoded.body.version(), rb.version())
- }
- }
- func testResponse(t *testing.T, name string, res protocolBody, expected []byte) {
- encoded, err := encode(res, nil)
- if err != nil {
- t.Error(err)
- } else if expected != nil && !bytes.Equal(encoded, expected) {
- t.Error("Encoding", name, "failed\ngot ", encoded, "\nwant", expected)
- }
- decoded := reflect.New(reflect.TypeOf(res).Elem()).Interface().(versionedDecoder)
- if err := versionedDecode(encoded, decoded, res.version()); err != nil {
- t.Error("Decoding", name, "failed:", err)
- }
- if !reflect.DeepEqual(decoded, res) {
- t.Errorf("Decoded response does not match the encoded one\nencoded: %#v\ndecoded: %#v", res, decoded)
- }
- }
- func nullString(s string) *string { return &s }
|