The nonNestedFilter should always be included if no types have been specified and
null can only be returned if there are no type or alias filter and the index has nested fields.
This commit is contained in:
parent
7914d0f940
commit
cdecf725f8
|
@ -255,14 +255,17 @@ public class DefaultSearchContext extends SearchContext {
|
||||||
typesBytes[i] = new BytesRef(types[i]);
|
typesBytes[i] = new BytesRef(types[i]);
|
||||||
}
|
}
|
||||||
typesFilter = new TermsQuery(TypeFieldMapper.NAME, typesBytes);
|
typesFilter = new TermsQuery(TypeFieldMapper.NAME, typesBytes);
|
||||||
} else if (hasNestedFields) {
|
}
|
||||||
typesFilter = Queries.newNonNestedFilter();
|
|
||||||
} else if (aliasFilter == null) {
|
if (typesFilter == null && aliasFilter == null && hasNestedFields == false) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
BooleanQuery.Builder bq = new BooleanQuery.Builder();
|
BooleanQuery.Builder bq = new BooleanQuery.Builder();
|
||||||
if (typesFilter != null) {
|
if (typesFilter != null) {
|
||||||
bq.add(typesFilter, Occur.FILTER);
|
bq.add(typesFilter, Occur.FILTER);
|
||||||
|
} else if (hasNestedFields) {
|
||||||
|
bq.add(Queries.newNonNestedFilter(), Occur.FILTER);
|
||||||
}
|
}
|
||||||
if (aliasFilter != null) {
|
if (aliasFilter != null) {
|
||||||
bq.add(aliasFilter, Occur.FILTER);
|
bq.add(aliasFilter, Occur.FILTER);
|
||||||
|
|
|
@ -55,8 +55,17 @@ public class DefaultSearchContextTests extends ESTestCase {
|
||||||
expectedQuery = new BooleanQuery.Builder().add(Queries.newNonNestedFilter(), FILTER).build();
|
expectedQuery = new BooleanQuery.Builder().add(Queries.newNonNestedFilter(), FILTER).build();
|
||||||
assertThat(searchFilter, equalTo(expectedQuery));
|
assertThat(searchFilter, equalTo(expectedQuery));
|
||||||
|
|
||||||
searchFilter = DefaultSearchContext.createSearchFilter(null, new MatchAllDocsQuery(), randomBoolean());
|
searchFilter = DefaultSearchContext.createSearchFilter(null, new MatchAllDocsQuery(), true);
|
||||||
expectedQuery = new BooleanQuery.Builder().add(new MatchAllDocsQuery(), FILTER).build();
|
expectedQuery = new BooleanQuery.Builder()
|
||||||
|
.add(new MatchAllDocsQuery(), FILTER)
|
||||||
|
.add(Queries.newNonNestedFilter(), FILTER)
|
||||||
|
.build();
|
||||||
|
assertThat(searchFilter, equalTo(expectedQuery));
|
||||||
|
|
||||||
|
searchFilter = DefaultSearchContext.createSearchFilter(null, new MatchAllDocsQuery(), false);
|
||||||
|
expectedQuery = new BooleanQuery.Builder()
|
||||||
|
.add(new MatchAllDocsQuery(), FILTER)
|
||||||
|
.build();
|
||||||
assertThat(searchFilter, equalTo(expectedQuery));
|
assertThat(searchFilter, equalTo(expectedQuery));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue