Skip to content

Commit

Permalink
branch-3.0: [fix](inverted index) Fix Null Pointer Exception in funct…
Browse files Browse the repository at this point in the history
…ion match #45456 (#45499)

Cherry-picked from #45456

Co-authored-by: zzzxl <[email protected]>
  • Loading branch information
github-actions[bot] and zzzxl1993 authored Dec 20, 2024
1 parent e3073ed commit d047f23
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 0 deletions.
3 changes: 3 additions & 0 deletions be/src/vec/functions/match.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -172,6 +172,9 @@ std::vector<std::string> FunctionMatchBase::analyse_query_str_token(
VLOG_DEBUG << "begin to run " << get_name() << ", parser_type: "
<< inverted_index_parser_type_to_string(inverted_index_ctx->parser_type);
std::vector<std::string> query_tokens;
if (inverted_index_ctx == nullptr) {
return query_tokens;
}
if (inverted_index_ctx->parser_type == InvertedIndexParserType::PARSER_NONE) {
query_tokens.emplace_back(match_query_str);
return query_tokens;
Expand Down
58 changes: 58 additions & 0 deletions be/test/vec/function/function_match_test.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

#include <gtest/gtest.h>

#include <memory>

#include "function_test_util.h"
#include "olap/rowset/segment_v2/inverted_index/analyzer/analyzer.h"
#include "vec/functions/match.h"

namespace doris::vectorized {

TEST(FunctionMatchTest, analyse_query_str) {
FunctionMatchPhrase func_match_phrase;

{
auto inverted_index_ctx = nullptr;
std::vector<std::string> query_tokens =
func_match_phrase.analyse_query_str_token(inverted_index_ctx, "a b c", "name");
ASSERT_EQ(query_tokens.size(), 0);
}

{
auto inverted_index_ctx = std::make_unique<InvertedIndexCtx>();
inverted_index_ctx->parser_type = InvertedIndexParserType::PARSER_NONE;
std::vector<std::string> query_tokens = func_match_phrase.analyse_query_str_token(
inverted_index_ctx.get(), "a b c", "name");
ASSERT_EQ(query_tokens.size(), 1);
}

{
auto inverted_index_ctx = std::make_unique<InvertedIndexCtx>();
inverted_index_ctx->parser_type = InvertedIndexParserType::PARSER_ENGLISH;
auto analyzer = doris::segment_v2::inverted_index::InvertedIndexAnalyzer::create_analyzer(
inverted_index_ctx.get());
inverted_index_ctx->analyzer = analyzer.get();
std::vector<std::string> query_tokens = func_match_phrase.analyse_query_str_token(
inverted_index_ctx.get(), "a b c", "name");
ASSERT_EQ(query_tokens.size(), 3);
}
}

} // namespace doris::vectorized

0 comments on commit d047f23

Please sign in to comment.