inner hits: Protected against specifying a size larger than the total amount of documents in an index.
Closes #13394
This commit is contained in:
parent
281eac757d
commit
65e7aba780
|
@ -123,7 +123,7 @@ public final class InnerHitsContext {
|
||||||
if (size() == 0) {
|
if (size() == 0) {
|
||||||
return new TopDocs(context.searcher().count(q), Lucene.EMPTY_SCORE_DOCS, 0);
|
return new TopDocs(context.searcher().count(q), Lucene.EMPTY_SCORE_DOCS, 0);
|
||||||
} else {
|
} else {
|
||||||
int topN = from() + size();
|
int topN = Math.min(from() + size(), context.searcher().getIndexReader().maxDoc());
|
||||||
TopDocsCollector topDocsCollector;
|
TopDocsCollector topDocsCollector;
|
||||||
if (sort() != null) {
|
if (sort() != null) {
|
||||||
try {
|
try {
|
||||||
|
@ -303,7 +303,7 @@ public final class InnerHitsContext {
|
||||||
final int count = context.searcher().count(q);
|
final int count = context.searcher().count(q);
|
||||||
return new TopDocs(count, Lucene.EMPTY_SCORE_DOCS, 0);
|
return new TopDocs(count, Lucene.EMPTY_SCORE_DOCS, 0);
|
||||||
} else {
|
} else {
|
||||||
int topN = from() + size();
|
int topN = Math.min(from() + size(), context.searcher().getIndexReader().maxDoc());
|
||||||
TopDocsCollector topDocsCollector;
|
TopDocsCollector topDocsCollector;
|
||||||
if (sort() != null) {
|
if (sort() != null) {
|
||||||
topDocsCollector = TopFieldCollector.create(sort(), topN, true, trackScores(), trackScores());
|
topDocsCollector = TopFieldCollector.create(sort(), topN, true, trackScores(), trackScores());
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
package org.elasticsearch.search.innerhits;
|
package org.elasticsearch.search.innerhits;
|
||||||
|
|
||||||
|
import org.apache.lucene.util.ArrayUtil;
|
||||||
import org.elasticsearch.Version;
|
import org.elasticsearch.Version;
|
||||||
import org.elasticsearch.action.admin.cluster.health.ClusterHealthStatus;
|
import org.elasticsearch.action.admin.cluster.health.ClusterHealthStatus;
|
||||||
import org.elasticsearch.action.index.IndexRequestBuilder;
|
import org.elasticsearch.action.index.IndexRequestBuilder;
|
||||||
|
@ -1131,4 +1132,38 @@ public class InnerHitsIT extends ESIntegTestCase {
|
||||||
assertThat(response.getHits().getAt(0).getInnerHits().get("child").getAt(0).getMatchedQueries()[0], equalTo("_name2"));
|
assertThat(response.getHits().getAt(0).getInnerHits().get("child").getAt(0).getMatchedQueries()[0], equalTo("_name2"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDontExplode() throws Exception {
|
||||||
|
assertAcked(prepareCreate("index1").addMapping("child", "_parent", "type=parent"));
|
||||||
|
List<IndexRequestBuilder> requests = new ArrayList<>();
|
||||||
|
requests.add(client().prepareIndex("index1", "parent", "1").setSource("{}"));
|
||||||
|
requests.add(client().prepareIndex("index1", "child", "1").setParent("1").setSource("field", "value1"));
|
||||||
|
indexRandom(true, requests);
|
||||||
|
|
||||||
|
SearchResponse response = client().prepareSearch("index1")
|
||||||
|
.setQuery(hasChildQuery("child", matchQuery("field", "value1")).innerHit(new QueryInnerHitBuilder().setSize(ArrayUtil.MAX_ARRAY_LENGTH - 1)))
|
||||||
|
.addSort("_uid", SortOrder.ASC)
|
||||||
|
.get();
|
||||||
|
assertNoFailures(response);
|
||||||
|
assertHitCount(response, 1);
|
||||||
|
|
||||||
|
assertAcked(prepareCreate("index2").addMapping("type", "nested", "type=nested"));
|
||||||
|
client().prepareIndex("index2", "type", "1").setSource(jsonBuilder().startObject()
|
||||||
|
.startArray("nested")
|
||||||
|
.startObject()
|
||||||
|
.field("field", "value1")
|
||||||
|
.endObject()
|
||||||
|
.endArray()
|
||||||
|
.endObject())
|
||||||
|
.setRefresh(true)
|
||||||
|
.get();
|
||||||
|
|
||||||
|
response = client().prepareSearch("index2")
|
||||||
|
.setQuery(nestedQuery("nested", matchQuery("nested.field", "value1")).innerHit(new QueryInnerHitBuilder().setSize(ArrayUtil.MAX_ARRAY_LENGTH - 1)))
|
||||||
|
.addSort("_uid", SortOrder.ASC)
|
||||||
|
.get();
|
||||||
|
assertNoFailures(response);
|
||||||
|
assertHitCount(response, 1);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue