mirror of
https://gitee.com/milvus-io/milvus.git
synced 2026-01-05 02:12:48 +08:00
issue: https://github.com/milvus-io/milvus/issues/43968 Co-authored-by: chyezh <ye.zhen@zilliz.com>
95 lines
3.1 KiB
Go
95 lines
3.1 KiB
Go
package discover
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/mock"
|
|
|
|
"github.com/milvus-io/milvus/internal/mocks/streamingcoord/server/mock_balancer"
|
|
"github.com/milvus-io/milvus/internal/mocks/streamingnode/client/mock_manager"
|
|
"github.com/milvus-io/milvus/internal/streamingcoord/server/balancer"
|
|
"github.com/milvus-io/milvus/internal/streamingcoord/server/resource"
|
|
"github.com/milvus-io/milvus/pkg/v2/mocks/proto/mock_streamingpb"
|
|
"github.com/milvus-io/milvus/pkg/v2/proto/streamingpb"
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/types"
|
|
"github.com/milvus-io/milvus/pkg/v2/util/typeutil"
|
|
)
|
|
|
|
func TestAssignmentDiscover(t *testing.T) {
|
|
mc := mock_manager.NewMockManagerClient(t)
|
|
mc.EXPECT().GetAllStreamingNodes(mock.Anything).Return(map[int64]*types.StreamingNodeInfo{
|
|
1: {ServerID: 1, Address: "localhost:1"},
|
|
}, nil)
|
|
resource.InitForTest(resource.OptStreamingManagerClient(mc))
|
|
b := mock_balancer.NewMockBalancer(t)
|
|
b.EXPECT().WatchChannelAssignments(mock.Anything, mock.Anything).RunAndReturn(func(ctx context.Context, cb balancer.WatchChannelAssignmentsCallback) error {
|
|
versions := []typeutil.VersionInt64Pair{
|
|
{Global: 1, Local: 2},
|
|
{Global: 1, Local: 3},
|
|
}
|
|
pchans := [][]types.PChannelInfoAssigned{
|
|
{
|
|
types.PChannelInfoAssigned{
|
|
Channel: types.PChannelInfo{Name: "pchannel", Term: 1},
|
|
Node: types.StreamingNodeInfo{ServerID: 1, Address: "localhost:1"},
|
|
},
|
|
},
|
|
{
|
|
types.PChannelInfoAssigned{
|
|
Channel: types.PChannelInfo{Name: "pchannel", Term: 1},
|
|
Node: types.StreamingNodeInfo{ServerID: 1, Address: "localhost:1"},
|
|
},
|
|
types.PChannelInfoAssigned{
|
|
Channel: types.PChannelInfo{Name: "pchannel2", Term: 1},
|
|
Node: types.StreamingNodeInfo{ServerID: 1, Address: "localhost:1"},
|
|
},
|
|
},
|
|
}
|
|
for i := 0; i < len(versions); i++ {
|
|
cb(balancer.WatchChannelAssignmentsCallbackParam{
|
|
Version: versions[i],
|
|
CChannelAssignment: &streamingpb.CChannelAssignment{Meta: &streamingpb.CChannelMeta{Pchannel: "pchannel"}},
|
|
Relations: pchans[i],
|
|
})
|
|
}
|
|
<-ctx.Done()
|
|
return context.Cause(ctx)
|
|
})
|
|
b.EXPECT().MarkAsUnavailable(mock.Anything, mock.Anything).Return(nil)
|
|
|
|
streamServer := mock_streamingpb.NewMockStreamingCoordAssignmentService_AssignmentDiscoverServer(t)
|
|
streamServer.EXPECT().Context().Return(context.Background())
|
|
k := 0
|
|
reqs := []*streamingpb.AssignmentDiscoverRequest{
|
|
{
|
|
Command: &streamingpb.AssignmentDiscoverRequest_ReportError{
|
|
ReportError: &streamingpb.ReportAssignmentErrorRequest{
|
|
Pchannel: &streamingpb.PChannelInfo{
|
|
Name: "pchannel",
|
|
Term: 1,
|
|
},
|
|
Err: &streamingpb.StreamingError{
|
|
Code: streamingpb.StreamingCode_STREAMING_CODE_CHANNEL_NOT_EXIST,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
Command: &streamingpb.AssignmentDiscoverRequest_Close{},
|
|
},
|
|
}
|
|
streamServer.EXPECT().Recv().RunAndReturn(func() (*streamingpb.AssignmentDiscoverRequest, error) {
|
|
if k >= len(reqs) {
|
|
return nil, io.EOF
|
|
}
|
|
req := reqs[k]
|
|
k++
|
|
return req, nil
|
|
})
|
|
streamServer.EXPECT().Send(mock.Anything).Return(nil)
|
|
ads := NewAssignmentDiscoverServer(b, streamServer)
|
|
ads.Execute()
|
|
}
|