Closes #48475
This commit is contained in:
parent
e528b41cf2
commit
1824a2fa58
|
@ -424,12 +424,19 @@ public class BoolQueryBuilder extends AbstractQueryBuilder<BoolQueryBuilder> {
|
||||||
changed |= rewriteClauses(queryRewriteContext, mustNotClauses, newBuilder::mustNot);
|
changed |= rewriteClauses(queryRewriteContext, mustNotClauses, newBuilder::mustNot);
|
||||||
changed |= rewriteClauses(queryRewriteContext, filterClauses, newBuilder::filter);
|
changed |= rewriteClauses(queryRewriteContext, filterClauses, newBuilder::filter);
|
||||||
changed |= rewriteClauses(queryRewriteContext, shouldClauses, newBuilder::should);
|
changed |= rewriteClauses(queryRewriteContext, shouldClauses, newBuilder::should);
|
||||||
|
// early termination when must clause is empty and optional clauses is returning MatchNoneQueryBuilder
|
||||||
|
if(mustClauses.size() == 0 && filterClauses.size() == 0 && shouldClauses.size() > 0
|
||||||
|
&& newBuilder.shouldClauses.stream().allMatch(b -> b instanceof MatchNoneQueryBuilder)) {
|
||||||
|
return new MatchNoneQueryBuilder();
|
||||||
|
}
|
||||||
|
|
||||||
// lets do some early termination and prevent any kind of rewriting if we have a mandatory query that is a MatchNoneQueryBuilder
|
// lets do some early termination and prevent any kind of rewriting if we have a mandatory query that is a MatchNoneQueryBuilder
|
||||||
Optional<QueryBuilder> any = Stream.concat(newBuilder.mustClauses.stream(), newBuilder.filterClauses.stream())
|
Optional<QueryBuilder> any = Stream.concat(newBuilder.mustClauses.stream(), newBuilder.filterClauses.stream())
|
||||||
.filter(b -> b instanceof MatchNoneQueryBuilder).findAny();
|
.filter(b -> b instanceof MatchNoneQueryBuilder).findAny();
|
||||||
if (any.isPresent()) {
|
if (any.isPresent()) {
|
||||||
return any.get();
|
return any.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (changed) {
|
if (changed) {
|
||||||
newBuilder.adjustPureNegative = adjustPureNegative;
|
newBuilder.adjustPureNegative = adjustPureNegative;
|
||||||
newBuilder.minimumShouldMatch = minimumShouldMatch;
|
newBuilder.minimumShouldMatch = minimumShouldMatch;
|
||||||
|
|
|
@ -371,5 +371,20 @@ public class BoolQueryBuilderTests extends AbstractQueryTestCase<BoolQueryBuilde
|
||||||
.filter(new MatchNoneQueryBuilder()));
|
.filter(new MatchNoneQueryBuilder()));
|
||||||
rewritten = Rewriteable.rewrite(boolQueryBuilder, createShardContext());
|
rewritten = Rewriteable.rewrite(boolQueryBuilder, createShardContext());
|
||||||
assertEquals(new MatchNoneQueryBuilder(), rewritten);
|
assertEquals(new MatchNoneQueryBuilder(), rewritten);
|
||||||
|
|
||||||
|
boolQueryBuilder = new BoolQueryBuilder();
|
||||||
|
boolQueryBuilder.should(new WrapperQueryBuilder(new MatchNoneQueryBuilder().toString()));
|
||||||
|
rewritten = Rewriteable.rewrite(boolQueryBuilder, createShardContext());
|
||||||
|
assertEquals(new MatchNoneQueryBuilder(), rewritten);
|
||||||
|
|
||||||
|
boolQueryBuilder = new BoolQueryBuilder();
|
||||||
|
boolQueryBuilder.should(new TermQueryBuilder("foo", "bar"));
|
||||||
|
boolQueryBuilder.should(new WrapperQueryBuilder(new MatchNoneQueryBuilder().toString()));
|
||||||
|
rewritten = Rewriteable.rewrite(boolQueryBuilder, createShardContext());
|
||||||
|
assertNotEquals(new MatchNoneQueryBuilder(), rewritten);
|
||||||
|
|
||||||
|
boolQueryBuilder = new BoolQueryBuilder();
|
||||||
|
rewritten = Rewriteable.rewrite(boolQueryBuilder, createShardContext());
|
||||||
|
assertNotEquals(new MatchNoneQueryBuilder(), rewritten);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue