|
|
@@ -0,0 +1,98 @@
|
|
|
+package sarama
|
|
|
+
|
|
|
+import (
|
|
|
+ "reflect"
|
|
|
+ "testing"
|
|
|
+)
|
|
|
+
|
|
|
+var (
|
|
|
+ joinGroupResponseNoError = []byte{
|
|
|
+ 0x00, 0x00, // No error
|
|
|
+ 0x00, 0x01, 0x02, 0x03, // Generation ID
|
|
|
+ 0, 8, 'p', 'r', 'o', 't', 'o', 'c', 'o', 'l', // Protocol name chosen
|
|
|
+ 0, 3, 'f', 'o', 'o', // Leader ID
|
|
|
+ 0, 3, 'b', 'a', 'r', // Member ID
|
|
|
+ 0, 0, 0, 0, // No member info
|
|
|
+ }
|
|
|
+
|
|
|
+ joinGroupResponseWithError = []byte{
|
|
|
+ 0, 23, // Error: inconsistent group protocol
|
|
|
+ 0x00, 0x00, 0x00, 0x00, // Generation ID
|
|
|
+ 0, 0, // Protocol name chosen
|
|
|
+ 0, 0, // Leader ID
|
|
|
+ 0, 0, // Member ID
|
|
|
+ 0, 0, 0, 0, // No member info
|
|
|
+ }
|
|
|
+
|
|
|
+ joinGroupResponseLeader = []byte{
|
|
|
+ 0x00, 0x00, // No error
|
|
|
+ 0x00, 0x01, 0x02, 0x03, // Generation ID
|
|
|
+ 0, 8, 'p', 'r', 'o', 't', 'o', 'c', 'o', 'l', // Protocol name chosen
|
|
|
+ 0, 3, 'f', 'o', 'o', // Leader ID
|
|
|
+ 0, 3, 'f', 'o', 'o', // Member ID == Leader ID
|
|
|
+ 0, 0, 0, 1, // 1 member
|
|
|
+ 0, 3, 'f', 'o', 'o', // Member ID
|
|
|
+ 0, 0, 0, 3, 0x01, 0x02, 0x03, // Member metadata
|
|
|
+ }
|
|
|
+)
|
|
|
+
|
|
|
+func TestJoinGroupResponse(t *testing.T) {
|
|
|
+ var response *JoinGroupResponse
|
|
|
+
|
|
|
+ response = new(JoinGroupResponse)
|
|
|
+ testDecodable(t, "no error", response, joinGroupResponseNoError)
|
|
|
+ if response.Err != ErrNoError {
|
|
|
+ t.Error("Decoding Err failed: no error expected but found", response.Err)
|
|
|
+ }
|
|
|
+ if response.GenerationId != 66051 {
|
|
|
+ t.Error("Decoding GenerationId failed, found:", response.GenerationId)
|
|
|
+ }
|
|
|
+ if response.LeaderId != "foo" {
|
|
|
+ t.Error("Decoding LeaderId failed, found:", response.LeaderId)
|
|
|
+ }
|
|
|
+ if response.MemberId != "bar" {
|
|
|
+ t.Error("Decoding MemberId failed, found:", response.MemberId)
|
|
|
+ }
|
|
|
+ if len(response.Members) != 0 {
|
|
|
+ t.Error("Decoding Members failed, found:", response.Members)
|
|
|
+ }
|
|
|
+
|
|
|
+ response = new(JoinGroupResponse)
|
|
|
+ testDecodable(t, "with error", response, joinGroupResponseWithError)
|
|
|
+ if response.Err != ErrInconsistentGroupProtocol {
|
|
|
+ t.Error("Decoding Err failed: ErrInconsistentGroupProtocol expected but found", response.Err)
|
|
|
+ }
|
|
|
+ if response.GenerationId != 0 {
|
|
|
+ t.Error("Decoding GenerationId failed, found:", response.GenerationId)
|
|
|
+ }
|
|
|
+ if response.LeaderId != "" {
|
|
|
+ t.Error("Decoding LeaderId failed, found:", response.LeaderId)
|
|
|
+ }
|
|
|
+ if response.MemberId != "" {
|
|
|
+ t.Error("Decoding MemberId failed, found:", response.MemberId)
|
|
|
+ }
|
|
|
+ if len(response.Members) != 0 {
|
|
|
+ t.Error("Decoding Members failed, found:", response.Members)
|
|
|
+ }
|
|
|
+
|
|
|
+ response = new(JoinGroupResponse)
|
|
|
+ testDecodable(t, "with error", response, joinGroupResponseLeader)
|
|
|
+ if response.Err != ErrNoError {
|
|
|
+ t.Error("Decoding Err failed: ErrNoError expected but found", response.Err)
|
|
|
+ }
|
|
|
+ if response.GenerationId != 66051 {
|
|
|
+ t.Error("Decoding GenerationId failed, found:", response.GenerationId)
|
|
|
+ }
|
|
|
+ if response.LeaderId != "foo" {
|
|
|
+ t.Error("Decoding LeaderId failed, found:", response.LeaderId)
|
|
|
+ }
|
|
|
+ if response.MemberId != "foo" {
|
|
|
+ t.Error("Decoding MemberId failed, found:", response.MemberId)
|
|
|
+ }
|
|
|
+ if len(response.Members) != 1 {
|
|
|
+ t.Error("Decoding Members failed, found:", response.Members)
|
|
|
+ }
|
|
|
+ if !reflect.DeepEqual(response.Members["foo"], []byte{0x01, 0x02, 0x03}) {
|
|
|
+ t.Error("Decoding foo member failed, found:", response.Members["foo"])
|
|
|
+ }
|
|
|
+}
|