mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-12-02 20:09:57 +08:00
bcbe98aba1
Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
295 lines
9.6 KiB
Go
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))
|
|
}
|