parent
4670a2e514
commit
6945f294e7
|
@ -60,6 +60,7 @@ public class IndicesFilterParser implements FilterParser {
|
||||||
boolean filterFound = false;
|
boolean filterFound = false;
|
||||||
boolean indicesFound = false;
|
boolean indicesFound = false;
|
||||||
boolean currentIndexMatchesIndices = false;
|
boolean currentIndexMatchesIndices = false;
|
||||||
|
String filterName = null;
|
||||||
|
|
||||||
String currentFieldName = null;
|
String currentFieldName = null;
|
||||||
XContentParser.Token token;
|
XContentParser.Token token;
|
||||||
|
@ -116,6 +117,8 @@ public class IndicesFilterParser implements FilterParser {
|
||||||
} else if ("none".equals(type)) {
|
} else if ("none".equals(type)) {
|
||||||
noMatchFilter = Queries.MATCH_NO_FILTER;
|
noMatchFilter = Queries.MATCH_NO_FILTER;
|
||||||
}
|
}
|
||||||
|
} else if ("_name".equals(currentFieldName)) {
|
||||||
|
filterName = parser.text();
|
||||||
} else {
|
} else {
|
||||||
throw new QueryParsingException(parseContext.index(), "[indices] filter does not support [" + currentFieldName + "]");
|
throw new QueryParsingException(parseContext.index(), "[indices] filter does not support [" + currentFieldName + "]");
|
||||||
}
|
}
|
||||||
|
@ -128,10 +131,18 @@ public class IndicesFilterParser implements FilterParser {
|
||||||
throw new QueryParsingException(parseContext.index(), "[indices] requires 'indices' or 'index' element");
|
throw new QueryParsingException(parseContext.index(), "[indices] requires 'indices' or 'index' element");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Filter chosenFilter;
|
||||||
if (currentIndexMatchesIndices) {
|
if (currentIndexMatchesIndices) {
|
||||||
return filter;
|
chosenFilter = filter;
|
||||||
|
} else {
|
||||||
|
chosenFilter = noMatchFilter;
|
||||||
}
|
}
|
||||||
return noMatchFilter;
|
|
||||||
|
if (filterName != null) {
|
||||||
|
parseContext.addNamedFilter(filterName, chosenFilter);
|
||||||
|
}
|
||||||
|
|
||||||
|
return chosenFilter;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean matchesIndices(String currentIndex, String... indices) {
|
protected boolean matchesIndices(String currentIndex, String... indices) {
|
||||||
|
|
|
@ -164,4 +164,43 @@ public class MatchedQueriesTests extends ElasticsearchIntegrationTest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testIndicesFilterSupportsName() {
|
||||||
|
createIndex("test1", "test2");
|
||||||
|
ensureGreen();
|
||||||
|
|
||||||
|
client().prepareIndex("test1", "type1", "1").setSource("title", "title1").get();
|
||||||
|
client().prepareIndex("test2", "type1", "2").setSource("title", "title2").get();
|
||||||
|
client().prepareIndex("test2", "type1", "3").setSource("title", "title3").get();
|
||||||
|
refresh();
|
||||||
|
|
||||||
|
SearchResponse searchResponse = client().prepareSearch()
|
||||||
|
.setQuery(filteredQuery(matchAllQuery(),
|
||||||
|
orFilter(
|
||||||
|
indicesFilter(termFilter("title", "title1").filterName("title1"), "test1")
|
||||||
|
.noMatchFilter(termFilter("title", "title2").filterName("title2")).filterName("indices_filter"),
|
||||||
|
termFilter("title", "title3").filterName("title3")).filterName("or"))).get();
|
||||||
|
assertHitCount(searchResponse, 3l);
|
||||||
|
|
||||||
|
for (SearchHit hit : searchResponse.getHits()) {
|
||||||
|
if (hit.id().equals("1")) {
|
||||||
|
assertThat(hit.matchedQueries().length, equalTo(3));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("indices_filter"));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("title1"));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("or"));
|
||||||
|
} else if (hit.id().equals("2")) {
|
||||||
|
assertThat(hit.matchedQueries().length, equalTo(3));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("indices_filter"));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("title2"));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("or"));
|
||||||
|
} else if (hit.id().equals("3")) {
|
||||||
|
assertThat(hit.matchedQueries().length, equalTo(2));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("title3"));
|
||||||
|
assertThat(hit.matchedQueries(), hasItemInArray("or"));
|
||||||
|
} else {
|
||||||
|
fail("Unexpected document returned with id " + hit.id());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue