Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support match_phrase filter function in SQL and PPL #604

Merged
merged 58 commits into from
May 25, 2022
Merged
Changes from 1 commit
Commits
Show all changes
58 commits
Select commit Hold shift + click to select a range
e7c45f5
Support match_phrase in AST expressions
Apr 22, 2022
a39f423
Support match_phrase in PPL syntax
Apr 26, 2022
8d0cd91
Added MATCH_QUERY to the list of supported functions in SQL parser.
Yury-Fridlyand Apr 26, 2022
7d451e5
Support slop parameter for relevancy functions
Apr 26, 2022
7001b87
Typo fix for previous commit. Expanded list of MATCH_* function argum…
Yury-Fridlyand Apr 26, 2022
f0ff81c
Integration tests for match_test in PPL
Apr 26, 2022
b883254
Support slop option
Apr 26, 2022
e1c071a
Tests to verify that PPL parser supports match_phrase
Apr 26, 2022
9d4f378
Refactor and style fixes
Apr 26, 2022
3c8bd62
Refactor and fix style in OpenSearchFunctions.java
Apr 26, 2022
4a0fe8b
Style fixes for OpenSearchFunctionsTest.java
Apr 26, 2022
659c4d7
Add tests for `MATCH` and `MATCH_PHRASE` functions.
Yury-Fridlyand Apr 26, 2022
017fbb7
Typo fix.
Yury-Fridlyand Apr 26, 2022
e93aa2b
Fix style and minor refactor in PPLSyntaxParserTest.java
Apr 26, 2022
f67b1ac
Minor test improvements
Yury-Fridlyand Apr 26, 2022
0e48992
Parameterized test for match_phrase parsing
Apr 28, 2022
cc2100b
Add `MATCH_PHRASE` function to the function repository.
Yury-Fridlyand Apr 27, 2022
23f8fe6
Finally added `MATCH_PHASE` query support to `FilterQueryBuilder`.
Yury-Fridlyand Apr 28, 2022
775cb20
Typo fix + EOL fix
Yury-Fridlyand Apr 28, 2022
2aaf047
Typo fix
Yury-Fridlyand Apr 29, 2022
2316173
Adding tests for `FilterQueryBuilder` for `MATCH_PHRASE`. Some tests …
Yury-Fridlyand Apr 29, 2022
e22879a
Address PR feedback.
Yury-Fridlyand May 2, 2022
a46d6ac
Add documentation for `MATCH_PHRASE` function.
Yury-Fridlyand May 2, 2022
30ef3ba
Remove duplicate definition of match_phrase in DSL.java
May 3, 2022
39ac1dd
Generate supported signatures for match and match_phrases
May 3, 2022
0ec0aec
Simplify match_phrase test.
May 3, 2022
a987aa3
Some sample queries with match_phrase for parser test
May 3, 2022
14cb1a5
Update PPL documentation.
May 3, 2022
b4f5ba9
Update query samples in docs. Add a new table to doctest to match the…
Yury-Fridlyand May 4, 2022
e4d155b
Recover `FUZZY_REWRITE` - was deleted by mistake.
Yury-Fridlyand May 4, 2022
c303381
Add missing file for `63009a05`.
Yury-Fridlyand May 4, 2022
5020d7f
Use constant seed to produce repeatable samples
May 4, 2022
82c6ab8
Enable integration tests for match_phrase in PPL
May 4, 2022
a0d56a8
Fix code style.
Yury-Fridlyand May 4, 2022
becdeac
Make generateAndTestQueries() product consistent results.
May 4, 2022
b30db7e
use generateQueries to generate samples for match_phrase
May 4, 2022
0e8d6da
Fix finction signature list. Typo fix for `5bf470c7`.
Yury-Fridlyand May 4, 2022
4b92454
Fix code styling.
Yury-Fridlyand May 4, 2022
5334c65
Minor style changes.
May 6, 2022
05c6acb
Add newline at the end of file.
May 6, 2022
80e3da0
Simplify MatchPhraseQuery and add unit tests.
May 9, 2022
8198323
Remove unused imports.
May 9, 2022
5c6e07f
Change data used by WhereCommandIT
May 9, 2022
0f7ea73
Style update for OpenSearchFunctions
May 9, 2022
026ac4c
100% test coverage for MatchPhraseQuery
May 9, 2022
e68ba62
Fix imports in WhereCommandIT
May 10, 2022
bcc0a82
Move final variables to class constants in OpenSearchFunctions
May 10, 2022
0127ee6
Fix checkstyle failure.
May 10, 2022
d6ea633
Support legacy syntax for match_phrase in the new SQL engine.
May 16, 2022
fedbbed
Merge pull request #59 from Bit-Quill/integ-match_phrase-#185-legacy-…
MaxKsyunz May 16, 2022
1fae665
Added missed license headers.
May 20, 2022
d3667ce
Add RelevanceQuery -- a base class for MatchQuery and MatchPhraseQuery.
May 20, 2022
7101d07
Use SyntaxCheckException from RelevanceQuery.build
May 20, 2022
b5bf44e
MatchPhraseQueryBuilder constructor requires a non-empty field name.
May 20, 2022
17f0ded
Add missing newline at the end of the file.
May 21, 2022
80f0deb
Merge branch 'main' into integ-match_phrase-#185
MaxKsyunz May 21, 2022
15775e8
Update tests from upstream/main to verify new behavior.
May 21, 2022
ee4e319
Verify exception messages in RelevanceQueryBuildTest
May 25, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

package org.opensearch.sql.opensearch.storage.script.filter.lucene.relevance;

import static org.junit.Assert.assertEquals;
import static org.junit.jupiter.api.Assertions.assertThrows;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.mock;
Expand All @@ -29,6 +30,7 @@
import org.opensearch.sql.data.model.ExprStringValue;
import org.opensearch.sql.data.model.ExprValue;
import org.opensearch.sql.data.type.ExprType;
import org.opensearch.sql.exception.ExpressionEvaluationException;
import org.opensearch.sql.exception.SemanticCheckException;
import org.opensearch.sql.expression.Expression;
import org.opensearch.sql.expression.FunctionExpression;
Expand All @@ -54,6 +56,7 @@ public void setUp() {
queryBuilder = mock(QueryBuilder.class);
when(query.createQueryBuilder(any(), any())).thenReturn(queryBuilder);
when(queryBuilder.queryName()).thenReturn("mocked_query");
when(queryBuilder.getWriteableName()).thenReturn("mock_query");
}

@Test
Expand All @@ -67,7 +70,9 @@ void throws_SemanticCheckException_when_wrong_argument_name() {
FunctionExpression expr =
createCall(List.of(FIELD_ARG, QUERY_ARG, namedArgument("wrongArg", "value")));

assertThrows(SemanticCheckException.class, () -> query.build(expr));
SemanticCheckException exception =
assertThrows(SemanticCheckException.class, () -> query.build(expr));
assertEquals("Parameter wrongArg is invalid for mock_query function.", exception.getMessage());
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure you want to tie the test that closely to the code (so that if someone changes a single character in the string, the test fails).
Maybe you can check that the messages contains "wrongArg" and "mock_query" and leave it at that?

assertThat(exception.getMessages(), containsString("wrongArg"));
assertThat(exception.getMessages(), containsString("mock_query"));

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@acarbonetto that's in line with pre-existing convention in this codebase.

}

@Test
Expand All @@ -82,7 +87,9 @@ void calls_action_when_correct_argument_name() {
@ParameterizedTest
@MethodSource("insufficientArguments")
public void throws_SyntaxCheckException_when_no_required_arguments(List<Expression> arguments) {
assertThrows(SyntaxCheckException.class, () -> query.build(createCall(arguments)));
SyntaxCheckException exception = assertThrows(SyntaxCheckException.class,
() -> query.build(createCall(arguments)));
assertEquals("mock_query requires at least two parameters", exception.getMessage());
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

as above

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See above.

}

public static Stream<List<Expression>> insufficientArguments() {
Expand Down