Fix the parent join aggregator test case (#60991)

The test was putting parent and child documents into different segments
which is unrealistic and was causing errors.

Closes #60980
This commit is contained in:
Nik Everett 2020-08-11 17:52:57 -04:00
parent ce9c5f0e46
commit 664ba0a80a
2 changed files with 15 additions and 14 deletions

View File

@ -32,7 +32,6 @@ import org.apache.lucene.search.Query;
import org.apache.lucene.search.TermInSetQuery; import org.apache.lucene.search.TermInSetQuery;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.util.BytesRef; import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.LuceneTestCase;
import org.elasticsearch.Version; import org.elasticsearch.Version;
import org.elasticsearch.cluster.metadata.IndexMetadata; import org.elasticsearch.cluster.metadata.IndexMetadata;
import org.elasticsearch.common.collect.Tuple; import org.elasticsearch.common.collect.Tuple;
@ -40,12 +39,12 @@ import org.elasticsearch.common.lucene.index.ElasticsearchDirectoryReader;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.index.Index; import org.elasticsearch.index.Index;
import org.elasticsearch.index.mapper.ContentPath; import org.elasticsearch.index.mapper.ContentPath;
import org.elasticsearch.index.mapper.MappingLookup;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.IdFieldMapper; import org.elasticsearch.index.mapper.IdFieldMapper;
import org.elasticsearch.index.mapper.MappedFieldType; import org.elasticsearch.index.mapper.MappedFieldType;
import org.elasticsearch.index.mapper.Mapper; import org.elasticsearch.index.mapper.Mapper;
import org.elasticsearch.index.mapper.MapperService; import org.elasticsearch.index.mapper.MapperService;
import org.elasticsearch.index.mapper.MappingLookup;
import org.elasticsearch.index.mapper.NumberFieldMapper; import org.elasticsearch.index.mapper.NumberFieldMapper;
import org.elasticsearch.index.mapper.Uid; import org.elasticsearch.index.mapper.Uid;
import org.elasticsearch.index.shard.ShardId; import org.elasticsearch.index.shard.ShardId;
@ -75,7 +74,6 @@ import java.util.function.Consumer;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
@LuceneTestCase.AwaitsFix(bugUrl = "https://github.com/elastic/elasticsearch/issues/60980")
public class ChildrenToParentAggregatorTests extends AggregatorTestCase { public class ChildrenToParentAggregatorTests extends AggregatorTestCase {
private static final String CHILD_TYPE = "child_type"; private static final String CHILD_TYPE = "child_type";
@ -121,9 +119,11 @@ public class ChildrenToParentAggregatorTests extends AggregatorTestCase {
expectedTotalParents++; expectedTotalParents++;
expectedMinValue = Math.min(expectedMinValue, expectedValues.v2()); expectedMinValue = Math.min(expectedMinValue, expectedValues.v2());
} }
assertEquals("Having " + parent.getDocCount() + " docs and aggregation results: " + assertEquals(
parent.getAggregations().asMap(), "Having " + parent.getDocCount() + " docs and aggregation results: " + parent,
expectedTotalParents, parent.getDocCount()); expectedTotalParents,
parent.getDocCount()
);
assertEquals(expectedMinValue, ((InternalMin) parent.getAggregations().get("in_parent")).getValue(), Double.MIN_VALUE); assertEquals(expectedMinValue, ((InternalMin) parent.getAggregations().get("in_parent")).getValue(), Double.MIN_VALUE);
assertTrue(JoinAggregationInspectionHelper.hasValue(parent)); assertTrue(JoinAggregationInspectionHelper.hasValue(parent));
}); });
@ -235,21 +235,19 @@ public class ChildrenToParentAggregatorTests extends AggregatorTestCase {
Map<String, Tuple<Integer, Integer>> expectedValues = new HashMap<>(); Map<String, Tuple<Integer, Integer>> expectedValues = new HashMap<>();
int numParents = randomIntBetween(1, 10); int numParents = randomIntBetween(1, 10);
for (int i = 0; i < numParents; i++) { for (int i = 0; i < numParents; i++) {
List<List<Field>> documents = new ArrayList<>();
String parent = "parent" + i; String parent = "parent" + i;
int randomValue = randomIntBetween(0, 100); int randomValue = randomIntBetween(0, 100);
List<Field> parentDocument = createParentDocument(parent, randomValue); documents.add(createParentDocument(parent, randomValue));
/*long parentDocId =*/ iw.addDocument(parentDocument);
//System.out.println("Parent: " + parent + ": " + randomValue + ", id: " + parentDocId);
int numChildren = randomIntBetween(1, 10); int numChildren = randomIntBetween(1, 10);
int minValue = Integer.MAX_VALUE; int minValue = Integer.MAX_VALUE;
for (int c = 0; c < numChildren; c++) { for (int c = 0; c < numChildren; c++) {
minValue = Math.min(minValue, randomValue); minValue = Math.min(minValue, randomValue);
int randomSubValue = randomIntBetween(0, 100); int randomSubValue = randomIntBetween(0, 100);
List<Field> childDocument = createChildDocument("child" + c + "_" + parent, parent, randomSubValue); documents.add(createChildDocument("child" + c + "_" + parent, parent, randomSubValue));
/*long childDocId =*/ iw.addDocument(childDocument);
//System.out.println("Child: " + "child" + c + "_" + parent + ": " + randomSubValue + ", id: " + childDocId);
} }
expectedValues.put(parent, new Tuple<>(numChildren, minValue)); expectedValues.put(parent, new Tuple<>(numChildren, minValue));
iw.addDocuments(documents);
} }
return expectedValues; return expectedValues;
} }

View File

@ -424,9 +424,12 @@ public abstract class AggregatorTestCase extends ESTestCase {
} }
/** /**
* Divides the provided {@link IndexSearcher} in sub-searcher, one for each segment, * Collects all documents that match the provided query {@link Query} and
* builds an aggregator for each sub-searcher filtered by the provided {@link Query} and
* returns the reduced {@link InternalAggregation}. * returns the reduced {@link InternalAggregation}.
* <p>
* Half the time it aggregates each leaf individually and reduces all
* results together. The other half the time it aggregates across the entire
* index at once and runs a final reduction on the single resulting agg.
*/ */
protected <A extends InternalAggregation, C extends Aggregator> A searchAndReduce(IndexSettings indexSettings, protected <A extends InternalAggregation, C extends Aggregator> A searchAndReduce(IndexSettings indexSettings,
IndexSearcher searcher, IndexSearcher searcher,