mirror of https://github.com/milvus-io/milvus.git
168 lines
3.9 KiB
Go
168 lines
3.9 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 proxy
|
|
|
|
import (
|
|
"errors"
|
|
"testing"
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/schemapb"
|
|
"github.com/milvus-io/milvus/internal/log"
|
|
"github.com/milvus-io/milvus/internal/proto/internalpb"
|
|
"github.com/stretchr/testify/assert"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
func Test_errInvalidNumRows(t *testing.T) {
|
|
invalidNumRowsList := []uint32{
|
|
0,
|
|
16384,
|
|
}
|
|
|
|
for _, invalidNumRows := range invalidNumRowsList {
|
|
log.Info("Test_errInvalidNumRows",
|
|
zap.Error(errInvalidNumRows(invalidNumRows)))
|
|
}
|
|
}
|
|
|
|
func Test_errNumRowsLessThanOrEqualToZero(t *testing.T) {
|
|
invalidNumRowsList := []uint32{
|
|
0,
|
|
16384,
|
|
}
|
|
|
|
for _, invalidNumRows := range invalidNumRowsList {
|
|
log.Info("Test_errNumRowsLessThanOrEqualToZero",
|
|
zap.Error(errNumRowsLessThanOrEqualToZero(invalidNumRows)))
|
|
}
|
|
}
|
|
|
|
func Test_errEmptyFieldData(t *testing.T) {
|
|
log.Info("Test_errEmptyFieldData",
|
|
zap.Error(errEmptyFieldData))
|
|
}
|
|
|
|
func Test_errFieldsLessThanNeeded(t *testing.T) {
|
|
cases := []struct {
|
|
fieldsNum int
|
|
neededNum int
|
|
}{
|
|
{0, 1},
|
|
{1, 2},
|
|
}
|
|
|
|
for _, test := range cases {
|
|
log.Info("Test_errFieldsLessThanNeeded",
|
|
zap.Error(errFieldsLessThanNeeded(test.fieldsNum, test.neededNum)))
|
|
}
|
|
}
|
|
|
|
func Test_errUnsupportedDataType(t *testing.T) {
|
|
unsupportedDTypes := []schemapb.DataType{
|
|
schemapb.DataType_None,
|
|
}
|
|
|
|
for _, dType := range unsupportedDTypes {
|
|
log.Info("Test_errUnsupportedDataType",
|
|
zap.Error(errUnsupportedDataType(dType)))
|
|
}
|
|
}
|
|
|
|
func Test_errUnsupportedDType(t *testing.T) {
|
|
unsupportedDTypes := []string{
|
|
"bytes",
|
|
"None",
|
|
}
|
|
|
|
for _, dType := range unsupportedDTypes {
|
|
log.Info("Test_errUnsupportedDType",
|
|
zap.Error(errUnsupportedDType(dType)))
|
|
}
|
|
}
|
|
|
|
func Test_errInvalidDim(t *testing.T) {
|
|
invalidDimList := []int{
|
|
0,
|
|
-1,
|
|
}
|
|
|
|
for _, invalidDim := range invalidDimList {
|
|
log.Info("Test_errInvalidDim",
|
|
zap.Error(errInvalidDim(invalidDim)))
|
|
}
|
|
}
|
|
|
|
func Test_errDimLessThanOrEqualToZero(t *testing.T) {
|
|
invalidDimList := []int{
|
|
0,
|
|
-1,
|
|
}
|
|
|
|
for _, invalidDim := range invalidDimList {
|
|
log.Info("Test_errDimLessThanOrEqualToZero",
|
|
zap.Error(errDimLessThanOrEqualToZero(invalidDim)))
|
|
}
|
|
}
|
|
|
|
func Test_errDimShouldDivide8(t *testing.T) {
|
|
invalidDimList := []int{
|
|
0,
|
|
1,
|
|
7,
|
|
}
|
|
|
|
for _, invalidDim := range invalidDimList {
|
|
log.Info("Test_errDimShouldDivide8",
|
|
zap.Error(errDimShouldDivide8(invalidDim)))
|
|
}
|
|
}
|
|
|
|
func Test_msgProxyIsUnhealthy(t *testing.T) {
|
|
ids := []UniqueID{
|
|
1,
|
|
}
|
|
|
|
for _, id := range ids {
|
|
log.Info("Test_msgProxyIsUnhealthy",
|
|
zap.String("msg", msgProxyIsUnhealthy(id)))
|
|
}
|
|
}
|
|
|
|
func Test_errProxyIsUnhealthy(t *testing.T) {
|
|
ids := []UniqueID{
|
|
1,
|
|
}
|
|
|
|
for _, id := range ids {
|
|
log.Info("Test_errProxyIsUnhealthy",
|
|
zap.Error(errProxyIsUnhealthy(id)))
|
|
}
|
|
}
|
|
|
|
func Test_ErrRateLimitAndErrForceDeny(t *testing.T) {
|
|
err := wrapRateLimitError()
|
|
assert.True(t, errors.Is(err, ErrRateLimit))
|
|
|
|
limiter := NewMultiRateLimiter()
|
|
err = wrapForceDenyError(internalpb.RateType_DMLInsert, limiter)
|
|
assert.True(t, errors.Is(err, ErrForceDeny))
|
|
err = wrapForceDenyError(internalpb.RateType_DMLDelete, limiter)
|
|
assert.True(t, errors.Is(err, ErrForceDeny))
|
|
err = wrapForceDenyError(internalpb.RateType_DQLSearch, limiter)
|
|
assert.True(t, errors.Is(err, ErrForceDeny))
|
|
}
|