mirror of https://github.com/milvus-io/milvus.git
fix: [ut] regex query under unsupported index (#34087)
/kind improvement issue: https://github.com/milvus-io/milvus/issues/29988 Signed-off-by: longjiquan <jiquan.long@zilliz.com>pull/34092/head
parent
d08cb885ca
commit
aa36f9feed
|
@ -479,28 +479,33 @@ TEST_F(SealedSegmentRegexQueryTest, RegexQueryOnInvertedIndexStringField) {
|
||||||
ASSERT_TRUE(final[4]);
|
ASSERT_TRUE(final[4]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: optimize this case
|
TEST_F(SealedSegmentRegexQueryTest, RegexQueryOnUnsupportedIndex) {
|
||||||
// TEST_F(SealedSegmentRegexQueryTest, RegexQueryOnUnsupportedIndex) {
|
std::string operand = "a%";
|
||||||
// std::string operand = "a%";
|
const auto& str_meta = schema->operator[](FieldName("str"));
|
||||||
// const auto& str_meta = schema->operator[](FieldName("str"));
|
auto column_info = test::GenColumnInfo(str_meta.get_id().get(),
|
||||||
// auto column_info = test::GenColumnInfo(str_meta.get_id().get(),
|
proto::schema::DataType::VarChar,
|
||||||
// proto::schema::DataType::VarChar,
|
false,
|
||||||
// false,
|
false);
|
||||||
// false);
|
auto unary_range_expr = test::GenUnaryRangeExpr(OpType::Match, operand);
|
||||||
// auto unary_range_expr = test::GenUnaryRangeExpr(OpType::Match, operand);
|
unary_range_expr->set_allocated_column_info(column_info);
|
||||||
// unary_range_expr->set_allocated_column_info(column_info);
|
auto expr = test::GenExpr();
|
||||||
// auto expr = test::GenExpr();
|
expr->set_allocated_unary_range_expr(unary_range_expr);
|
||||||
// expr->set_allocated_unary_range_expr(unary_range_expr);
|
|
||||||
|
|
||||||
// auto parser = ProtoParser(*schema);
|
auto parser = ProtoParser(*schema);
|
||||||
// auto typed_expr = parser.ParseExprs(*expr);
|
auto typed_expr = parser.ParseExprs(*expr);
|
||||||
// auto parsed =
|
auto parsed =
|
||||||
// std::make_shared<plan::FilterBitsNode>(DEFAULT_PLANNODE_ID, typed_expr);
|
std::make_shared<plan::FilterBitsNode>(DEFAULT_PLANNODE_ID, typed_expr);
|
||||||
|
|
||||||
// LoadMockIndex();
|
LoadMockIndex();
|
||||||
|
|
||||||
// auto segpromote = dynamic_cast<SegmentSealedImpl*>(seg.get());
|
auto segpromote = dynamic_cast<SegmentSealedImpl*>(seg.get());
|
||||||
// query::ExecPlanNodeVisitor visitor(*segpromote, MAX_TIMESTAMP);
|
query::ExecPlanNodeVisitor visitor(*segpromote, MAX_TIMESTAMP);
|
||||||
// BitsetType final;
|
BitsetType final;
|
||||||
// ASSERT_ANY_THROW(visitor.ExecuteExprNode(parsed, segpromote, N, final));
|
// regex query under this index will be executed using raw data (brute force).
|
||||||
// }
|
visitor.ExecuteExprNode(parsed, segpromote, N, final);
|
||||||
|
ASSERT_FALSE(final[0]);
|
||||||
|
ASSERT_TRUE(final[1]);
|
||||||
|
ASSERT_TRUE(final[2]);
|
||||||
|
ASSERT_TRUE(final[3]);
|
||||||
|
ASSERT_TRUE(final[4]);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue