summaryrefslogtreecommitdiff
path: root/core/src/test/java/org/elasticsearch/search/aggregations/bucket
diff options
context:
space:
mode:
authorZachary Tong <polyfractal@elastic.co>2017-05-16 09:01:38 -0400
committerGitHub <noreply@github.com>2017-05-16 09:01:38 -0400
commit1e9718451940984ac2ec1ed9e290dd1c26577798 (patch)
tree0492b6c186710a79fc8cdc84d5a9a20b37918a17 /core/src/test/java/org/elasticsearch/search/aggregations/bucket
parentf6e19dcedc6030923808ff86ec2dc644f1e2140f (diff)
Automatically close releasables after test (#24687)
This moves the releasing logic to the base test, so that individual test cases don't need to worry about releasing the aggregators. It's not a big deal for individual aggs, but once tests start using sub-aggs, it can become tricky to free (without double-freeing) all the aggregators.
Diffstat (limited to 'core/src/test/java/org/elasticsearch/search/aggregations/bucket')
-rw-r--r--core/src/test/java/org/elasticsearch/search/aggregations/bucket/GlobalAggregatorTests.java19
-rw-r--r--core/src/test/java/org/elasticsearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorTests.java13
-rw-r--r--core/src/test/java/org/elasticsearch/search/aggregations/bucket/terms/TermsAggregatorTests.java42
3 files changed, 36 insertions, 38 deletions
diff --git a/core/src/test/java/org/elasticsearch/search/aggregations/bucket/GlobalAggregatorTests.java b/core/src/test/java/org/elasticsearch/search/aggregations/bucket/GlobalAggregatorTests.java
index 571a32b87b..67bec2acf7 100644
--- a/core/src/test/java/org/elasticsearch/search/aggregations/bucket/GlobalAggregatorTests.java
+++ b/core/src/test/java/org/elasticsearch/search/aggregations/bucket/GlobalAggregatorTests.java
@@ -78,17 +78,14 @@ public class GlobalAggregatorTests extends AggregatorTestCase {
aggregationBuilder.subAggregation(new MinAggregationBuilder("in_global").field("number"));
MappedFieldType fieldType = new NumberFieldMapper.NumberFieldType(NumberFieldMapper.NumberType.LONG);
fieldType.setName("number");
- try (GlobalAggregator aggregator = createAggregator(aggregationBuilder, indexSearcher, fieldType)) {
- try {
- aggregator.preCollection();
- indexSearcher.search(new MatchAllDocsQuery(), aggregator);
- aggregator.postCollection();
- InternalGlobal result = (InternalGlobal) aggregator.buildAggregation(0L);
- verify.accept(result, (InternalMin) result.getAggregations().asMap().get("in_global"));
- } finally {
- IOUtils.close(aggregator.subAggregators());
- }
- }
+
+ GlobalAggregator aggregator = createAggregator(aggregationBuilder, indexSearcher, fieldType);
+ aggregator.preCollection();
+ indexSearcher.search(new MatchAllDocsQuery(), aggregator);
+ aggregator.postCollection();
+ InternalGlobal result = (InternalGlobal) aggregator.buildAggregation(0L);
+ verify.accept(result, (InternalMin) result.getAggregations().asMap().get("in_global"));
+
indexReader.close();
directory.close();
}
diff --git a/core/src/test/java/org/elasticsearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorTests.java b/core/src/test/java/org/elasticsearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorTests.java
index 04147b245c..45b6b64cdd 100644
--- a/core/src/test/java/org/elasticsearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorTests.java
+++ b/core/src/test/java/org/elasticsearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorTests.java
@@ -112,12 +112,13 @@ public class GeoHashGridAggregatorTests extends AggregatorTestCase {
MappedFieldType fieldType = new GeoPointFieldMapper.GeoPointFieldType();
fieldType.setHasDocValues(true);
fieldType.setName(FIELD_NAME);
- try (Aggregator aggregator = createAggregator(aggregationBuilder, indexSearcher, fieldType)) {
- aggregator.preCollection();
- indexSearcher.search(query, aggregator);
- aggregator.postCollection();
- verify.accept((InternalGeoHashGrid) aggregator.buildAggregation(0L));
- }
+
+ Aggregator aggregator = createAggregator(aggregationBuilder, indexSearcher, fieldType);
+ aggregator.preCollection();
+ indexSearcher.search(query, aggregator);
+ aggregator.postCollection();
+ verify.accept((InternalGeoHashGrid) aggregator.buildAggregation(0L));
+
indexReader.close();
directory.close();
}
diff --git a/core/src/test/java/org/elasticsearch/search/aggregations/bucket/terms/TermsAggregatorTests.java b/core/src/test/java/org/elasticsearch/search/aggregations/bucket/terms/TermsAggregatorTests.java
index 7b93653fff..f54cb902d9 100644
--- a/core/src/test/java/org/elasticsearch/search/aggregations/bucket/terms/TermsAggregatorTests.java
+++ b/core/src/test/java/org/elasticsearch/search/aggregations/bucket/terms/TermsAggregatorTests.java
@@ -75,21 +75,22 @@ public class TermsAggregatorTests extends AggregatorTestCase {
MappedFieldType fieldType = new KeywordFieldMapper.KeywordFieldType();
fieldType.setName("string");
fieldType.setHasDocValues(true );
- try (TermsAggregator aggregator = createAggregator(aggregationBuilder, indexSearcher, fieldType)) {
- aggregator.preCollection();
- indexSearcher.search(new MatchAllDocsQuery(), aggregator);
- aggregator.postCollection();
- Terms result = (Terms) aggregator.buildAggregation(0L);
- assertEquals(4, result.getBuckets().size());
- assertEquals("a", result.getBuckets().get(0).getKeyAsString());
- assertEquals(2L, result.getBuckets().get(0).getDocCount());
- assertEquals("b", result.getBuckets().get(1).getKeyAsString());
- assertEquals(2L, result.getBuckets().get(1).getDocCount());
- assertEquals("c", result.getBuckets().get(2).getKeyAsString());
- assertEquals(1L, result.getBuckets().get(2).getDocCount());
- assertEquals("d", result.getBuckets().get(3).getKeyAsString());
- assertEquals(1L, result.getBuckets().get(3).getDocCount());
- }
+
+ TermsAggregator aggregator = createAggregator(aggregationBuilder, indexSearcher, fieldType);
+ aggregator.preCollection();
+ indexSearcher.search(new MatchAllDocsQuery(), aggregator);
+ aggregator.postCollection();
+ Terms result = (Terms) aggregator.buildAggregation(0L);
+ assertEquals(4, result.getBuckets().size());
+ assertEquals("a", result.getBuckets().get(0).getKeyAsString());
+ assertEquals(2L, result.getBuckets().get(0).getDocCount());
+ assertEquals("b", result.getBuckets().get(1).getKeyAsString());
+ assertEquals(2L, result.getBuckets().get(1).getDocCount());
+ assertEquals("c", result.getBuckets().get(2).getKeyAsString());
+ assertEquals(1L, result.getBuckets().get(2).getDocCount());
+ assertEquals("d", result.getBuckets().get(3).getKeyAsString());
+ assertEquals(1L, result.getBuckets().get(3).getDocCount());
+
}
indexReader.close();
directory.close();
@@ -191,12 +192,11 @@ public class TermsAggregatorTests extends AggregatorTestCase {
private InternalAggregation buildInternalAggregation(TermsAggregationBuilder builder, MappedFieldType fieldType,
IndexSearcher searcher) throws IOException {
- try (TermsAggregator aggregator = createAggregator(builder, searcher, fieldType)) {
- aggregator.preCollection();
- searcher.search(new MatchAllDocsQuery(), aggregator);
- aggregator.postCollection();
- return aggregator.buildAggregation(0L);
- }
+ TermsAggregator aggregator = createAggregator(builder, searcher, fieldType);
+ aggregator.preCollection();
+ searcher.search(new MatchAllDocsQuery(), aggregator);
+ aggregator.postCollection();
+ return aggregator.buildAggregation(0L);
}
}