1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- package sarama
- import "testing"
- var (
- joinGroupRequestV0_NoProtocols = []byte{
- 0, 9, 'T', 'e', 's', 't', 'G', 'r', 'o', 'u', 'p', // Group ID
- 0, 0, 0, 100, // Session timeout
- 0, 0, // Member ID
- 0, 8, 'c', 'o', 'n', 's', 'u', 'm', 'e', 'r', // Protocol Type
- 0, 0, 0, 0, // 0 protocol groups
- }
- joinGroupRequestV0_OneProtocol = []byte{
- 0, 9, 'T', 'e', 's', 't', 'G', 'r', 'o', 'u', 'p', // Group ID
- 0, 0, 0, 100, // Session timeout
- 0, 11, 'O', 'n', 'e', 'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', // Member ID
- 0, 8, 'c', 'o', 'n', 's', 'u', 'm', 'e', 'r', // Protocol Type
- 0, 0, 0, 1, // 1 group protocol
- 0, 3, 'o', 'n', 'e', // Protocol name
- 0, 0, 0, 3, 0x01, 0x02, 0x03, // protocol metadata
- }
- joinGroupRequestV1 = []byte{
- 0, 9, 'T', 'e', 's', 't', 'G', 'r', 'o', 'u', 'p', // Group ID
- 0, 0, 0, 100, // Session timeout
- 0, 0, 0, 200, // Rebalance timeout
- 0, 11, 'O', 'n', 'e', 'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', // Member ID
- 0, 8, 'c', 'o', 'n', 's', 'u', 'm', 'e', 'r', // Protocol Type
- 0, 0, 0, 1, // 1 group protocol
- 0, 3, 'o', 'n', 'e', // Protocol name
- 0, 0, 0, 3, 0x01, 0x02, 0x03, // protocol metadata
- }
- )
- func TestJoinGroupRequest(t *testing.T) {
- request := new(JoinGroupRequest)
- request.GroupId = "TestGroup"
- request.SessionTimeout = 100
- request.ProtocolType = "consumer"
- testRequest(t, "V0: no protocols", request, joinGroupRequestV0_NoProtocols)
- }
- func TestJoinGroupRequestV0_OneProtocol(t *testing.T) {
- request := new(JoinGroupRequest)
- request.GroupId = "TestGroup"
- request.SessionTimeout = 100
- request.MemberId = "OneProtocol"
- request.ProtocolType = "consumer"
- request.AddGroupProtocol("one", []byte{0x01, 0x02, 0x03})
- packet := testRequestEncode(t, "V0: one protocol", request, joinGroupRequestV0_OneProtocol)
- request.GroupProtocols = make(map[string][]byte)
- request.GroupProtocols["one"] = []byte{0x01, 0x02, 0x03}
- testRequestDecode(t, "V0: one protocol", request, packet)
- }
- func TestJoinGroupRequestDeprecatedEncode(t *testing.T) {
- request := new(JoinGroupRequest)
- request.GroupId = "TestGroup"
- request.SessionTimeout = 100
- request.MemberId = "OneProtocol"
- request.ProtocolType = "consumer"
- request.GroupProtocols = make(map[string][]byte)
- request.GroupProtocols["one"] = []byte{0x01, 0x02, 0x03}
- packet := testRequestEncode(t, "V0: one protocol", request, joinGroupRequestV0_OneProtocol)
- request.AddGroupProtocol("one", []byte{0x01, 0x02, 0x03})
- testRequestDecode(t, "V0: one protocol", request, packet)
- }
- func TestJoinGroupRequestV1(t *testing.T) {
- request := new(JoinGroupRequest)
- request.Version = 1
- request.GroupId = "TestGroup"
- request.SessionTimeout = 100
- request.RebalanceTimeout = 200
- request.MemberId = "OneProtocol"
- request.ProtocolType = "consumer"
- request.AddGroupProtocol("one", []byte{0x01, 0x02, 0x03})
- packet := testRequestEncode(t, "V1", request, joinGroupRequestV1)
- request.GroupProtocols = make(map[string][]byte)
- request.GroupProtocols["one"] = []byte{0x01, 0x02, 0x03}
- testRequestDecode(t, "V1", request, packet)
- }
|