milvus/internal/util/funcutil/count_util_test.go
Jiquan Long 8139106b51
Feat: count entities by expression (#22765)
Signed-off-by: longjiquan <jiquan.long@zilliz.com>
2023-03-16 19:31:55 +08:00

96 lines
2.1 KiB
Go

package funcutil
import (
"testing"
"github.com/milvus-io/milvus/internal/proto/segcorepb"
"github.com/milvus-io/milvus-proto/go-api/schemapb"
"github.com/milvus-io/milvus/internal/proto/internalpb"
"github.com/stretchr/testify/assert"
)
func TestCntOfInternalResult(t *testing.T) {
t.Run("invalid", func(t *testing.T) {
res := &internalpb.RetrieveResults{
FieldsData: []*schemapb.FieldData{nil, nil},
}
_, err := CntOfInternalResult(res)
assert.Error(t, err)
})
t.Run("normal case", func(t *testing.T) {
res := WrapCntToInternalResult(5)
cnt, err := CntOfInternalResult(res)
assert.NoError(t, err)
assert.Equal(t, int64(5), cnt)
})
}
func TestCntOfSegCoreResult(t *testing.T) {
t.Run("invalid", func(t *testing.T) {
res := &segcorepb.RetrieveResults{
FieldsData: []*schemapb.FieldData{nil, nil},
}
_, err := CntOfSegCoreResult(res)
assert.Error(t, err)
})
t.Run("normal case", func(t *testing.T) {
res := WrapCntToSegCoreResult(5)
cnt, err := CntOfSegCoreResult(res)
assert.NoError(t, err)
assert.Equal(t, int64(5), cnt)
})
}
func TestCntOfFieldData(t *testing.T) {
t.Run("not scalars", func(t *testing.T) {
f := &schemapb.FieldData{
Field: &schemapb.FieldData_Vectors{},
}
_, err := CntOfFieldData(f)
assert.Error(t, err)
})
t.Run("not long data", func(t *testing.T) {
f := &schemapb.FieldData{
Field: &schemapb.FieldData_Scalars{
Scalars: &schemapb.ScalarField{
Data: &schemapb.ScalarField_DoubleData{},
},
},
}
_, err := CntOfFieldData(f)
assert.Error(t, err)
})
t.Run("more than one row", func(t *testing.T) {
f := &schemapb.FieldData{
Field: &schemapb.FieldData_Scalars{
Scalars: &schemapb.ScalarField{
Data: &schemapb.ScalarField_LongData{
LongData: &schemapb.LongArray{
Data: []int64{1, 2, 3},
},
},
},
},
}
_, err := CntOfFieldData(f)
assert.Error(t, err)
})
t.Run("more than one row", func(t *testing.T) {
f := WrapCntToFieldData(1000)
cnt, err := CntOfFieldData(f)
assert.NoError(t, err)
assert.Equal(t, int64(1000), cnt)
})
}