mirror of https://github.com/milvus-io/milvus.git
197 lines
6.2 KiB
Go
197 lines
6.2 KiB
Go
package milvusclient
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"testing"
|
|
|
|
mock "github.com/stretchr/testify/mock"
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/milvuspb"
|
|
"github.com/milvus-io/milvus/pkg/util/merr"
|
|
)
|
|
|
|
type DatabaseSuite struct {
|
|
MockSuiteBase
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestListDatabases() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
s.mock.EXPECT().ListDatabases(mock.Anything, mock.Anything).Return(&milvuspb.ListDatabasesResponse{
|
|
Status: merr.Success(),
|
|
DbNames: []string{"default", "db1"},
|
|
}, nil).Once()
|
|
|
|
names, err := s.client.ListDatabase(ctx, NewListDatabaseOption())
|
|
s.NoError(err)
|
|
s.ElementsMatch([]string{"default", "db1"}, names)
|
|
})
|
|
|
|
s.Run("failure", func() {
|
|
s.mock.EXPECT().ListDatabases(mock.Anything, mock.Anything).Return(nil, merr.WrapErrServiceInternal("mocked")).Once()
|
|
|
|
_, err := s.client.ListDatabase(ctx, NewListDatabaseOption())
|
|
s.Error(err)
|
|
})
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestCreateDatabase() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().CreateDatabase(mock.Anything, mock.Anything).RunAndReturn(func(ctx context.Context, cdr *milvuspb.CreateDatabaseRequest) (*commonpb.Status, error) {
|
|
s.Equal(dbName, cdr.GetDbName())
|
|
return merr.Success(), nil
|
|
}).Once()
|
|
|
|
err := s.client.CreateDatabase(ctx, NewCreateDatabaseOption(dbName))
|
|
s.NoError(err)
|
|
})
|
|
|
|
s.Run("failure", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().CreateDatabase(mock.Anything, mock.Anything).Return(nil, merr.WrapErrServiceInternal("mocked")).Once()
|
|
|
|
err := s.client.CreateDatabase(ctx, NewCreateDatabaseOption(dbName))
|
|
s.Error(err)
|
|
})
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestDropDatabase() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().DropDatabase(mock.Anything, mock.Anything).RunAndReturn(func(ctx context.Context, ddr *milvuspb.DropDatabaseRequest) (*commonpb.Status, error) {
|
|
s.Equal(dbName, ddr.GetDbName())
|
|
return merr.Success(), nil
|
|
}).Once()
|
|
|
|
err := s.client.DropDatabase(ctx, NewDropDatabaseOption(dbName))
|
|
s.NoError(err)
|
|
})
|
|
|
|
s.Run("failure", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().DropDatabase(mock.Anything, mock.Anything).Return(nil, merr.WrapErrServiceInternal("mocked")).Once()
|
|
|
|
err := s.client.DropDatabase(ctx, NewDropDatabaseOption(dbName))
|
|
s.Error(err)
|
|
})
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestUseDatabase() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().Connect(mock.Anything, mock.Anything).RunAndReturn(func(ctx context.Context, cr *milvuspb.ConnectRequest) (*milvuspb.ConnectResponse, error) {
|
|
return &milvuspb.ConnectResponse{
|
|
Status: merr.Success(),
|
|
ServerInfo: &commonpb.ServerInfo{},
|
|
}, nil
|
|
}).Once()
|
|
|
|
err := s.client.UseDatabase(ctx, NewUseDatabaseOption(dbName))
|
|
s.NoError(err)
|
|
|
|
s.Equal(dbName, s.client.currentDB)
|
|
})
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestDescribeDatabase() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
key := fmt.Sprintf("key_%s", s.randString(4))
|
|
value := s.randString(6)
|
|
s.mock.EXPECT().DescribeDatabase(mock.Anything, mock.Anything).Return(&milvuspb.DescribeDatabaseResponse{
|
|
Status: merr.Success(),
|
|
DbName: dbName,
|
|
Properties: []*commonpb.KeyValuePair{
|
|
{Key: key, Value: value},
|
|
},
|
|
}, nil).Once()
|
|
|
|
db, err := s.client.DescribeDatabase(ctx, NewDescribeDatabaseOption(dbName))
|
|
s.NoError(err)
|
|
s.Equal(dbName, db.Name)
|
|
s.Equal(value, db.Properties[key])
|
|
})
|
|
|
|
s.Run("failure", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().DescribeDatabase(mock.Anything, mock.Anything).Return(nil, merr.WrapErrServiceInternal("mocked")).Once()
|
|
|
|
_, err := s.client.DescribeDatabase(ctx, NewDescribeDatabaseOption(dbName))
|
|
s.Error(err)
|
|
})
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestAlterDatabaseProperties() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
key := fmt.Sprintf("key_%s", s.randString(4))
|
|
value := s.randString(6)
|
|
s.mock.EXPECT().AlterDatabase(mock.Anything, mock.Anything).RunAndReturn(func(ctx context.Context, adr *milvuspb.AlterDatabaseRequest) (*commonpb.Status, error) {
|
|
s.Equal(dbName, adr.GetDbName())
|
|
s.Len(adr.GetProperties(), 1)
|
|
return merr.Success(), nil
|
|
}).Once()
|
|
|
|
err := s.client.AlterDatabaseProperties(ctx, NewAlterDatabasePropertiesOption(dbName).WithProperty(key, value))
|
|
s.NoError(err)
|
|
})
|
|
|
|
s.Run("failure", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().AlterDatabase(mock.Anything, mock.Anything).Return(nil, merr.WrapErrServiceInternal("mocked")).Once()
|
|
|
|
err := s.client.AlterDatabaseProperties(ctx, NewAlterDatabasePropertiesOption(dbName).WithProperty("key", "value"))
|
|
s.Error(err)
|
|
})
|
|
}
|
|
|
|
func (s *DatabaseSuite) TestDropDatabaseProperties() {
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
s.Run("success", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
key := fmt.Sprintf("key_%s", s.randString(4))
|
|
s.mock.EXPECT().AlterDatabase(mock.Anything, mock.Anything).RunAndReturn(func(ctx context.Context, adr *milvuspb.AlterDatabaseRequest) (*commonpb.Status, error) {
|
|
s.Equal([]string{key}, adr.GetDeleteKeys())
|
|
return merr.Success(), nil
|
|
}).Once()
|
|
|
|
err := s.client.DropDatabaseProperties(ctx, NewDropDatabasePropertiesOption(dbName, key))
|
|
s.NoError(err)
|
|
})
|
|
|
|
s.Run("failure", func() {
|
|
dbName := fmt.Sprintf("dt_%s", s.randString(6))
|
|
s.mock.EXPECT().AlterDatabase(mock.Anything, mock.Anything).Return(nil, merr.WrapErrServiceInternal("mocked")).Once()
|
|
|
|
err := s.client.DropDatabaseProperties(ctx, NewDropDatabasePropertiesOption(dbName, "key"))
|
|
s.Error(err)
|
|
})
|
|
}
|
|
|
|
func TestDatabase(t *testing.T) {
|
|
suite.Run(t, new(DatabaseSuite))
|
|
}
|