From a4b64179b3d123d609834ebdce0b723048d575e9 Mon Sep 17 00:00:00 2001 From: amory Date: Thu, 28 Nov 2024 10:25:41 +0800 Subject: [PATCH] [fix](ip-search)fix ip search with inverted index (#44580) this pr is to solve is_ip_address_in_range with invalid param --- be/src/vec/functions/function_ip.h | 5 +++++ .../test_ip_cidr_search_with_inverted_index.out | 4 ---- .../test_ip_cidr_search_with_inverted_index.groovy | 9 +++++++-- 3 files changed, 12 insertions(+), 6 deletions(-) diff --git a/be/src/vec/functions/function_ip.h b/be/src/vec/functions/function_ip.h index 25f09bb594a943..b60e1f393f80b7 100644 --- a/be/src/vec/functions/function_ip.h +++ b/be/src/vec/functions/function_ip.h @@ -694,6 +694,11 @@ class FunctionIsIPAddressInRange : public IFunction { reinterpret_cast(&cidr_range_ipv6_data[1]), cidr._prefix); min_ip = cidr_range_ipv6_data[0]; max_ip = cidr_range_ipv6_data[1]; + } else { + // if here param is invalid for current column to calcute min_ip|max_ip we just return + return Status::Error( + "Inverted index evaluate skipped, data type " + arg_type->get_name() + + " can not support this cidr " + arg_column->get_data_at(0).to_string()); } // apply for inverted index std::shared_ptr res_roaring = std::make_shared(); diff --git a/regression-test/data/inverted_index_p0/test_ip_cidr_search_with_inverted_index.out b/regression-test/data/inverted_index_p0/test_ip_cidr_search_with_inverted_index.out index f365449b9e5244..2211a11b95a697 100644 --- a/regression-test/data/inverted_index_p0/test_ip_cidr_search_with_inverted_index.out +++ b/regression-test/data/inverted_index_p0/test_ip_cidr_search_with_inverted_index.out @@ -50,13 +50,9 @@ -- !sql -- --- !sql -- - -- !sql -- 2 42.117.228.166 2001:16a0:2:200a::2 --- !sql -- - -- !sql -- 5 255.255.255.255 \N diff --git a/regression-test/suites/inverted_index_p0/test_ip_cidr_search_with_inverted_index.groovy b/regression-test/suites/inverted_index_p0/test_ip_cidr_search_with_inverted_index.groovy index 61751f2404f2d2..191c818f351fde 100644 --- a/regression-test/suites/inverted_index_p0/test_ip_cidr_search_with_inverted_index.groovy +++ b/regression-test/suites/inverted_index_p0/test_ip_cidr_search_with_inverted_index.groovy @@ -118,8 +118,13 @@ suite("test_ip_cidr_search_with_inverted_index", "nonConcurrent"){ def execute_sql = { sqlList -> def i = 0 for (sqlStr in sqlList) { + if (i == 0 || i == 4 ) { + // inverted index will skip and do eval expr + ++i; + continue; + } try { - log.info("execute sql: i") + log.info("execute sql: ${i} : ${sqlStr}") GetDebugPoint().enableDebugPointForAllBEs(checkpoints_name, [req_id: i]) order_qt_sql """ ${sqlStr} """ } finally { @@ -131,4 +136,4 @@ suite("test_ip_cidr_search_with_inverted_index", "nonConcurrent"){ execute_sql.call(create_sql.call()) -} \ No newline at end of file +}