|
@ -9,7 +9,7 @@ import ( |
|
|
func Test_doBalanceSticky(t *testing.T) { |
|
|
func Test_doBalanceSticky(t *testing.T) { |
|
|
type args struct { |
|
|
type args struct { |
|
|
partitions []*pub_balancer.PartitionSlotToBroker |
|
|
partitions []*pub_balancer.PartitionSlotToBroker |
|
|
consumerInstanceIds []string |
|
|
|
|
|
|
|
|
consumerInstanceIds []*ConsumerGroupInstance |
|
|
prevMapping *PartitionSlotToConsumerInstanceList |
|
|
prevMapping *PartitionSlotToConsumerInstanceList |
|
|
} |
|
|
} |
|
|
tests := []struct { |
|
|
tests := []struct { |
|
@ -26,7 +26,12 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 100, |
|
|
RangeStop: 100, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: nil, |
|
|
prevMapping: nil, |
|
|
}, |
|
|
}, |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
@ -46,7 +51,16 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 100, |
|
|
RangeStop: 100, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1", "consumer-instance-2"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-2", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: nil, |
|
|
prevMapping: nil, |
|
|
}, |
|
|
}, |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
@ -70,7 +84,12 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 100, |
|
|
RangeStop: 100, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: nil, |
|
|
prevMapping: nil, |
|
|
}, |
|
|
}, |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
@ -99,7 +118,16 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 100, |
|
|
RangeStop: 100, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1", "consumer-instance-2"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-2", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: nil, |
|
|
prevMapping: nil, |
|
|
}, |
|
|
}, |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
wantPartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
@ -128,7 +156,16 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 100, |
|
|
RangeStop: 100, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1", "consumer-instance-2"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-2", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
{ |
|
|
{ |
|
@ -170,7 +207,20 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 100, |
|
|
RangeStop: 100, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1", "consumer-instance-2", "consumer-instance-3"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-2", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-3", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
{ |
|
|
{ |
|
@ -216,7 +266,16 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 150, |
|
|
RangeStop: 150, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1", "consumer-instance-2"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-2", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
{ |
|
|
{ |
|
@ -267,7 +326,20 @@ func Test_doBalanceSticky(t *testing.T) { |
|
|
RangeStop: 150, |
|
|
RangeStop: 150, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
}, |
|
|
consumerInstanceIds: []string{"consumer-instance-1", "consumer-instance-2", "consumer-instance-3"}, |
|
|
|
|
|
|
|
|
consumerInstanceIds: []*ConsumerGroupInstance{ |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-1", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-2", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
InstanceId: "consumer-instance-3", |
|
|
|
|
|
MaxPartitionCount: 1, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
prevMapping: &PartitionSlotToConsumerInstanceList{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
PartitionSlots: []*PartitionSlotToConsumerInstance{ |
|
|
{ |
|
|
{ |
|
|