milvus/internal/util/wrappers/qn_wrapper_test.go
congqixia bcbe98aba1
Add querynode client wrapper and avoid grpc in standalone mode (#27781)
Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
2023-10-19 11:10:07 +08:00

295 lines
9.6 KiB
Go

// Licensed to the LF AI & Data foundation under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you 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 wrappers
import (
"context"
"testing"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/suite"
"github.com/milvus-io/milvus-proto/go-api/v2/milvuspb"
"github.com/milvus-io/milvus/internal/mocks"
"github.com/milvus-io/milvus/internal/proto/internalpb"
"github.com/milvus-io/milvus/internal/proto/querypb"
"github.com/milvus-io/milvus/internal/types"
"github.com/milvus-io/milvus/pkg/util/merr"
)
type QnWrapperSuite struct {
suite.Suite
qn *mocks.MockQueryNode
client types.QueryNodeClient
}
func (s *QnWrapperSuite) SetupTest() {
s.qn = mocks.NewMockQueryNode(s.T())
s.client = WrapQueryNodeServerAsClient(s.qn)
}
func (s *QnWrapperSuite) TearDownTest() {
s.client = nil
s.qn = nil
}
func (s *QnWrapperSuite) TestGetComponentStates() {
s.qn.EXPECT().GetComponentStates(mock.Anything, mock.Anything).
Return(&milvuspb.ComponentStates{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetComponentStates(context.Background(), &milvuspb.GetComponentStatesRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestGetTimeTickChannel() {
s.qn.EXPECT().GetTimeTickChannel(mock.Anything, mock.Anything).
Return(&milvuspb.StringResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetTimeTickChannel(context.Background(), &internalpb.GetTimeTickChannelRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestGetStatisticsChannel() {
s.qn.EXPECT().GetStatisticsChannel(mock.Anything, mock.Anything).
Return(&milvuspb.StringResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetStatisticsChannel(context.Background(), &internalpb.GetStatisticsChannelRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestWatchDmChannels() {
s.qn.EXPECT().WatchDmChannels(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.WatchDmChannels(context.Background(), &querypb.WatchDmChannelsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestUnsubDmChannel() {
s.qn.EXPECT().UnsubDmChannel(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.UnsubDmChannel(context.Background(), &querypb.UnsubDmChannelRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestLoadSegments() {
s.qn.EXPECT().LoadSegments(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.LoadSegments(context.Background(), &querypb.LoadSegmentsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestReleaseCollection() {
s.qn.EXPECT().ReleaseCollection(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.ReleaseCollection(context.Background(), &querypb.ReleaseCollectionRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestLoadPartitions() {
s.qn.EXPECT().LoadPartitions(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.LoadPartitions(context.Background(), &querypb.LoadPartitionsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestReleasePartitions() {
s.qn.EXPECT().ReleasePartitions(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.ReleasePartitions(context.Background(), &querypb.ReleasePartitionsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestReleaseSegments() {
s.qn.EXPECT().ReleaseSegments(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.ReleaseSegments(context.Background(), &querypb.ReleaseSegmentsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestGetSegmentInfo() {
s.qn.EXPECT().GetSegmentInfo(mock.Anything, mock.Anything).
Return(&querypb.GetSegmentInfoResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetSegmentInfo(context.Background(), &querypb.GetSegmentInfoRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestSyncReplicaSegments() {
s.qn.EXPECT().SyncReplicaSegments(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.SyncReplicaSegments(context.Background(), &querypb.SyncReplicaSegmentsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestGetStatistics() {
s.qn.EXPECT().GetStatistics(mock.Anything, mock.Anything).
Return(&internalpb.GetStatisticsResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetStatistics(context.Background(), &querypb.GetStatisticsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestSearch() {
s.qn.EXPECT().Search(mock.Anything, mock.Anything).
Return(&internalpb.SearchResults{Status: merr.Status(nil)}, nil)
resp, err := s.client.Search(context.Background(), &querypb.SearchRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestSearchSegments() {
s.qn.EXPECT().SearchSegments(mock.Anything, mock.Anything).
Return(&internalpb.SearchResults{Status: merr.Status(nil)}, nil)
resp, err := s.client.SearchSegments(context.Background(), &querypb.SearchRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestQuery() {
s.qn.EXPECT().Query(mock.Anything, mock.Anything).
Return(&internalpb.RetrieveResults{Status: merr.Status(nil)}, nil)
resp, err := s.client.Query(context.Background(), &querypb.QueryRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestQuerySegments() {
s.qn.EXPECT().QuerySegments(mock.Anything, mock.Anything).
Return(&internalpb.RetrieveResults{Status: merr.Status(nil)}, nil)
resp, err := s.client.QuerySegments(context.Background(), &querypb.QueryRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestShowConfigurations() {
s.qn.EXPECT().ShowConfigurations(mock.Anything, mock.Anything).
Return(&internalpb.ShowConfigurationsResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.ShowConfigurations(context.Background(), &internalpb.ShowConfigurationsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestGetMetrics() {
s.qn.EXPECT().GetMetrics(mock.Anything, mock.Anything).
Return(&milvuspb.GetMetricsResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetMetrics(context.Background(), &milvuspb.GetMetricsRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) GetDataDistribution() {
s.qn.EXPECT().GetDataDistribution(mock.Anything, mock.Anything).
Return(&querypb.GetDataDistributionResponse{Status: merr.Status(nil)}, nil)
resp, err := s.client.GetDataDistribution(context.Background(), &querypb.GetDataDistributionRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestSyncDistribution() {
s.qn.EXPECT().SyncDistribution(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.SyncDistribution(context.Background(), &querypb.SyncDistributionRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
func (s *QnWrapperSuite) TestDelete() {
s.qn.EXPECT().Delete(mock.Anything, mock.Anything).
Return(merr.Status(nil), nil)
resp, err := s.client.Delete(context.Background(), &querypb.DeleteRequest{})
err = merr.CheckRPCCall(resp, err)
s.NoError(err)
}
// Race caused by mock parameter check on once
/*
func (s *QnWrapperSuite) TestQueryStream() {
s.qn.EXPECT().QueryStream(mock.Anything, mock.Anything).
Run(func(_ *querypb.QueryRequest, server querypb.QueryNode_QueryStreamServer) {
server.Send(&internalpb.RetrieveResults{})
}).
Return(nil)
streamer, err := s.client.QueryStream(context.Background(), &querypb.QueryRequest{})
s.NoError(err)
inMemStreamer, ok := streamer.(*streamrpc.InMemoryStreamer[*internalpb.RetrieveResults])
s.Require().True(ok)
r, err := streamer.Recv()
err = merr.CheckRPCCall(r, err)
s.NoError(err)
s.Eventually(func() bool {
return inMemStreamer.IsClosed()
}, time.Second, time.Millisecond*100)
}
func (s *QnWrapperSuite) TestQueryStreamSegments() {
s.qn.EXPECT().QueryStreamSegments(mock.Anything, mock.Anything).
Run(func(_ *querypb.QueryRequest, server querypb.QueryNode_QueryStreamSegmentsServer) {
server.Send(&internalpb.RetrieveResults{})
}).
Return(nil)
streamer, err := s.client.QueryStreamSegments(context.Background(), &querypb.QueryRequest{})
s.NoError(err)
inMemStreamer, ok := streamer.(*streamrpc.InMemoryStreamer[*internalpb.RetrieveResults])
s.Require().True(ok)
r, err := streamer.Recv()
err = merr.CheckRPCCall(r, err)
s.NoError(err)
s.Eventually(func() bool {
return inMemStreamer.IsClosed()
}, time.Second, time.Millisecond*100)
}*/
func TestQnServerWrapper(t *testing.T) {
suite.Run(t, new(QnWrapperSuite))
}