mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-12-02 20:09:57 +08:00
244d2c04f6
Related to #31293 Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
856 lines
22 KiB
Go
856 lines
22 KiB
Go
// Code generated by go generate; DO NOT EDIT
|
|
// This file is generated by go generated
|
|
|
|
package column
|
|
|
|
import (
|
|
"fmt"
|
|
"math/rand"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/schemapb"
|
|
"github.com/milvus-io/milvus/client/v2/entity"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestColumnBool(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Bool_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]bool, columnLen)
|
|
column := NewColumnBool(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeBool
|
|
assert.Equal(t, "Bool", ft.Name())
|
|
assert.Equal(t, "bool", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Bool", pbName)
|
|
assert.Equal(t, "bool", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeBool, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataBoolColumn(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Bool_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Bool,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_BoolData{
|
|
BoolData: &schemapb.BoolArray{
|
|
Data: make([]bool, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeBool, column.Type())
|
|
|
|
var ev bool
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_BoolData{
|
|
BoolData: &schemapb.BoolArray{
|
|
Data: make([]bool, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeBool, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnInt8(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Int8_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]int8, columnLen)
|
|
column := NewColumnInt8(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeInt8
|
|
assert.Equal(t, "Int8", ft.Name())
|
|
assert.Equal(t, "int8", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Int", pbName)
|
|
assert.Equal(t, "int32", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeInt8, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataInt8Column(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Int8_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Int8,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_IntData{
|
|
IntData: &schemapb.IntArray{
|
|
Data: make([]int32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt8, column.Type())
|
|
|
|
var ev int8
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_IntData{
|
|
IntData: &schemapb.IntArray{
|
|
Data: make([]int32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt8, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnInt16(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Int16_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]int16, columnLen)
|
|
column := NewColumnInt16(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeInt16
|
|
assert.Equal(t, "Int16", ft.Name())
|
|
assert.Equal(t, "int16", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Int", pbName)
|
|
assert.Equal(t, "int32", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeInt16, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataInt16Column(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Int16_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Int16,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_IntData{
|
|
IntData: &schemapb.IntArray{
|
|
Data: make([]int32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt16, column.Type())
|
|
|
|
var ev int16
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_IntData{
|
|
IntData: &schemapb.IntArray{
|
|
Data: make([]int32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt16, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnInt32(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Int32_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]int32, columnLen)
|
|
column := NewColumnInt32(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeInt32
|
|
assert.Equal(t, "Int32", ft.Name())
|
|
assert.Equal(t, "int32", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Int", pbName)
|
|
assert.Equal(t, "int32", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeInt32, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataInt32Column(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Int32_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Int32,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_IntData{
|
|
IntData: &schemapb.IntArray{
|
|
Data: make([]int32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt32, column.Type())
|
|
|
|
var ev int32
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_IntData{
|
|
IntData: &schemapb.IntArray{
|
|
Data: make([]int32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt32, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnInt64(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Int64_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]int64, columnLen)
|
|
column := NewColumnInt64(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeInt64
|
|
assert.Equal(t, "Int64", ft.Name())
|
|
assert.Equal(t, "int64", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Long", pbName)
|
|
assert.Equal(t, "int64", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeInt64, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataInt64Column(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Int64_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Int64,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_LongData{
|
|
LongData: &schemapb.LongArray{
|
|
Data: make([]int64, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt64, column.Type())
|
|
|
|
var ev int64
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_LongData{
|
|
LongData: &schemapb.LongArray{
|
|
Data: make([]int64, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeInt64, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnFloat(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Float_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]float32, columnLen)
|
|
column := NewColumnFloat(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeFloat
|
|
assert.Equal(t, "Float", ft.Name())
|
|
assert.Equal(t, "float32", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Float", pbName)
|
|
assert.Equal(t, "float32", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeFloat, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataFloatColumn(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Float_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Float,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_FloatData{
|
|
FloatData: &schemapb.FloatArray{
|
|
Data: make([]float32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeFloat, column.Type())
|
|
|
|
var ev float32
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_FloatData{
|
|
FloatData: &schemapb.FloatArray{
|
|
Data: make([]float32, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeFloat, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnDouble(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_Double_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]float64, columnLen)
|
|
column := NewColumnDouble(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeDouble
|
|
assert.Equal(t, "Double", ft.Name())
|
|
assert.Equal(t, "float64", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "Double", pbName)
|
|
assert.Equal(t, "float64", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeDouble, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataDoubleColumn(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_Double_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_Double,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_DoubleData{
|
|
DoubleData: &schemapb.DoubleArray{
|
|
Data: make([]float64, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeDouble, column.Type())
|
|
|
|
var ev float64
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_DoubleData{
|
|
DoubleData: &schemapb.DoubleArray{
|
|
Data: make([]float64, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeDouble, column.Type())
|
|
})
|
|
}
|
|
|
|
func TestColumnString(t *testing.T) {
|
|
rand.Seed(time.Now().UnixNano())
|
|
columnName := fmt.Sprintf("column_String_%d", rand.Int())
|
|
columnLen := 8 + rand.Intn(10)
|
|
|
|
v := make([]string, columnLen)
|
|
column := NewColumnString(columnName, v)
|
|
|
|
t.Run("test meta", func(t *testing.T) {
|
|
ft := entity.FieldTypeString
|
|
assert.Equal(t, "String", ft.Name())
|
|
assert.Equal(t, "string", ft.String())
|
|
pbName, pbType := ft.PbFieldType()
|
|
assert.Equal(t, "String", pbName)
|
|
assert.Equal(t, "string", pbType)
|
|
})
|
|
|
|
t.Run("test column attribute", func(t *testing.T) {
|
|
assert.Equal(t, columnName, column.Name())
|
|
assert.Equal(t, entity.FieldTypeString, column.Type())
|
|
assert.Equal(t, columnLen, column.Len())
|
|
assert.EqualValues(t, v, column.Data())
|
|
})
|
|
|
|
t.Run("test column field data", func(t *testing.T) {
|
|
fd := column.FieldData()
|
|
assert.NotNil(t, fd)
|
|
assert.Equal(t, fd.GetFieldName(), columnName)
|
|
})
|
|
|
|
t.Run("test column value by idx", func(t *testing.T) {
|
|
_, err := column.ValueByIdx(-1)
|
|
assert.NotNil(t, err)
|
|
_, err = column.ValueByIdx(columnLen)
|
|
assert.NotNil(t, err)
|
|
for i := 0; i < columnLen; i++ {
|
|
v, err := column.ValueByIdx(i)
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, column.values[i], v)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestFieldDataStringColumn(t *testing.T) {
|
|
len := rand.Intn(10) + 8
|
|
name := fmt.Sprintf("fd_String_%d", rand.Int())
|
|
fd := &schemapb.FieldData{
|
|
Type: schemapb.DataType_String,
|
|
FieldName: name,
|
|
}
|
|
|
|
t.Run("normal usage", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_StringData{
|
|
StringData: &schemapb.StringArray{
|
|
Data: make([]string, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, len)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeString, column.Type())
|
|
|
|
var ev string
|
|
err = column.AppendValue(ev)
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.Nil(t, err)
|
|
|
|
err = column.AppendValue(struct{}{})
|
|
assert.Equal(t, len+1, column.Len())
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("nil data", func(t *testing.T) {
|
|
fd.Field = nil
|
|
_, err := FieldDataColumn(fd, 0, len)
|
|
assert.NotNil(t, err)
|
|
})
|
|
|
|
t.Run("get all data", func(t *testing.T) {
|
|
fd.Field = &schemapb.FieldData_Scalars{
|
|
Scalars: &schemapb.ScalarField{
|
|
Data: &schemapb.ScalarField_StringData{
|
|
StringData: &schemapb.StringArray{
|
|
Data: make([]string, len),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
column, err := FieldDataColumn(fd, 0, -1)
|
|
assert.Nil(t, err)
|
|
assert.NotNil(t, column)
|
|
|
|
assert.Equal(t, name, column.Name())
|
|
assert.Equal(t, len, column.Len())
|
|
assert.Equal(t, entity.FieldTypeString, column.Type())
|
|
})
|
|
}
|