coordinator_broker_test.go 2.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
// 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 meta

import (
	"context"
	"testing"

23
	"github.com/cockroachdb/errors"
24 25 26
	"github.com/stretchr/testify/assert"
	"github.com/stretchr/testify/mock"

27 28 29
	"github.com/milvus-io/milvus-proto/go-api/commonpb"
	"github.com/milvus-io/milvus-proto/go-api/milvuspb"
	"github.com/milvus-io/milvus-proto/go-api/schemapb"
30 31 32 33
	"github.com/milvus-io/milvus/internal/mocks"
)

func TestCoordinatorBroker_GetCollectionSchema(t *testing.T) {
34
	t.Run("got error on DescribeCollectionInternal", func(t *testing.T) {
35
		rootCoord := mocks.NewRootCoord(t)
36
		rootCoord.On("DescribeCollectionInternal",
37 38
			mock.Anything,
			mock.Anything,
39
		).Return(nil, errors.New("error mock DescribeCollectionInternal"))
40 41 42 43 44 45 46 47
		ctx := context.Background()
		broker := &CoordinatorBroker{rootCoord: rootCoord}
		_, err := broker.GetCollectionSchema(ctx, 100)
		assert.Error(t, err)
	})

	t.Run("non-success code", func(t *testing.T) {
		rootCoord := mocks.NewRootCoord(t)
48
		rootCoord.On("DescribeCollectionInternal",
49 50 51 52 53 54 55 56 57 58 59 60 61
			mock.Anything,
			mock.Anything,
		).Return(&milvuspb.DescribeCollectionResponse{
			Status: &commonpb.Status{ErrorCode: commonpb.ErrorCode_CollectionNotExists},
		}, nil)
		ctx := context.Background()
		broker := &CoordinatorBroker{rootCoord: rootCoord}
		_, err := broker.GetCollectionSchema(ctx, 100)
		assert.Error(t, err)
	})

	t.Run("normal case", func(t *testing.T) {
		rootCoord := mocks.NewRootCoord(t)
62
		rootCoord.On("DescribeCollectionInternal",
63 64 65 66 67 68 69 70 71 72 73 74 75
			mock.Anything,
			mock.Anything,
		).Return(&milvuspb.DescribeCollectionResponse{
			Status: &commonpb.Status{ErrorCode: commonpb.ErrorCode_Success},
			Schema: &schemapb.CollectionSchema{Name: "test_schema"},
		}, nil)
		ctx := context.Background()
		broker := &CoordinatorBroker{rootCoord: rootCoord}
		schema, err := broker.GetCollectionSchema(ctx, 100)
		assert.NoError(t, err)
		assert.Equal(t, "test_schema", schema.GetName())
	})
}