2022-04-01 10:59:29 +00:00
|
|
|
package proxy
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/golang/protobuf/proto"
|
|
|
|
"github.com/stretchr/testify/assert"
|
2022-04-20 08:15:41 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-04-01 10:59:29 +00:00
|
|
|
|
|
|
|
"github.com/milvus-io/milvus/internal/common"
|
2022-04-20 08:15:41 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/types"
|
2022-04-01 10:59:29 +00:00
|
|
|
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/commonpb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/internalpb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/milvuspb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/querypb"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/schemapb"
|
|
|
|
|
|
|
|
"github.com/milvus-io/milvus/internal/util/funcutil"
|
|
|
|
"github.com/milvus-io/milvus/internal/util/typeutil"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestQueryTask_all(t *testing.T) {
|
|
|
|
Params.Init()
|
|
|
|
|
2022-04-20 08:15:41 +00:00
|
|
|
var (
|
|
|
|
err error
|
|
|
|
ctx = context.TODO()
|
|
|
|
|
|
|
|
rc = NewRootCoordMock()
|
|
|
|
qc = NewQueryCoordMock(withValidShardLeaders())
|
|
|
|
qn = &QueryNodeMock{}
|
|
|
|
|
|
|
|
shardsNum = int32(2)
|
|
|
|
collectionName = t.Name() + funcutil.GenRandomStr()
|
|
|
|
|
|
|
|
expr = fmt.Sprintf("%s > 0", testInt64Field)
|
|
|
|
hitNum = 10
|
|
|
|
)
|
|
|
|
|
|
|
|
mockGetQueryNodePolicy := func(ctx context.Context, address string) (types.QueryNode, error) {
|
|
|
|
return qn, nil
|
|
|
|
}
|
|
|
|
|
2022-04-01 10:59:29 +00:00
|
|
|
rc.Start()
|
|
|
|
defer rc.Stop()
|
2022-04-20 08:15:41 +00:00
|
|
|
qc.Start()
|
|
|
|
defer qc.Stop()
|
2022-04-01 10:59:29 +00:00
|
|
|
|
|
|
|
err = InitMetaCache(rc)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
fieldName2Types := map[string]schemapb.DataType{
|
|
|
|
testBoolField: schemapb.DataType_Bool,
|
|
|
|
testInt32Field: schemapb.DataType_Int32,
|
|
|
|
testInt64Field: schemapb.DataType_Int64,
|
|
|
|
testFloatField: schemapb.DataType_Float,
|
|
|
|
testDoubleField: schemapb.DataType_Double,
|
|
|
|
testFloatVecField: schemapb.DataType_FloatVector,
|
|
|
|
}
|
|
|
|
if enableMultipleVectorFields {
|
|
|
|
fieldName2Types[testBinaryVecField] = schemapb.DataType_BinaryVector
|
|
|
|
}
|
|
|
|
|
|
|
|
schema := constructCollectionSchemaByDataType(collectionName, fieldName2Types, testInt64Field, false)
|
|
|
|
marshaledSchema, err := proto.Marshal(schema)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
createColT := &createCollectionTask{
|
|
|
|
Condition: NewTaskCondition(ctx),
|
|
|
|
CreateCollectionRequest: &milvuspb.CreateCollectionRequest{
|
|
|
|
CollectionName: collectionName,
|
|
|
|
Schema: marshaledSchema,
|
|
|
|
ShardsNum: shardsNum,
|
|
|
|
},
|
|
|
|
ctx: ctx,
|
|
|
|
rootCoord: rc,
|
|
|
|
}
|
|
|
|
|
2022-04-20 08:15:41 +00:00
|
|
|
require.NoError(t, createColT.OnEnqueue())
|
|
|
|
require.NoError(t, createColT.PreExecute(ctx))
|
|
|
|
require.NoError(t, createColT.Execute(ctx))
|
|
|
|
require.NoError(t, createColT.PostExecute(ctx))
|
2022-04-01 10:59:29 +00:00
|
|
|
|
|
|
|
collectionID, err := globalMetaCache.GetCollectionID(ctx, collectionName)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
status, err := qc.LoadCollection(ctx, &querypb.LoadCollectionRequest{
|
|
|
|
Base: &commonpb.MsgBase{
|
2022-04-20 08:15:41 +00:00
|
|
|
MsgType: commonpb.MsgType_LoadCollection,
|
2022-04-24 14:03:44 +00:00
|
|
|
SourceID: Params.ProxyCfg.GetNodeID(),
|
2022-04-01 10:59:29 +00:00
|
|
|
},
|
|
|
|
CollectionID: collectionID,
|
|
|
|
})
|
2022-04-20 08:15:41 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, commonpb.ErrorCode_Success, status.ErrorCode)
|
2022-04-01 10:59:29 +00:00
|
|
|
|
2022-04-20 08:15:41 +00:00
|
|
|
// test begins
|
2022-04-01 10:59:29 +00:00
|
|
|
task := &queryTask{
|
|
|
|
Condition: NewTaskCondition(ctx),
|
|
|
|
RetrieveRequest: &internalpb.RetrieveRequest{
|
|
|
|
Base: &commonpb.MsgBase{
|
2022-04-20 08:15:41 +00:00
|
|
|
MsgType: commonpb.MsgType_Retrieve,
|
2022-04-24 14:03:44 +00:00
|
|
|
SourceID: Params.ProxyCfg.GetNodeID(),
|
2022-04-01 10:59:29 +00:00
|
|
|
},
|
2022-04-20 08:15:41 +00:00
|
|
|
CollectionID: collectionID,
|
|
|
|
OutputFieldsId: make([]int64, len(fieldName2Types)),
|
2022-04-01 10:59:29 +00:00
|
|
|
},
|
2022-04-20 08:15:41 +00:00
|
|
|
ctx: ctx,
|
2022-04-01 10:59:29 +00:00
|
|
|
result: &milvuspb.QueryResults{
|
|
|
|
Status: &commonpb.Status{
|
|
|
|
ErrorCode: commonpb.ErrorCode_Success,
|
|
|
|
},
|
|
|
|
},
|
2022-04-20 08:15:41 +00:00
|
|
|
request: &milvuspb.QueryRequest{
|
2022-04-01 10:59:29 +00:00
|
|
|
Base: &commonpb.MsgBase{
|
2022-04-20 08:15:41 +00:00
|
|
|
MsgType: commonpb.MsgType_Retrieve,
|
2022-04-24 14:03:44 +00:00
|
|
|
SourceID: Params.ProxyCfg.GetNodeID(),
|
2022-04-01 10:59:29 +00:00
|
|
|
},
|
2022-04-20 08:15:41 +00:00
|
|
|
CollectionName: collectionName,
|
|
|
|
Expr: expr,
|
2022-04-01 10:59:29 +00:00
|
|
|
},
|
2022-04-20 08:15:41 +00:00
|
|
|
qc: qc,
|
|
|
|
|
|
|
|
getQueryNodePolicy: mockGetQueryNodePolicy,
|
|
|
|
queryShardPolicy: roundRobinPolicy,
|
2022-04-01 10:59:29 +00:00
|
|
|
}
|
|
|
|
for i := 0; i < len(fieldName2Types); i++ {
|
|
|
|
task.RetrieveRequest.OutputFieldsId[i] = int64(common.StartOfUserFieldID + i)
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.NoError(t, task.OnEnqueue())
|
|
|
|
|
|
|
|
// test query task with timeout
|
|
|
|
ctx1, cancel1 := context.WithTimeout(ctx, 10*time.Second)
|
|
|
|
defer cancel1()
|
|
|
|
// before preExecute
|
|
|
|
assert.Equal(t, typeutil.ZeroTimestamp, task.TimeoutTimestamp)
|
|
|
|
task.ctx = ctx1
|
|
|
|
assert.NoError(t, task.PreExecute(ctx))
|
|
|
|
// after preExecute
|
|
|
|
assert.Greater(t, task.TimeoutTimestamp, typeutil.ZeroTimestamp)
|
|
|
|
|
2022-04-20 08:15:41 +00:00
|
|
|
result1 := &internalpb.RetrieveResults{
|
|
|
|
Base: &commonpb.MsgBase{MsgType: commonpb.MsgType_RetrieveResult},
|
|
|
|
Status: &commonpb.Status{
|
|
|
|
ErrorCode: commonpb.ErrorCode_Success,
|
|
|
|
},
|
|
|
|
Ids: &schemapb.IDs{
|
|
|
|
IdField: &schemapb.IDs_IntId{
|
|
|
|
IntId: &schemapb.LongArray{Data: generateInt64Array(hitNum)},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for fieldName, dataType := range fieldName2Types {
|
2022-04-29 05:35:49 +00:00
|
|
|
result1.FieldsData = append(result1.FieldsData, generateFieldData(dataType, fieldName, hitNum))
|
2022-04-20 08:15:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
qn.withQueryResult = result1
|
|
|
|
|
|
|
|
task.ctx = ctx
|
2022-04-01 10:59:29 +00:00
|
|
|
assert.NoError(t, task.Execute(ctx))
|
|
|
|
|
2022-04-20 08:15:41 +00:00
|
|
|
assert.NoError(t, task.PostExecute(ctx))
|
2022-04-01 10:59:29 +00:00
|
|
|
}
|