blob: 1139d0ff1008619d177626ee117e7d31fced3680 [file] [log] [blame]
// Copyright 2017 Google Inc. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package pubsub
import (
"testing"
"cloud.google.com/go/internal/testutil"
pb "google.golang.org/genproto/googleapis/pubsub/v1"
)
func TestSplitRequest(t *testing.T) {
split := func(a []string, i int) ([]string, []string) {
if len(a) < i {
return a, nil
}
return a[:i], a[i:]
}
ackIDs := []string{"aaaa", "bbbb", "cccc", "dddd", "eeee"}
modDeadlines := []int32{1, 2, 3, 4, 5}
for i, test := range []struct {
ackIDs []string
modAckIDs []string
splitIndex int
}{
{ackIDs, ackIDs, 2},
{nil, ackIDs, 3},
{ackIDs, nil, 5},
{nil, ackIDs[:1], 1},
} {
req := &pb.StreamingPullRequest{
AckIds: test.ackIDs,
ModifyDeadlineAckIds: test.modAckIDs,
ModifyDeadlineSeconds: modDeadlines[:len(test.modAckIDs)],
}
a1, a2 := split(test.ackIDs, test.splitIndex)
m1, m2 := split(test.modAckIDs, test.splitIndex)
want1 := &pb.StreamingPullRequest{
AckIds: a1,
ModifyDeadlineAckIds: m1,
ModifyDeadlineSeconds: modDeadlines[:len(m1)],
}
want2 := &pb.StreamingPullRequest{
AckIds: a2,
ModifyDeadlineAckIds: m2,
ModifyDeadlineSeconds: modDeadlines[len(m1) : len(m1)+len(m2)],
}
got1, got2 := splitRequest(req, reqFixedOverhead+40)
if !testutil.Equal(got1, want1) {
t.Errorf("#%d: first:\ngot %+v\nwant %+v", i, got1, want1)
}
if !testutil.Equal(got2, want2) {
t.Errorf("#%d: second:\ngot %+v\nwant %+v", i, got2, want2)
}
}
}