From 2a1fa61505866b4097c3d6517baa94c5d5a9547b Mon Sep 17 00:00:00 2001
From: Navneet Verma
Date: Mon, 22 Aug 2022 13:03:22 -0700
Subject: [PATCH] Refactored the src and test of GeoHashGrid and GeoTileGrid
Aggregations on GeoPoint from server folder to geo module.(#4071) (#4072)
(#4180)
The changes also includes:
* Updated Search plugin to provide the interface so that plugins can also register the composite aggregations
* Added YAML test for the geo_grid, geo_tile and composite aggregation
Signed-off-by: Navneet Verma
---
.../client/RestHighLevelClient.java | 6 -
modules/geo/build.gradle | 9 +-
.../aggregations/bucket/GeoHashGridIT.java | 39 +-
.../aggregations/bucket/ShardReduceIT.java | 107 +++++
...actGeoAggregatorModulePluginTestCase.java} | 2 +-
...BoundsIT.java => GeoBoundsITTestCase.java} | 2 +-
.../metrics/GeoCentroidITTestCase.java | 84 ++++
.../org/opensearch/geo/GeoModulePlugin.java | 42 +-
.../GeoTileGridValuesSourceBuilder.java | 29 +-
.../bucket/composite/GeoTileValuesSource.java | 8 +-
.../bucket/geogrid/BoundedCellValues.java | 2 +-
.../bucket/geogrid/BucketPriorityQueue.java | 2 +-
.../bucket/geogrid/CellIdSource.java | 2 +-
.../bucket/geogrid/CellValues.java | 2 +-
.../aggregations/bucket/geogrid/GeoGrid.java | 2 +-
.../geogrid/GeoGridAggregationBuilder.java | 2 +-
.../bucket/geogrid/GeoGridAggregator.java | 2 +-
.../GeoHashGridAggregationBuilder.java | 4 +-
.../bucket/geogrid/GeoHashGridAggregator.java | 2 +-
.../geogrid/GeoHashGridAggregatorFactory.java | 2 +-
.../GeoTileGridAggregationBuilder.java | 5 +-
.../bucket/geogrid/GeoTileGridAggregator.java | 2 +-
.../geogrid/GeoTileGridAggregatorFactory.java | 3 +-
.../bucket/geogrid/InternalGeoGrid.java | 2 +-
.../bucket/geogrid/InternalGeoGridBucket.java | 2 +-
.../bucket/geogrid/InternalGeoHashGrid.java | 2 +-
.../geogrid/InternalGeoHashGridBucket.java | 2 +-
.../bucket/geogrid/InternalGeoTileGrid.java | 2 +-
.../geogrid/InternalGeoTileGridBucket.java | 3 +-
.../bucket/geogrid/ParsedGeoGrid.java | 2 +-
.../bucket/geogrid/ParsedGeoGridBucket.java | 2 +-
.../bucket/geogrid/ParsedGeoHashGrid.java | 2 +-
.../geogrid/ParsedGeoHashGridBucket.java | 2 +-
.../bucket/geogrid/ParsedGeoTileGrid.java | 2 +-
.../geogrid/ParsedGeoTileGridBucket.java | 3 +-
.../bucket/geogrid/UnboundedCellValues.java | 2 +-
.../bucket/geogrid/package-info.java | 2 +-
.../metrics/GeoGridAggregatorSupplier.java | 4 +-
.../GeoHashGridAggregationBuilderTests.java | 20 +-
.../GeoTileGridAggregationBuilderTests.java | 22 +-
...idAggregationCompositeAggregatorTests.java | 174 ++++++++
...eGridCompositeAggregationBuilderTests.java | 50 +++
.../GeoTileGridValuesSourceBuilderTests.java | 7 +-
.../geogrid/GeoGridAggregatorTestCase.java | 20 +-
.../bucket/geogrid/GeoGridTestCase.java | 39 +-
.../geogrid/GeoHashGridAggregatorTests.java | 2 +-
.../geogrid/GeoHashGridParserTests.java | 2 +-
.../bucket/geogrid/GeoHashGridTests.java | 2 +-
.../geogrid/GeoTileGridAggregatorTests.java | 4 +-
.../geogrid/GeoTileGridParserTests.java | 3 +-
.../bucket/geogrid/GeoTileGridTests.java | 3 +-
.../geo/tests/common/AggregationBuilders.java | 18 +
.../common/AggregationInspectionHelper.java | 5 +
.../geo/tests/common/RandomGeoGenerator.java | 11 +
.../test/geo_shape/230_composite.yml | 168 ++++++++
.../test/geo_shape}/280_geohash_grid.yml | 0
.../test/geo_shape}/290_geotile_grid.yml | 0
.../test/search.aggregation/230_composite.yml | 86 ----
.../aggregations/bucket/ShardReduceIT.java | 35 --
.../aggregations/metrics/GeoCentroidIT.java | 33 --
.../org/opensearch/plugins/SearchPlugin.java | 82 ++++
.../org/opensearch/search/DocValueFormat.java | 2 +-
.../org/opensearch/search/SearchModule.java | 22 +-
.../aggregations/AggregationBuilders.java | 18 -
.../bucket/{geogrid => }/GeoTileUtils.java | 8 +-
.../CompositeAggregationBuilder.java | 50 ++-
.../CompositeAggregationParsingFunction.java | 22 +
.../CompositeValuesSourceBuilder.java | 6 +-
.../CompositeValuesSourceConfig.java | 18 +-
.../CompositeValuesSourceParserHelper.java | 78 +++-
.../bucket/composite/LongValuesSource.java | 6 +-
.../SingleDimensionValuesSource.java | 2 +-
.../support/AggregationInspectionHelper.java | 5 -
.../aggregations/support/package-info.java | 2 +-
.../search/DocValueFormatTests.java | 2 +-
.../aggregations/AggregationsTests.java | 4 -
.../CompositeAggregationBuilderTests.java | 20 +-
.../composite/CompositeAggregatorTests.java | 384 +-----------------
.../bucket/geogrid/GeoTileUtilsTests.java | 13 +-
.../BaseCompositeAggregatorTestCase.java | 310 ++++++++++++++
.../test/InternalAggregationTestCase.java | 6 -
81 files changed, 1395 insertions(+), 763 deletions(-)
rename {server/src/internalClusterTest/java/org/opensearch => modules/geo/src/internalClusterTest/java/org/opensearch/geo}/search/aggregations/bucket/GeoHashGridIT.java (89%)
create mode 100644 modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/ShardReduceIT.java
rename modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/{AbstractGeoAggregatorTestCaseModulePlugin.java => AbstractGeoAggregatorModulePluginTestCase.java} (99%)
rename modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/{GeoBoundsIT.java => GeoBoundsITTestCase.java} (99%)
create mode 100644 modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoCentroidITTestCase.java
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java (87%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/composite/GeoTileValuesSource.java (88%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/BoundedCellValues.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/BucketPriorityQueue.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/CellIdSource.java (98%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/CellValues.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoGrid.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java (99%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoGridAggregator.java (99%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java (98%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java (95%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/InternalGeoGrid.java (99%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java (98%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java (94%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/ParsedGeoGrid.java (97%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java (93%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/UnboundedCellValues.java (96%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/package-info.java (79%)
rename {server/src/main/java/org/opensearch => modules/geo/src/main/java/org/opensearch/geo}/search/aggregations/metrics/GeoGridAggregatorSupplier.java (93%)
rename server/src/test/java/org/opensearch/search/aggregations/bucket/GeoHashGridTests.java => modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridAggregationBuilderTests.java (83%)
rename server/src/test/java/org/opensearch/search/aggregations/bucket/GeoTileGridTests.java => modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoTileGridAggregationBuilderTests.java (81%)
create mode 100644 modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridAggregationCompositeAggregatorTests.java
create mode 100644 modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridCompositeAggregationBuilderTests.java
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilderTests.java (91%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoGridAggregatorTestCase.java (95%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoGridTestCase.java (79%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoHashGridAggregatorTests.java (96%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoHashGridParserTests.java (99%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoHashGridTests.java (97%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoTileGridAggregatorTests.java (94%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoTileGridParserTests.java (97%)
rename {server/src/test/java/org/opensearch => modules/geo/src/test/java/org/opensearch/geo}/search/aggregations/bucket/geogrid/GeoTileGridTests.java (94%)
create mode 100644 modules/geo/src/yamlRestTest/resources/rest-api-spec/test/geo_shape/230_composite.yml
rename {rest-api-spec/src/main/resources/rest-api-spec/test/search.aggregation => modules/geo/src/yamlRestTest/resources/rest-api-spec/test/geo_shape}/280_geohash_grid.yml (100%)
rename {rest-api-spec/src/main/resources/rest-api-spec/test/search.aggregation => modules/geo/src/yamlRestTest/resources/rest-api-spec/test/geo_shape}/290_geotile_grid.yml (100%)
rename server/src/main/java/org/opensearch/search/aggregations/bucket/{geogrid => }/GeoTileUtils.java (97%)
create mode 100644 server/src/main/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregationParsingFunction.java
create mode 100644 test/framework/src/main/java/org/opensearch/search/aggregations/composite/BaseCompositeAggregatorTestCase.java
diff --git a/client/rest-high-level/src/main/java/org/opensearch/client/RestHighLevelClient.java b/client/rest-high-level/src/main/java/org/opensearch/client/RestHighLevelClient.java
index 7ae8f8826c5a4..28a441bdf7f7f 100644
--- a/client/rest-high-level/src/main/java/org/opensearch/client/RestHighLevelClient.java
+++ b/client/rest-high-level/src/main/java/org/opensearch/client/RestHighLevelClient.java
@@ -108,10 +108,6 @@
import org.opensearch.search.aggregations.bucket.filter.FiltersAggregationBuilder;
import org.opensearch.search.aggregations.bucket.filter.ParsedFilter;
import org.opensearch.search.aggregations.bucket.filter.ParsedFilters;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoHashGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.ParsedGeoHashGrid;
-import org.opensearch.search.aggregations.bucket.geogrid.ParsedGeoTileGrid;
import org.opensearch.search.aggregations.bucket.global.GlobalAggregationBuilder;
import org.opensearch.search.aggregations.bucket.global.ParsedGlobal;
import org.opensearch.search.aggregations.bucket.histogram.AutoDateHistogramAggregationBuilder;
@@ -2130,8 +2126,6 @@ static List getDefaultNamedXContents() {
map.put(GlobalAggregationBuilder.NAME, (p, c) -> ParsedGlobal.fromXContent(p, (String) c));
map.put(FilterAggregationBuilder.NAME, (p, c) -> ParsedFilter.fromXContent(p, (String) c));
map.put(InternalSampler.PARSER_NAME, (p, c) -> ParsedSampler.fromXContent(p, (String) c));
- map.put(GeoHashGridAggregationBuilder.NAME, (p, c) -> ParsedGeoHashGrid.fromXContent(p, (String) c));
- map.put(GeoTileGridAggregationBuilder.NAME, (p, c) -> ParsedGeoTileGrid.fromXContent(p, (String) c));
map.put(RangeAggregationBuilder.NAME, (p, c) -> ParsedRange.fromXContent(p, (String) c));
map.put(DateRangeAggregationBuilder.NAME, (p, c) -> ParsedDateRange.fromXContent(p, (String) c));
map.put(GeoDistanceAggregationBuilder.NAME, (p, c) -> ParsedGeoDistance.fromXContent(p, (String) c));
diff --git a/modules/geo/build.gradle b/modules/geo/build.gradle
index 0b8e623c24ac6..7f687a414e566 100644
--- a/modules/geo/build.gradle
+++ b/modules/geo/build.gradle
@@ -37,9 +37,16 @@ opensearchplugin {
restResources {
restApi {
- includeCore '_common', 'indices', 'index', 'search'
+ includeCore '_common', 'indices', 'index', 'search', 'bulk'
}
}
artifacts {
restTests(project.file('src/yamlRestTest/resources/rest-api-spec/test'))
}
+/**
+ * These compiler arguments needs to be removed, as there are raw types being used in the GeoGrid and GeoTile aggregations.
+ */
+tasks.withType(JavaCompile).configureEach {
+ options.compilerArgs -= '-Xlint:rawtypes'
+ options.compilerArgs -= '-Xlint:unchecked'
+}
diff --git a/server/src/internalClusterTest/java/org/opensearch/search/aggregations/bucket/GeoHashGridIT.java b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridIT.java
similarity index 89%
rename from server/src/internalClusterTest/java/org/opensearch/search/aggregations/bucket/GeoHashGridIT.java
rename to modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridIT.java
index 56d918feef9d8..6ab7dd5254679 100644
--- a/server/src/internalClusterTest/java/org/opensearch/search/aggregations/bucket/GeoHashGridIT.java
+++ b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridIT.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket;
+package org.opensearch.geo.search.aggregations.bucket;
import com.carrotsearch.hppc.ObjectIntHashMap;
import com.carrotsearch.hppc.ObjectIntMap;
@@ -41,12 +41,12 @@
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.settings.Settings;
import org.opensearch.common.xcontent.XContentBuilder;
+import org.opensearch.geo.GeoModulePluginIntegTestCase;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoGrid;
+import org.opensearch.geo.tests.common.AggregationBuilders;
import org.opensearch.index.query.GeoBoundingBoxQueryBuilder;
-import org.opensearch.search.aggregations.AggregationBuilders;
import org.opensearch.search.aggregations.InternalAggregation;
import org.opensearch.search.aggregations.bucket.filter.Filter;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoGrid;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoGrid.Bucket;
import org.opensearch.test.OpenSearchIntegTestCase;
import org.opensearch.test.VersionUtils;
@@ -57,17 +57,16 @@
import java.util.Random;
import java.util.Set;
+import static org.hamcrest.Matchers.containsString;
+import static org.hamcrest.Matchers.equalTo;
+import static org.opensearch.common.xcontent.XContentFactory.jsonBuilder;
import static org.opensearch.geometry.utils.Geohash.PRECISION;
import static org.opensearch.geometry.utils.Geohash.stringEncode;
-import static org.opensearch.common.xcontent.XContentFactory.jsonBuilder;
-import static org.opensearch.search.aggregations.AggregationBuilders.geohashGrid;
import static org.opensearch.test.hamcrest.OpenSearchAssertions.assertAcked;
import static org.opensearch.test.hamcrest.OpenSearchAssertions.assertSearchResponse;
-import static org.hamcrest.Matchers.containsString;
-import static org.hamcrest.Matchers.equalTo;
@OpenSearchIntegTestCase.SuiteScopeTestCase
-public class GeoHashGridIT extends OpenSearchIntegTestCase {
+public class GeoHashGridIT extends GeoModulePluginIntegTestCase {
@Override
protected boolean forbidPrivateIndexSettings() {
@@ -158,13 +157,13 @@ public void setupSuiteScopeCluster() throws Exception {
public void testSimple() throws Exception {
for (int precision = 1; precision <= PRECISION; precision++) {
SearchResponse response = client().prepareSearch("idx")
- .addAggregation(geohashGrid("geohashgrid").field("location").precision(precision))
+ .addAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").precision(precision))
.get();
assertSearchResponse(response);
GeoGrid geoGrid = response.getAggregations().get("geohashgrid");
- List extends Bucket> buckets = geoGrid.getBuckets();
+ List extends GeoGrid.Bucket> buckets = geoGrid.getBuckets();
Object[] propertiesKeys = (Object[]) ((InternalAggregation) geoGrid).getProperty("_key");
Object[] propertiesDocCounts = (Object[]) ((InternalAggregation) geoGrid).getProperty("_count");
for (int i = 0; i < buckets.size(); i++) {
@@ -185,7 +184,7 @@ public void testSimple() throws Exception {
public void testMultivalued() throws Exception {
for (int precision = 1; precision <= PRECISION; precision++) {
SearchResponse response = client().prepareSearch("multi_valued_idx")
- .addAggregation(geohashGrid("geohashgrid").field("location").precision(precision))
+ .addAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").precision(precision))
.get();
assertSearchResponse(response);
@@ -208,8 +207,8 @@ public void testFiltered() throws Exception {
for (int precision = 1; precision <= PRECISION; precision++) {
SearchResponse response = client().prepareSearch("idx")
.addAggregation(
- AggregationBuilders.filter("filtered", bbox)
- .subAggregation(geohashGrid("geohashgrid").field("location").precision(precision))
+ org.opensearch.search.aggregations.AggregationBuilders.filter("filtered", bbox)
+ .subAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").precision(precision))
)
.get();
@@ -233,7 +232,7 @@ public void testFiltered() throws Exception {
public void testUnmapped() throws Exception {
for (int precision = 1; precision <= PRECISION; precision++) {
SearchResponse response = client().prepareSearch("idx_unmapped")
- .addAggregation(geohashGrid("geohashgrid").field("location").precision(precision))
+ .addAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").precision(precision))
.get();
assertSearchResponse(response);
@@ -247,7 +246,7 @@ public void testUnmapped() throws Exception {
public void testPartiallyUnmapped() throws Exception {
for (int precision = 1; precision <= PRECISION; precision++) {
SearchResponse response = client().prepareSearch("idx", "idx_unmapped")
- .addAggregation(geohashGrid("geohashgrid").field("location").precision(precision))
+ .addAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").precision(precision))
.get();
assertSearchResponse(response);
@@ -267,7 +266,9 @@ public void testPartiallyUnmapped() throws Exception {
public void testTopMatch() throws Exception {
for (int precision = 1; precision <= PRECISION; precision++) {
SearchResponse response = client().prepareSearch("idx")
- .addAggregation(geohashGrid("geohashgrid").field("location").size(1).shardSize(100).precision(precision))
+ .addAggregation(
+ AggregationBuilders.geohashGrid("geohashgrid").field("location").size(1).shardSize(100).precision(precision)
+ )
.get();
assertSearchResponse(response);
@@ -296,7 +297,7 @@ public void testSizeIsZero() {
IllegalArgumentException exception = expectThrows(
IllegalArgumentException.class,
() -> client().prepareSearch("idx")
- .addAggregation(geohashGrid("geohashgrid").field("location").size(size).shardSize(shardSize))
+ .addAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").size(size).shardSize(shardSize))
.get()
);
assertThat(exception.getMessage(), containsString("[size] must be greater than 0. Found [0] in [geohashgrid]"));
@@ -308,7 +309,7 @@ public void testShardSizeIsZero() {
IllegalArgumentException exception = expectThrows(
IllegalArgumentException.class,
() -> client().prepareSearch("idx")
- .addAggregation(geohashGrid("geohashgrid").field("location").size(size).shardSize(shardSize))
+ .addAggregation(AggregationBuilders.geohashGrid("geohashgrid").field("location").size(size).shardSize(shardSize))
.get()
);
assertThat(exception.getMessage(), containsString("[shardSize] must be greater than 0. Found [0] in [geohashgrid]"));
diff --git a/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/ShardReduceIT.java b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/ShardReduceIT.java
new file mode 100644
index 0000000000000..5b4dd052a2f65
--- /dev/null
+++ b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/bucket/ShardReduceIT.java
@@ -0,0 +1,107 @@
+/*
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * The OpenSearch Contributors require contributions made to
+ * this file be licensed under the Apache-2.0 license or a
+ * compatible open source license.
+ */
+
+package org.opensearch.geo.search.aggregations.bucket;
+
+import org.opensearch.action.index.IndexRequestBuilder;
+import org.opensearch.action.search.SearchResponse;
+import org.opensearch.geo.GeoModulePluginIntegTestCase;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoGrid;
+import org.opensearch.geo.tests.common.AggregationBuilders;
+import org.opensearch.geometry.utils.Geohash;
+import org.opensearch.index.query.QueryBuilders;
+import org.opensearch.search.aggregations.bucket.histogram.DateHistogramInterval;
+import org.opensearch.search.aggregations.bucket.histogram.Histogram;
+import org.opensearch.test.OpenSearchIntegTestCase;
+
+import static org.hamcrest.Matchers.equalTo;
+import static org.opensearch.common.xcontent.XContentFactory.jsonBuilder;
+import static org.opensearch.search.aggregations.AggregationBuilders.dateHistogram;
+import static org.opensearch.test.hamcrest.OpenSearchAssertions.assertAcked;
+import static org.opensearch.test.hamcrest.OpenSearchAssertions.assertSearchResponse;
+
+/**
+ * Tests making sure that the reduce is propagated to all aggregations in the hierarchy when executing on a single shard
+ * These tests are based on the date histogram in combination of min_doc_count=0. In order for the date histogram to
+ * compute empty buckets, its {@code reduce()} method must be called. So by adding the date histogram under other buckets,
+ * we can make sure that the reduce is properly propagated by checking that empty buckets were created.
+ */
+@OpenSearchIntegTestCase.SuiteScopeTestCase
+public class ShardReduceIT extends GeoModulePluginIntegTestCase {
+
+ private IndexRequestBuilder indexDoc(String date, int value) throws Exception {
+ return client().prepareIndex("idx")
+ .setSource(
+ jsonBuilder().startObject()
+ .field("value", value)
+ .field("ip", "10.0.0." + value)
+ .field("location", Geohash.stringEncode(5, 52, Geohash.PRECISION))
+ .field("date", date)
+ .field("term-l", 1)
+ .field("term-d", 1.5)
+ .field("term-s", "term")
+ .startObject("nested")
+ .field("date", date)
+ .endObject()
+ .endObject()
+ );
+ }
+
+ @Override
+ public void setupSuiteScopeCluster() throws Exception {
+ assertAcked(
+ prepareCreate("idx").setMapping(
+ "nested",
+ "type=nested",
+ "ip",
+ "type=ip",
+ "location",
+ "type=geo_point",
+ "term-s",
+ "type=keyword"
+ )
+ );
+
+ indexRandom(true, indexDoc("2014-01-01", 1), indexDoc("2014-01-02", 2), indexDoc("2014-01-04", 3));
+ ensureSearchable();
+ }
+
+ public void testGeoHashGrid() throws Exception {
+ SearchResponse response = client().prepareSearch("idx")
+ .setQuery(QueryBuilders.matchAllQuery())
+ .addAggregation(
+ AggregationBuilders.geohashGrid("grid")
+ .field("location")
+ .subAggregation(dateHistogram("histo").field("date").fixedInterval(DateHistogramInterval.DAY).minDocCount(0))
+ )
+ .get();
+
+ assertSearchResponse(response);
+
+ GeoGrid grid = response.getAggregations().get("grid");
+ Histogram histo = grid.getBuckets().iterator().next().getAggregations().get("histo");
+ assertThat(histo.getBuckets().size(), equalTo(4));
+ }
+
+ public void testGeoTileGrid() throws Exception {
+ SearchResponse response = client().prepareSearch("idx")
+ .setQuery(QueryBuilders.matchAllQuery())
+ .addAggregation(
+ AggregationBuilders.geotileGrid("grid")
+ .field("location")
+ .subAggregation(dateHistogram("histo").field("date").fixedInterval(DateHistogramInterval.DAY).minDocCount(0))
+ )
+ .get();
+
+ assertSearchResponse(response);
+
+ GeoGrid grid = response.getAggregations().get("grid");
+ Histogram histo = grid.getBuckets().iterator().next().getAggregations().get("histo");
+ assertThat(histo.getBuckets().size(), equalTo(4));
+ }
+}
diff --git a/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/AbstractGeoAggregatorTestCaseModulePlugin.java b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/AbstractGeoAggregatorModulePluginTestCase.java
similarity index 99%
rename from modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/AbstractGeoAggregatorTestCaseModulePlugin.java
rename to modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/AbstractGeoAggregatorModulePluginTestCase.java
index 0065cca7d6101..92987d407f51d 100644
--- a/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/AbstractGeoAggregatorTestCaseModulePlugin.java
+++ b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/AbstractGeoAggregatorModulePluginTestCase.java
@@ -42,7 +42,7 @@
* to copy the code as we cannot depend on this class.
* GitHub issue
*/
-public abstract class AbstractGeoAggregatorTestCaseModulePlugin extends GeoModulePluginIntegTestCase {
+public abstract class AbstractGeoAggregatorModulePluginTestCase extends GeoModulePluginIntegTestCase {
protected static final String SINGLE_VALUED_FIELD_NAME = "geo_value";
protected static final String MULTI_VALUED_FIELD_NAME = "geo_values";
diff --git a/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoBoundsIT.java b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoBoundsITTestCase.java
similarity index 99%
rename from modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoBoundsIT.java
rename to modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoBoundsITTestCase.java
index 5cbd98a4936e4..8cc82da12d69a 100644
--- a/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoBoundsIT.java
+++ b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoBoundsITTestCase.java
@@ -57,7 +57,7 @@
import static org.opensearch.geo.tests.common.AggregationBuilders.geoBounds;
@OpenSearchIntegTestCase.SuiteScopeTestCase
-public class GeoBoundsIT extends AbstractGeoAggregatorTestCaseModulePlugin {
+public class GeoBoundsITTestCase extends AbstractGeoAggregatorModulePluginTestCase {
private static final String aggName = "geoBounds";
public void testSingleValuedField() throws Exception {
diff --git a/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoCentroidITTestCase.java b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoCentroidITTestCase.java
new file mode 100644
index 0000000000000..e6d45e27b8f70
--- /dev/null
+++ b/modules/geo/src/internalClusterTest/java/org/opensearch/geo/search/aggregations/metrics/GeoCentroidITTestCase.java
@@ -0,0 +1,84 @@
+/*
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * The OpenSearch Contributors require contributions made to
+ * this file be licensed under the Apache-2.0 license or a
+ * compatible open source license.
+ */
+
+/*
+ * Licensed to Elasticsearch under one or more contributor
+ * license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright
+ * ownership. Elasticsearch licenses this file to you under
+ * the Apache License, Version 2.0 (the "License"); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+/*
+ * Modifications Copyright OpenSearch Contributors. See
+ * GitHub history for details.
+ */
+
+package org.opensearch.geo.search.aggregations.metrics;
+
+import org.opensearch.action.search.SearchResponse;
+import org.opensearch.common.geo.GeoPoint;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoGrid;
+import org.opensearch.geo.tests.common.AggregationBuilders;
+import org.opensearch.search.aggregations.metrics.GeoCentroid;
+import org.opensearch.test.OpenSearchIntegTestCase;
+
+import java.util.List;
+
+import static org.hamcrest.Matchers.closeTo;
+import static org.hamcrest.Matchers.equalTo;
+import static org.hamcrest.Matchers.notNullValue;
+import static org.opensearch.search.aggregations.AggregationBuilders.geoCentroid;
+import static org.opensearch.test.hamcrest.OpenSearchAssertions.assertSearchResponse;
+
+@OpenSearchIntegTestCase.SuiteScopeTestCase
+public class GeoCentroidITTestCase extends AbstractGeoAggregatorModulePluginTestCase {
+ private static final String aggName = "geoCentroid";
+
+ public void testSingleValueFieldAsSubAggToGeohashGrid() throws Exception {
+ SearchResponse response = client().prepareSearch(HIGH_CARD_IDX_NAME)
+ .addAggregation(
+ AggregationBuilders.geohashGrid("geoGrid")
+ .field(SINGLE_VALUED_FIELD_NAME)
+ .subAggregation(geoCentroid(aggName).field(SINGLE_VALUED_FIELD_NAME))
+ )
+ .get();
+ assertSearchResponse(response);
+
+ GeoGrid grid = response.getAggregations().get("geoGrid");
+ assertThat(grid, notNullValue());
+ assertThat(grid.getName(), equalTo("geoGrid"));
+ List extends GeoGrid.Bucket> buckets = grid.getBuckets();
+ for (GeoGrid.Bucket cell : buckets) {
+ String geohash = cell.getKeyAsString();
+ GeoPoint expectedCentroid = expectedCentroidsForGeoHash.get(geohash);
+ GeoCentroid centroidAgg = cell.getAggregations().get(aggName);
+ assertThat(
+ "Geohash " + geohash + " has wrong centroid latitude ",
+ expectedCentroid.lat(),
+ closeTo(centroidAgg.centroid().lat(), GEOHASH_TOLERANCE)
+ );
+ assertThat(
+ "Geohash " + geohash + " has wrong centroid longitude",
+ expectedCentroid.lon(),
+ closeTo(centroidAgg.centroid().lon(), GEOHASH_TOLERANCE)
+ );
+ }
+ }
+}
diff --git a/modules/geo/src/main/java/org/opensearch/geo/GeoModulePlugin.java b/modules/geo/src/main/java/org/opensearch/geo/GeoModulePlugin.java
index 64aac66b7eef3..25dcf8db2c407 100644
--- a/modules/geo/src/main/java/org/opensearch/geo/GeoModulePlugin.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/GeoModulePlugin.java
@@ -32,6 +32,12 @@
package org.opensearch.geo;
+import org.opensearch.geo.search.aggregations.bucket.composite.GeoTileGridValuesSourceBuilder;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoHashGridAggregationBuilder;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoTileGridAggregator;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.InternalGeoHashGrid;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.InternalGeoTileGrid;
import org.opensearch.geo.search.aggregations.metrics.GeoBounds;
import org.opensearch.geo.search.aggregations.metrics.GeoBoundsAggregationBuilder;
import org.opensearch.geo.search.aggregations.metrics.InternalGeoBounds;
@@ -40,6 +46,7 @@
import org.opensearch.plugins.MapperPlugin;
import org.opensearch.plugins.Plugin;
import org.opensearch.plugins.SearchPlugin;
+import org.opensearch.search.aggregations.bucket.composite.CompositeAggregation;
import java.util.Collections;
import java.util.List;
@@ -57,11 +64,42 @@ public Map getMappers() {
*/
@Override
public List getAggregations() {
- final AggregationSpec spec = new AggregationSpec(
+ final AggregationSpec geoBounds = new AggregationSpec(
GeoBoundsAggregationBuilder.NAME,
GeoBoundsAggregationBuilder::new,
GeoBoundsAggregationBuilder.PARSER
).addResultReader(InternalGeoBounds::new).setAggregatorRegistrar(GeoBoundsAggregationBuilder::registerAggregators);
- return Collections.singletonList(spec);
+
+ final AggregationSpec geoHashGrid = new AggregationSpec(
+ GeoHashGridAggregationBuilder.NAME,
+ GeoHashGridAggregationBuilder::new,
+ GeoHashGridAggregationBuilder.PARSER
+ ).addResultReader(InternalGeoHashGrid::new).setAggregatorRegistrar(GeoHashGridAggregationBuilder::registerAggregators);
+
+ final AggregationSpec geoTileGrid = new AggregationSpec(
+ GeoTileGridAggregationBuilder.NAME,
+ GeoTileGridAggregationBuilder::new,
+ GeoTileGridAggregationBuilder.PARSER
+ ).addResultReader(InternalGeoTileGrid::new).setAggregatorRegistrar(GeoTileGridAggregationBuilder::registerAggregators);
+ return List.of(geoBounds, geoHashGrid, geoTileGrid);
+ }
+
+ /**
+ * Registering the {@link GeoTileGridAggregator} in the {@link CompositeAggregation}.
+ *
+ * @return a {@link List} of {@link CompositeAggregationSpec}
+ */
+ @Override
+ public List getCompositeAggregations() {
+ return Collections.singletonList(
+ new CompositeAggregationSpec(
+ GeoTileGridValuesSourceBuilder::register,
+ GeoTileGridValuesSourceBuilder.class,
+ GeoTileGridValuesSourceBuilder.COMPOSITE_AGGREGATION_SERIALISATION_BYTE_CODE,
+ GeoTileGridValuesSourceBuilder::new,
+ GeoTileGridValuesSourceBuilder::parse,
+ GeoTileGridValuesSourceBuilder.TYPE
+ )
+ );
}
}
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java
similarity index 87%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java
index 4b01a08d29a43..84d5943da287f 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridValuesSourceBuilder.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.composite;
+package org.opensearch.geo.search.aggregations.bucket.composite;
import org.apache.lucene.index.IndexReader;
import org.opensearch.LegacyESVersion;
@@ -43,12 +43,15 @@
import org.opensearch.common.xcontent.ObjectParser;
import org.opensearch.common.xcontent.XContentBuilder;
import org.opensearch.common.xcontent.XContentParser;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.CellIdSource;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
import org.opensearch.index.mapper.MappedFieldType;
import org.opensearch.index.query.QueryShardContext;
import org.opensearch.search.DocValueFormat;
-import org.opensearch.search.aggregations.bucket.geogrid.CellIdSource;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils;
+import org.opensearch.search.aggregations.bucket.composite.CompositeValuesSourceBuilder;
+import org.opensearch.search.aggregations.bucket.composite.CompositeValuesSourceConfig;
+import org.opensearch.search.aggregations.bucket.composite.CompositeValuesSourceParserHelper;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import org.opensearch.search.aggregations.bucket.missing.MissingOrder;
import org.opensearch.search.aggregations.support.CoreValuesSourceType;
import org.opensearch.search.aggregations.support.ValuesSource;
@@ -88,13 +91,19 @@ CompositeValuesSourceConfig apply(
);
}
- static final String TYPE = "geotile_grid";
+ public static final String TYPE = "geotile_grid";
+ /*
+ use the TYPE parameter instead of Byte code. The byte code is added for backward compatibility and will be
+ removed in the next version.
+ */
+ @Deprecated
+ public static final Byte COMPOSITE_AGGREGATION_SERIALISATION_BYTE_CODE = 3;
static final ValuesSourceRegistry.RegistryKey REGISTRY_KEY = new ValuesSourceRegistry.RegistryKey(
TYPE,
GeoTileCompositeSuppier.class
);
- private static final ObjectParser PARSER;
+ static final ObjectParser PARSER;
static {
PARSER = new ObjectParser<>(GeoTileGridValuesSourceBuilder.TYPE);
PARSER.declareInt(GeoTileGridValuesSourceBuilder::precision, new ParseField("precision"));
@@ -106,11 +115,11 @@ CompositeValuesSourceConfig apply(
CompositeValuesSourceParserHelper.declareValuesSourceFields(PARSER);
}
- static GeoTileGridValuesSourceBuilder parse(String name, XContentParser parser) throws IOException {
+ public static GeoTileGridValuesSourceBuilder parse(String name, XContentParser parser) throws IOException {
return PARSER.parse(parser, new GeoTileGridValuesSourceBuilder(name), null);
}
- static void register(ValuesSourceRegistry.Builder builder) {
+ public static void register(ValuesSourceRegistry.Builder builder) {
builder.register(
REGISTRY_KEY,
@@ -163,7 +172,7 @@ static void register(ValuesSourceRegistry.Builder builder) {
super(name);
}
- GeoTileGridValuesSourceBuilder(StreamInput in) throws IOException {
+ public GeoTileGridValuesSourceBuilder(StreamInput in) throws IOException {
super(in);
this.precision = in.readInt();
if (in.getVersion().onOrAfter(LegacyESVersion.V_7_6_0)) {
@@ -203,7 +212,7 @@ protected void doXContentBody(XContentBuilder builder, Params params) throws IOE
}
@Override
- String type() {
+ protected String type() {
return TYPE;
}
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/composite/GeoTileValuesSource.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileValuesSource.java
similarity index 88%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/composite/GeoTileValuesSource.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileValuesSource.java
index 819dfc573bbe4..303e577e99e7b 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/composite/GeoTileValuesSource.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileValuesSource.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.composite;
+package org.opensearch.geo.search.aggregations.bucket.composite;
import org.apache.lucene.index.LeafReaderContext;
import org.apache.lucene.index.SortedNumericDocValues;
@@ -38,7 +38,9 @@
import org.opensearch.common.util.BigArrays;
import org.opensearch.index.mapper.MappedFieldType;
import org.opensearch.search.DocValueFormat;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils;
+import org.opensearch.search.aggregations.bucket.composite.LongValuesSource;
+import org.opensearch.search.aggregations.bucket.composite.SingleDimensionValuesSource;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import org.opensearch.search.aggregations.bucket.missing.MissingOrder;
import java.io.IOException;
@@ -68,7 +70,7 @@ class GeoTileValuesSource extends LongValuesSource {
}
@Override
- void setAfter(Comparable value) {
+ protected void setAfter(Comparable value) {
if (missingBucket && value == null) {
afterValue = null;
} else if (value instanceof Number) {
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/BoundedCellValues.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/BoundedCellValues.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/BoundedCellValues.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/BoundedCellValues.java
index ba824fc8f21dd..06d2dcaee3932 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/BoundedCellValues.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/BoundedCellValues.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoBoundingBox;
import org.opensearch.index.fielddata.MultiGeoPointValues;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/BucketPriorityQueue.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/BucketPriorityQueue.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/BucketPriorityQueue.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/BucketPriorityQueue.java
index d6cfde0c46eae..70d0552b3e80b 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/BucketPriorityQueue.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/BucketPriorityQueue.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.apache.lucene.util.PriorityQueue;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/CellIdSource.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/CellIdSource.java
similarity index 98%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/CellIdSource.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/CellIdSource.java
index 12d9043a2fd5f..d40029e9a762d 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/CellIdSource.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/CellIdSource.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.apache.lucene.index.LeafReaderContext;
import org.apache.lucene.index.SortedNumericDocValues;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/CellValues.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/CellValues.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/CellValues.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/CellValues.java
index 9dc357659aae8..d01896c8136fa 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/CellValues.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/CellValues.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.index.fielddata.AbstractSortingNumericDocValues;
import org.opensearch.index.fielddata.MultiGeoPointValues;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGrid.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGrid.java
index cfdb08f9ee3d7..4ae888640efc8 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGrid.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.search.aggregations.bucket.MultiBucketsAggregation;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java
similarity index 99%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java
index b08c40268c5cf..4a904b3aa2b16 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGridAggregationBuilder.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.LegacyESVersion;
import org.opensearch.OpenSearchException;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGridAggregator.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGridAggregator.java
similarity index 99%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGridAggregator.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGridAggregator.java
index 1ef8ba6c697f4..909772c61a960 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoGridAggregator.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoGridAggregator.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.apache.lucene.index.LeafReaderContext;
import org.apache.lucene.index.SortedNumericDocValues;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java
index 4049bf2c73640..bbaf9613fb216 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregationBuilder.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoBoundingBox;
import org.opensearch.common.geo.GeoUtils;
@@ -40,7 +40,7 @@
import org.opensearch.search.aggregations.AggregationBuilder;
import org.opensearch.search.aggregations.AggregatorFactories;
import org.opensearch.search.aggregations.AggregatorFactory;
-import org.opensearch.search.aggregations.metrics.GeoGridAggregatorSupplier;
+import org.opensearch.geo.search.aggregations.metrics.GeoGridAggregatorSupplier;
import org.opensearch.search.aggregations.support.ValuesSourceAggregatorFactory;
import org.opensearch.search.aggregations.support.ValuesSourceConfig;
import org.opensearch.search.aggregations.support.ValuesSourceRegistry;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java
index 1106320c7431f..6ca7a4d8a9cb8 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregator.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.search.aggregations.Aggregator;
import org.opensearch.search.aggregations.AggregatorFactories;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java
similarity index 98%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java
index cdc801aaedffb..1914c07e831f7 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoHashGridAggregatorFactory.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoBoundingBox;
import org.opensearch.geometry.utils.Geohash;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java
similarity index 95%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java
index f73360e3cb826..76ad515f34fe5 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregationBuilder.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoBoundingBox;
import org.opensearch.common.io.stream.StreamInput;
@@ -39,7 +39,8 @@
import org.opensearch.search.aggregations.AggregationBuilder;
import org.opensearch.search.aggregations.AggregatorFactories;
import org.opensearch.search.aggregations.AggregatorFactory;
-import org.opensearch.search.aggregations.metrics.GeoGridAggregatorSupplier;
+import org.opensearch.geo.search.aggregations.metrics.GeoGridAggregatorSupplier;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import org.opensearch.search.aggregations.support.ValuesSourceAggregatorFactory;
import org.opensearch.search.aggregations.support.ValuesSourceConfig;
import org.opensearch.search.aggregations.support.ValuesSourceRegistry;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java
index 7a2b908148c4c..a205a9afde41e 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregator.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.search.aggregations.Aggregator;
import org.opensearch.search.aggregations.AggregatorFactories;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java
index ef8cd11a22498..b830988a3d410 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/GeoTileGridAggregatorFactory.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoBoundingBox;
import org.opensearch.index.query.QueryShardContext;
@@ -40,6 +40,7 @@
import org.opensearch.search.aggregations.CardinalityUpperBound;
import org.opensearch.search.aggregations.InternalAggregation;
import org.opensearch.search.aggregations.NonCollectingAggregator;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import org.opensearch.search.aggregations.support.CoreValuesSourceType;
import org.opensearch.search.aggregations.support.ValuesSource;
import org.opensearch.search.aggregations.support.ValuesSourceAggregatorFactory;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoGrid.java
similarity index 99%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoGrid.java
index 94a5ad5717854..9dbed7b27307a 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoGrid.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.common.io.stream.StreamOutput;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java
similarity index 98%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java
index a187bfefb661f..93fcdbd098400 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoGridBucket.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.common.io.stream.StreamOutput;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java
index 7811b8774d04f..ff1247300939a 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoHashGrid.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.search.aggregations.InternalAggregations;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java
index f9c45dc41ceb1..659909e868651 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoHashGridBucket.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.io.stream.StreamInput;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java
index efbd9a05d6a4d..fa544b5893f0c 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoTileGrid.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.search.aggregations.InternalAggregations;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java
similarity index 94%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java
index f200f55232e00..65d736cfceb32 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/InternalGeoTileGridBucket.java
@@ -30,11 +30,12 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.search.aggregations.InternalAggregations;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import java.io.IOException;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoGrid.java
similarity index 97%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoGrid.java
index 3f85cf350c89c..adfffeddba59d 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoGrid.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.CheckedFunction;
import org.opensearch.common.xcontent.ObjectParser;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java
index 08e5c15188ee6..80124cda50b19 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoGridBucket.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.xcontent.XContentBuilder;
import org.opensearch.search.aggregations.Aggregation;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java
index f20f972c1ce0a..109524e755c4d 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoHashGrid.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.xcontent.ObjectParser;
import org.opensearch.common.xcontent.XContentParser;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java
index 05c7a1c8d1663..4e6e454b08324 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoHashGridBucket.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.xcontent.XContentParser;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java
index 06915cc4210e1..8734c96a15578 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoTileGrid.java
@@ -30,7 +30,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.xcontent.ObjectParser;
import org.opensearch.common.xcontent.XContentParser;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java
similarity index 93%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java
index c8dec16f322ef..fd47c35f13de1 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/ParsedGeoTileGridBucket.java
@@ -30,10 +30,11 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.xcontent.XContentParser;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import java.io.IOException;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/UnboundedCellValues.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/UnboundedCellValues.java
similarity index 96%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/UnboundedCellValues.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/UnboundedCellValues.java
index f5a139cdb8d9d..c628c7bfdc8ec 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/UnboundedCellValues.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/UnboundedCellValues.java
@@ -29,7 +29,7 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
import org.opensearch.common.geo.GeoBoundingBox;
import org.opensearch.index.fielddata.MultiGeoPointValues;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/package-info.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/package-info.java
similarity index 79%
rename from server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/package-info.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/package-info.java
index c59685e06cf79..d9183a0f742ef 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/bucket/geogrid/package-info.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/bucket/geogrid/package-info.java
@@ -7,4 +7,4 @@
*/
/** geo_grid Aggregation package. */
-package org.opensearch.search.aggregations.bucket.geogrid;
+package org.opensearch.geo.search.aggregations.bucket.geogrid;
diff --git a/server/src/main/java/org/opensearch/search/aggregations/metrics/GeoGridAggregatorSupplier.java b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/metrics/GeoGridAggregatorSupplier.java
similarity index 93%
rename from server/src/main/java/org/opensearch/search/aggregations/metrics/GeoGridAggregatorSupplier.java
rename to modules/geo/src/main/java/org/opensearch/geo/search/aggregations/metrics/GeoGridAggregatorSupplier.java
index 183c64f4e4af2..43ccb8b89545a 100644
--- a/server/src/main/java/org/opensearch/search/aggregations/metrics/GeoGridAggregatorSupplier.java
+++ b/modules/geo/src/main/java/org/opensearch/geo/search/aggregations/metrics/GeoGridAggregatorSupplier.java
@@ -30,13 +30,13 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.metrics;
+package org.opensearch.geo.search.aggregations.metrics;
import org.opensearch.common.geo.GeoBoundingBox;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoGridAggregator;
import org.opensearch.search.aggregations.Aggregator;
import org.opensearch.search.aggregations.AggregatorFactories;
import org.opensearch.search.aggregations.CardinalityUpperBound;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoGridAggregator;
import org.opensearch.search.aggregations.support.ValuesSource;
import org.opensearch.search.internal.SearchContext;
diff --git a/server/src/test/java/org/opensearch/search/aggregations/bucket/GeoHashGridTests.java b/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridAggregationBuilderTests.java
similarity index 83%
rename from server/src/test/java/org/opensearch/search/aggregations/bucket/GeoHashGridTests.java
rename to modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridAggregationBuilderTests.java
index b85761b709105..559a21870e919 100644
--- a/server/src/test/java/org/opensearch/search/aggregations/bucket/GeoHashGridTests.java
+++ b/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoHashGridAggregationBuilderTests.java
@@ -30,27 +30,35 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket;
+package org.opensearch.geo.search.aggregations.bucket;
import org.opensearch.LegacyESVersion;
import org.opensearch.Version;
import org.opensearch.common.geo.GeoBoundingBox;
-import org.opensearch.common.geo.GeoBoundingBoxTests;
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.io.stream.BytesStreamOutput;
import org.opensearch.common.io.stream.NamedWriteableAwareStreamInput;
import org.opensearch.common.io.stream.NamedWriteableRegistry;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.search.aggregations.BaseAggregationTestCase;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoHashGridAggregationBuilder;
import org.opensearch.test.VersionUtils;
import java.util.Collections;
import static org.hamcrest.Matchers.equalTo;
+import org.opensearch.geo.GeoModulePlugin;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoGridAggregationBuilder;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoHashGridAggregationBuilder;
+import org.opensearch.geo.tests.common.RandomGeoGenerator;
+import org.opensearch.plugins.Plugin;
-public class GeoHashGridTests extends BaseAggregationTestCase {
+import java.util.Collection;
+
+public class GeoHashGridAggregationBuilderTests extends BaseAggregationTestCase {
+
+ protected Collection> getPlugins() {
+ return Collections.singletonList(GeoModulePlugin.class);
+ }
@Override
protected GeoHashGridAggregationBuilder createTestAggregatorBuilder() {
@@ -68,7 +76,7 @@ protected GeoHashGridAggregationBuilder createTestAggregatorBuilder() {
factory.shardSize(randomIntBetween(1, Integer.MAX_VALUE));
}
if (randomBoolean()) {
- factory.setGeoBoundingBox(GeoBoundingBoxTests.randomBBox());
+ factory.setGeoBoundingBox(RandomGeoGenerator.randomBBox());
}
return factory;
}
diff --git a/server/src/test/java/org/opensearch/search/aggregations/bucket/GeoTileGridTests.java b/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoTileGridAggregationBuilderTests.java
similarity index 81%
rename from server/src/test/java/org/opensearch/search/aggregations/bucket/GeoTileGridTests.java
rename to modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoTileGridAggregationBuilderTests.java
index 3564ea337f741..1681de25d9ade 100644
--- a/server/src/test/java/org/opensearch/search/aggregations/bucket/GeoTileGridTests.java
+++ b/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/GeoTileGridAggregationBuilderTests.java
@@ -30,28 +30,36 @@
* GitHub history for details.
*/
-package org.opensearch.search.aggregations.bucket;
+package org.opensearch.geo.search.aggregations.bucket;
import org.opensearch.LegacyESVersion;
import org.opensearch.Version;
import org.opensearch.common.geo.GeoBoundingBox;
-import org.opensearch.common.geo.GeoBoundingBoxTests;
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.common.io.stream.BytesStreamOutput;
import org.opensearch.common.io.stream.NamedWriteableAwareStreamInput;
import org.opensearch.common.io.stream.NamedWriteableRegistry;
import org.opensearch.common.io.stream.StreamInput;
import org.opensearch.search.aggregations.BaseAggregationTestCase;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils;
import org.opensearch.test.VersionUtils;
import java.util.Collections;
import static org.hamcrest.Matchers.equalTo;
+import org.opensearch.geo.GeoModulePlugin;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoGridAggregationBuilder;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
+import org.opensearch.geo.tests.common.RandomGeoGenerator;
+import org.opensearch.plugins.Plugin;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
-public class GeoTileGridTests extends BaseAggregationTestCase {
+import java.util.Collection;
+
+public class GeoTileGridAggregationBuilderTests extends BaseAggregationTestCase {
+
+ protected Collection> getPlugins() {
+ return Collections.singletonList(GeoModulePlugin.class);
+ }
@Override
protected GeoTileGridAggregationBuilder createTestAggregatorBuilder() {
@@ -68,7 +76,7 @@ protected GeoTileGridAggregationBuilder createTestAggregatorBuilder() {
factory.shardSize(randomIntBetween(1, Integer.MAX_VALUE));
}
if (randomBoolean()) {
- factory.setGeoBoundingBox(GeoBoundingBoxTests.randomBBox());
+ factory.setGeoBoundingBox(RandomGeoGenerator.randomBBox());
}
return factory;
}
diff --git a/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridAggregationCompositeAggregatorTests.java b/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridAggregationCompositeAggregatorTests.java
new file mode 100644
index 0000000000000..3c7c292f9d193
--- /dev/null
+++ b/modules/geo/src/test/java/org/opensearch/geo/search/aggregations/bucket/composite/GeoTileGridAggregationCompositeAggregatorTests.java
@@ -0,0 +1,174 @@
+/*
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * The OpenSearch Contributors require contributions made to
+ * this file be licensed under the Apache-2.0 license or a
+ * compatible open source license.
+ */
+
+package org.opensearch.geo.search.aggregations.bucket.composite;
+
+import org.apache.lucene.document.Document;
+import org.apache.lucene.document.LatLonPoint;
+import org.apache.lucene.document.SortedNumericDocValuesField;
+import org.apache.lucene.search.DocValuesFieldExistsQuery;
+import org.apache.lucene.search.MatchAllDocsQuery;
+import org.junit.Before;
+import org.opensearch.common.geo.GeoPoint;
+import org.opensearch.geo.GeoModulePlugin;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
+import org.opensearch.geo.search.aggregations.bucket.geogrid.GeoTileGridAggregator;
+import org.opensearch.index.mapper.GeoPointFieldMapper;
+import org.opensearch.plugins.SearchPlugin;
+import org.opensearch.search.aggregations.bucket.composite.CompositeAggregationBuilder;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
+import org.opensearch.search.aggregations.composite.BaseCompositeAggregatorTestCase;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * Testing the {@link GeoTileGridAggregator} as part of CompositeAggregation.
+ */
+public class GeoTileGridAggregationCompositeAggregatorTests extends BaseCompositeAggregatorTestCase {
+
+ protected List getSearchPlugins() {
+ return Collections.singletonList(new GeoModulePlugin());
+ }
+
+ @Override
+ @Before
+ public void setUp() throws Exception {
+ super.setUp();
+ FIELD_TYPES.add(new GeoPointFieldMapper.GeoPointFieldType("geo_point"));
+ }
+
+ public void testUnmappedFieldWithGeopoint() throws Exception {
+ final List
*
diff --git a/server/src/test/java/org/opensearch/search/DocValueFormatTests.java b/server/src/test/java/org/opensearch/search/DocValueFormatTests.java
index 36a6eb3ae87b0..bd0fbfe69960c 100644
--- a/server/src/test/java/org/opensearch/search/DocValueFormatTests.java
+++ b/server/src/test/java/org/opensearch/search/DocValueFormatTests.java
@@ -48,7 +48,7 @@
import java.util.ArrayList;
import java.util.List;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.longEncode;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.longEncode;
public class DocValueFormatTests extends OpenSearchTestCase {
diff --git a/server/src/test/java/org/opensearch/search/aggregations/AggregationsTests.java b/server/src/test/java/org/opensearch/search/aggregations/AggregationsTests.java
index 111ce23f8a0cb..94fb6cded637d 100644
--- a/server/src/test/java/org/opensearch/search/aggregations/AggregationsTests.java
+++ b/server/src/test/java/org/opensearch/search/aggregations/AggregationsTests.java
@@ -48,8 +48,6 @@
import org.opensearch.search.aggregations.bucket.composite.InternalCompositeTests;
import org.opensearch.search.aggregations.bucket.filter.InternalFilterTests;
import org.opensearch.search.aggregations.bucket.filter.InternalFiltersTests;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoHashGridTests;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileGridTests;
import org.opensearch.search.aggregations.bucket.global.InternalGlobalTests;
import org.opensearch.search.aggregations.bucket.histogram.InternalAutoDateHistogramTests;
import org.opensearch.search.aggregations.bucket.histogram.InternalDateHistogramTests;
@@ -157,8 +155,6 @@ private static List> getAggsTests() {
aggsTests.add(new InternalGlobalTests());
aggsTests.add(new InternalFilterTests());
aggsTests.add(new InternalSamplerTests());
- aggsTests.add(new GeoHashGridTests());
- aggsTests.add(new GeoTileGridTests());
aggsTests.add(new InternalRangeTests());
aggsTests.add(new InternalDateRangeTests());
aggsTests.add(new InternalGeoDistanceTests());
diff --git a/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregationBuilderTests.java b/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregationBuilderTests.java
index c4a87f3993bb4..9290183ec7312 100644
--- a/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregationBuilderTests.java
+++ b/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregationBuilderTests.java
@@ -32,10 +32,8 @@
package org.opensearch.search.aggregations.bucket.composite;
-import org.opensearch.common.geo.GeoBoundingBoxTests;
import org.opensearch.script.Script;
import org.opensearch.search.aggregations.BaseAggregationTestCase;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils;
import org.opensearch.search.aggregations.bucket.histogram.DateHistogramInterval;
import org.opensearch.search.aggregations.bucket.missing.MissingOrder;
import org.opensearch.search.sort.SortOrder;
@@ -74,17 +72,6 @@ private DateHistogramValuesSourceBuilder randomDateHistogramSourceBuilder() {
return histo;
}
- private GeoTileGridValuesSourceBuilder randomGeoTileGridValuesSourceBuilder() {
- GeoTileGridValuesSourceBuilder geoTile = new GeoTileGridValuesSourceBuilder(randomAlphaOfLengthBetween(5, 10));
- if (randomBoolean()) {
- geoTile.precision(randomIntBetween(0, GeoTileUtils.MAX_ZOOM));
- }
- if (randomBoolean()) {
- geoTile.geoBoundingBox(GeoBoundingBoxTests.randomBBox());
- }
- return geoTile;
- }
-
private TermsValuesSourceBuilder randomTermsSourceBuilder() {
TermsValuesSourceBuilder terms = new TermsValuesSourceBuilder(randomAlphaOfLengthBetween(5, 10));
if (randomBoolean()) {
@@ -118,11 +105,9 @@ private HistogramValuesSourceBuilder randomHistogramSourceBuilder() {
@Override
protected CompositeAggregationBuilder createTestAggregatorBuilder() {
int numSources = randomIntBetween(1, 10);
- numSources = 1;
List> sources = new ArrayList<>();
for (int i = 0; i < numSources; i++) {
- int type = randomIntBetween(0, 3);
- type = 3;
+ int type = randomIntBetween(0, 2);
switch (type) {
case 0:
sources.add(randomTermsSourceBuilder());
@@ -133,9 +118,6 @@ protected CompositeAggregationBuilder createTestAggregatorBuilder() {
case 2:
sources.add(randomHistogramSourceBuilder());
break;
- case 3:
- sources.add(randomGeoTileGridValuesSourceBuilder());
- break;
default:
throw new AssertionError("wrong branch");
}
diff --git a/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregatorTests.java b/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregatorTests.java
index 88b2323b8adfc..25003e0b84567 100644
--- a/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregatorTests.java
+++ b/server/src/test/java/org/opensearch/search/aggregations/bucket/composite/CompositeAggregatorTests.java
@@ -32,68 +32,24 @@
package org.opensearch.search.aggregations.bucket.composite;
-import org.apache.lucene.tests.analysis.MockAnalyzer;
-import org.apache.lucene.document.Document;
-import org.apache.lucene.document.DoublePoint;
-import org.apache.lucene.document.Field;
-import org.apache.lucene.document.InetAddressPoint;
-import org.apache.lucene.document.IntPoint;
-import org.apache.lucene.document.LatLonPoint;
import org.apache.lucene.document.LongPoint;
-import org.apache.lucene.document.SortedNumericDocValuesField;
-import org.apache.lucene.document.SortedSetDocValuesField;
-import org.apache.lucene.document.StringField;
-import org.apache.lucene.index.DirectoryReader;
-import org.apache.lucene.index.IndexReader;
-import org.apache.lucene.index.IndexWriterConfig;
-import org.apache.lucene.tests.index.RandomIndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.DocValuesFieldExistsQuery;
-import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.MatchAllDocsQuery;
-import org.apache.lucene.search.Query;
-import org.apache.lucene.search.Sort;
-import org.apache.lucene.search.SortField;
-import org.apache.lucene.search.SortedNumericSortField;
-import org.apache.lucene.search.SortedSetSortField;
import org.apache.lucene.search.TermQuery;
-import org.apache.lucene.store.Directory;
-import org.apache.lucene.util.BytesRef;
-import org.apache.lucene.util.NumericUtils;
-import org.apache.lucene.tests.util.TestUtil;
import org.opensearch.OpenSearchParseException;
-import org.opensearch.common.geo.GeoPoint;
-import org.opensearch.common.settings.Settings;
-import org.opensearch.common.text.Text;
-import org.opensearch.common.time.DateFormatter;
-import org.opensearch.common.time.DateFormatters;
-import org.opensearch.index.Index;
-import org.opensearch.index.IndexSettings;
-import org.opensearch.index.mapper.DateFieldMapper;
-import org.opensearch.index.mapper.DocumentMapper;
-import org.opensearch.index.mapper.GeoPointFieldMapper;
-import org.opensearch.index.mapper.IpFieldMapper;
-import org.opensearch.index.mapper.KeywordFieldMapper;
-import org.opensearch.index.mapper.MappedFieldType;
-import org.opensearch.index.mapper.MapperService;
-import org.opensearch.index.mapper.NumberFieldMapper;
import org.opensearch.search.aggregations.Aggregator;
-import org.opensearch.search.aggregations.AggregatorTestCase;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils;
import org.opensearch.search.aggregations.bucket.histogram.DateHistogramInterval;
import org.opensearch.search.aggregations.bucket.missing.MissingOrder;
import org.opensearch.search.aggregations.bucket.terms.StringTerms;
import org.opensearch.search.aggregations.bucket.terms.TermsAggregationBuilder;
+import org.opensearch.search.aggregations.composite.BaseCompositeAggregatorTestCase;
import org.opensearch.search.aggregations.metrics.InternalMax;
import org.opensearch.search.aggregations.metrics.MaxAggregationBuilder;
import org.opensearch.search.aggregations.metrics.TopHits;
import org.opensearch.search.aggregations.metrics.TopHitsAggregationBuilder;
import org.opensearch.search.aggregations.support.ValueType;
import org.opensearch.search.sort.SortOrder;
-import org.opensearch.test.IndexSettingsModule;
-import org.junit.After;
-import org.junit.Before;
import java.io.IOException;
import java.net.InetAddress;
@@ -109,51 +65,14 @@
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicLong;
-import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Supplier;
-import java.util.stream.Collectors;
import static org.hamcrest.Matchers.containsString;
import static org.hamcrest.Matchers.equalTo;
import static org.hamcrest.Matchers.instanceOf;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.when;
-
-public class CompositeAggregatorTests extends AggregatorTestCase {
- private static MappedFieldType[] FIELD_TYPES;
-
- @Override
- @Before
- public void setUp() throws Exception {
- super.setUp();
- FIELD_TYPES = new MappedFieldType[8];
- FIELD_TYPES[0] = new KeywordFieldMapper.KeywordFieldType("keyword");
- FIELD_TYPES[1] = new NumberFieldMapper.NumberFieldType("long", NumberFieldMapper.NumberType.LONG);
- FIELD_TYPES[2] = new NumberFieldMapper.NumberFieldType("double", NumberFieldMapper.NumberType.DOUBLE);
- FIELD_TYPES[3] = new DateFieldMapper.DateFieldType("date", DateFormatter.forPattern("yyyy-MM-dd||epoch_millis"));
- FIELD_TYPES[4] = new NumberFieldMapper.NumberFieldType("price", NumberFieldMapper.NumberType.INTEGER);
- FIELD_TYPES[5] = new KeywordFieldMapper.KeywordFieldType("terms");
- FIELD_TYPES[6] = new IpFieldMapper.IpFieldType("ip");
- FIELD_TYPES[7] = new GeoPointFieldMapper.GeoPointFieldType("geo_point");
- }
-
- @Override
- @After
- public void tearDown() throws Exception {
- super.tearDown();
- FIELD_TYPES = null;
- }
- @Override
- protected MapperService mapperServiceMock() {
- MapperService mapperService = mock(MapperService.class);
- DocumentMapper mapper = mock(DocumentMapper.class);
- when(mapper.typeText()).thenReturn(new Text("_doc"));
- when(mapper.type()).thenReturn("_doc");
- when(mapperService.documentMapper()).thenReturn(mapper);
- return mapperService;
- }
+public class CompositeAggregatorTests extends BaseCompositeAggregatorTestCase {
public void testUnmappedFieldWithTerms() throws Exception {
final List>> dataset = new ArrayList<>();
@@ -234,80 +153,6 @@ public void testUnmappedFieldWithTerms() throws Exception {
);
}
- public void testUnmappedFieldWithGeopoint() throws Exception {
- final List>> dataset = new ArrayList<>();
- final String mappedFieldName = "geo_point";
- dataset.addAll(
- Arrays.asList(
- createDocument(mappedFieldName, new GeoPoint(48.934059, 41.610741)),
- createDocument(mappedFieldName, new GeoPoint(-23.065941, 113.610741)),
- createDocument(mappedFieldName, new GeoPoint(90.0, 0.0)),
- createDocument(mappedFieldName, new GeoPoint(37.2343, -115.8067)),
- createDocument(mappedFieldName, new GeoPoint(90.0, 0.0))
- )
- );
-
- // just unmapped = no results
- testSearchCase(
- Arrays.asList(new MatchAllDocsQuery(), new DocValuesFieldExistsQuery(mappedFieldName)),
- dataset,
- () -> new CompositeAggregationBuilder("name", Arrays.asList(new GeoTileGridValuesSourceBuilder("unmapped").field("unmapped"))),
- (result) -> assertEquals(0, result.getBuckets().size())
- );
-
- // unmapped missing bucket = one result
- testSearchCase(
- Arrays.asList(new MatchAllDocsQuery(), new DocValuesFieldExistsQuery(mappedFieldName)),
- dataset,
- () -> new CompositeAggregationBuilder(
- "name",
- Arrays.asList(new GeoTileGridValuesSourceBuilder("unmapped").field("unmapped").missingBucket(true))
- ),
- (result) -> {
- assertEquals(1, result.getBuckets().size());
- assertEquals("{unmapped=null}", result.afterKey().toString());
- assertEquals("{unmapped=null}", result.getBuckets().get(0).getKeyAsString());
- assertEquals(5L, result.getBuckets().get(0).getDocCount());
- }
- );
-
- // field + unmapped, no missing bucket = no results
- testSearchCase(
- Arrays.asList(new MatchAllDocsQuery(), new DocValuesFieldExistsQuery(mappedFieldName)),
- dataset,
- () -> new CompositeAggregationBuilder(
- "name",
- Arrays.asList(
- new GeoTileGridValuesSourceBuilder(mappedFieldName).field(mappedFieldName),
- new GeoTileGridValuesSourceBuilder("unmapped").field("unmapped")
- )
- ),
- (result) -> assertEquals(0, result.getBuckets().size())
- );
-
- // field + unmapped with missing bucket = multiple results
- testSearchCase(
- Arrays.asList(new MatchAllDocsQuery(), new DocValuesFieldExistsQuery(mappedFieldName)),
- dataset,
- () -> new CompositeAggregationBuilder(
- "name",
- Arrays.asList(
- new GeoTileGridValuesSourceBuilder(mappedFieldName).field(mappedFieldName),
- new GeoTileGridValuesSourceBuilder("unmapped").field("unmapped").missingBucket(true)
- )
- ),
- (result) -> {
- assertEquals(2, result.getBuckets().size());
- assertEquals("{geo_point=7/64/56, unmapped=null}", result.afterKey().toString());
- assertEquals("{geo_point=7/32/56, unmapped=null}", result.getBuckets().get(0).getKeyAsString());
- assertEquals(2L, result.getBuckets().get(0).getDocCount());
- assertEquals("{geo_point=7/64/56, unmapped=null}", result.getBuckets().get(1).getKeyAsString());
- assertEquals(3L, result.getBuckets().get(1).getDocCount());
- }
- );
-
- }
-
public void testUnmappedFieldWithHistogram() throws Exception {
final List>> dataset = new ArrayList<>();
final String mappedFieldName = "price";
@@ -2483,42 +2328,6 @@ public void testWithIP() throws Exception {
});
}
- public void testWithGeoPoint() throws Exception {
- final List>> dataset = new ArrayList<>();
- dataset.addAll(
- Arrays.asList(
- createDocument("geo_point", new GeoPoint(48.934059, 41.610741)),
- createDocument("geo_point", new GeoPoint(-23.065941, 113.610741)),
- createDocument("geo_point", new GeoPoint(90.0, 0.0)),
- createDocument("geo_point", new GeoPoint(37.2343, -115.8067)),
- createDocument("geo_point", new GeoPoint(90.0, 0.0))
- )
- );
- testSearchCase(Arrays.asList(new MatchAllDocsQuery(), new DocValuesFieldExistsQuery("geo_point")), dataset, () -> {
- GeoTileGridValuesSourceBuilder geoTile = new GeoTileGridValuesSourceBuilder("geo_point").field("geo_point");
- return new CompositeAggregationBuilder("name", Collections.singletonList(geoTile));
- }, (result) -> {
- assertEquals(2, result.getBuckets().size());
- assertEquals("{geo_point=7/64/56}", result.afterKey().toString());
- assertEquals("{geo_point=7/32/56}", result.getBuckets().get(0).getKeyAsString());
- assertEquals(2L, result.getBuckets().get(0).getDocCount());
- assertEquals("{geo_point=7/64/56}", result.getBuckets().get(1).getKeyAsString());
- assertEquals(3L, result.getBuckets().get(1).getDocCount());
- });
-
- testSearchCase(Arrays.asList(new MatchAllDocsQuery(), new DocValuesFieldExistsQuery("geo_point")), dataset, () -> {
- GeoTileGridValuesSourceBuilder geoTile = new GeoTileGridValuesSourceBuilder("geo_point").field("geo_point");
- return new CompositeAggregationBuilder("name", Collections.singletonList(geoTile)).aggregateAfter(
- Collections.singletonMap("geo_point", "7/32/56")
- );
- }, (result) -> {
- assertEquals(1, result.getBuckets().size());
- assertEquals("{geo_point=7/64/56}", result.afterKey().toString());
- assertEquals("{geo_point=7/64/56}", result.getBuckets().get(0).getKeyAsString());
- assertEquals(3L, result.getBuckets().get(0).getDocCount());
- });
- }
-
public void testEarlyTermination() throws Exception {
final List>> dataset = new ArrayList<>();
dataset.addAll(
@@ -2648,193 +2457,4 @@ public void testIndexSortWithDuplicate() throws Exception {
);
}
}
-
- private void testSearchCase(
- List queries,
- List>> dataset,
- Supplier create,
- Consumer verify
- ) throws IOException {
- for (Query query : queries) {
- executeTestCase(false, false, query, dataset, create, verify);
- executeTestCase(false, true, query, dataset, create, verify);
- }
- }
-
- private void executeTestCase(
- boolean forceMerge,
- boolean useIndexSort,
- Query query,
- List>> dataset,
- Supplier create,
- Consumer verify
- ) throws IOException {
- Map types = Arrays.stream(FIELD_TYPES)
- .collect(Collectors.toMap(MappedFieldType::name, Function.identity()));
- CompositeAggregationBuilder aggregationBuilder = create.get();
- Sort indexSort = useIndexSort ? buildIndexSort(aggregationBuilder.sources(), types) : null;
- IndexSettings indexSettings = createIndexSettings(indexSort);
- try (Directory directory = newDirectory()) {
- IndexWriterConfig config = newIndexWriterConfig(random(), new MockAnalyzer(random()));
- if (indexSort != null) {
- config.setIndexSort(indexSort);
- config.setCodec(TestUtil.getDefaultCodec());
- }
- try (RandomIndexWriter indexWriter = new RandomIndexWriter(random(), directory, config)) {
- Document document = new Document();
- int id = 0;
- for (Map> fields : dataset) {
- document.clear();
- addToDocument(id, document, fields);
- indexWriter.addDocument(document);
- id++;
- }
- if (forceMerge || rarely()) {
- // forceMerge randomly or if the collector-per-leaf testing stuff would break the tests.
- indexWriter.forceMerge(1);
- } else {
- if (dataset.size() > 0) {
- int numDeletes = randomIntBetween(1, 25);
- for (int i = 0; i < numDeletes; i++) {
- id = randomIntBetween(0, dataset.size() - 1);
- indexWriter.deleteDocuments(new Term("id", Integer.toString(id)));
- document.clear();
- addToDocument(id, document, dataset.get(id));
- indexWriter.addDocument(document);
- }
- }
-
- }
- }
- try (IndexReader indexReader = DirectoryReader.open(directory)) {
- IndexSearcher indexSearcher = new IndexSearcher(indexReader);
- InternalComposite composite = searchAndReduce(indexSettings, indexSearcher, query, aggregationBuilder, FIELD_TYPES);
- verify.accept(composite);
- }
- }
- }
-
- private static IndexSettings createIndexSettings(Sort sort) {
- Settings.Builder builder = Settings.builder();
- if (sort != null) {
- String[] fields = Arrays.stream(sort.getSort()).map(SortField::getField).toArray(String[]::new);
- String[] orders = Arrays.stream(sort.getSort()).map((o) -> o.getReverse() ? "desc" : "asc").toArray(String[]::new);
- builder.putList("index.sort.field", fields);
- builder.putList("index.sort.order", orders);
- }
- return IndexSettingsModule.newIndexSettings(new Index("_index", "0"), builder.build());
- }
-
- private void addToDocument(int id, Document doc, Map> keys) {
- doc.add(new StringField("id", Integer.toString(id), Field.Store.NO));
- for (Map.Entry> entry : keys.entrySet()) {
- final String name = entry.getKey();
- for (Object value : entry.getValue()) {
- if (value instanceof Integer) {
- doc.add(new SortedNumericDocValuesField(name, (int) value));
- doc.add(new IntPoint(name, (int) value));
- } else if (value instanceof Long) {
- doc.add(new SortedNumericDocValuesField(name, (long) value));
- doc.add(new LongPoint(name, (long) value));
- } else if (value instanceof Double) {
- doc.add(new SortedNumericDocValuesField(name, NumericUtils.doubleToSortableLong((double) value)));
- doc.add(new DoublePoint(name, (double) value));
- } else if (value instanceof String) {
- doc.add(new SortedSetDocValuesField(name, new BytesRef((String) value)));
- doc.add(new StringField(name, new BytesRef((String) value), Field.Store.NO));
- } else if (value instanceof InetAddress) {
- doc.add(new SortedSetDocValuesField(name, new BytesRef(InetAddressPoint.encode((InetAddress) value))));
- doc.add(new InetAddressPoint(name, (InetAddress) value));
- } else if (value instanceof GeoPoint) {
- GeoPoint point = (GeoPoint) value;
- doc.add(
- new SortedNumericDocValuesField(
- name,
- GeoTileUtils.longEncode(point.lon(), point.lat(), GeoTileGridAggregationBuilder.DEFAULT_PRECISION)
- )
- );
- doc.add(new LatLonPoint(name, point.lat(), point.lon()));
- } else {
- throw new AssertionError("invalid object: " + value.getClass().getSimpleName());
- }
- }
- }
- }
-
- private static Map createAfterKey(Object... fields) {
- assert fields.length % 2 == 0;
- final Map map = new HashMap<>();
- for (int i = 0; i < fields.length; i += 2) {
- String field = (String) fields[i];
- map.put(field, fields[i + 1]);
- }
- return map;
- }
-
- @SuppressWarnings("unchecked")
- private static Map> createDocument(Object... fields) {
- assert fields.length % 2 == 0;
- final Map> map = new HashMap<>();
- for (int i = 0; i < fields.length; i += 2) {
- String field = (String) fields[i];
- if (fields[i + 1] instanceof List) {
- map.put(field, (List) fields[i + 1]);
- } else {
- map.put(field, Collections.singletonList(fields[i + 1]));
- }
- }
- return map;
- }
-
- private static long asLong(String dateTime) {
- return DateFormatters.from(DateFieldMapper.DEFAULT_DATE_TIME_FORMATTER.parse(dateTime)).toInstant().toEpochMilli();
- }
-
- private static Sort buildIndexSort(List> sources, Map fieldTypes) {
- List sortFields = new ArrayList<>();
- Map remainingFieldTypes = new HashMap<>(fieldTypes);
- for (CompositeValuesSourceBuilder> source : sources) {
- MappedFieldType type = fieldTypes.remove(source.field());
- remainingFieldTypes.remove(source.field());
- SortField sortField = sortFieldFrom(type);
- if (sortField == null) {
- break;
- }
- sortFields.add(sortField);
- }
- while (remainingFieldTypes.size() > 0 && randomBoolean()) {
- // Add extra unused sorts
- List fields = new ArrayList<>(remainingFieldTypes.keySet());
- Collections.sort(fields);
- String field = fields.get(between(0, fields.size() - 1));
- SortField sortField = sortFieldFrom(remainingFieldTypes.remove(field));
- if (sortField != null) {
- sortFields.add(sortField);
- }
- }
- return sortFields.size() > 0 ? new Sort(sortFields.toArray(new SortField[0])) : null;
- }
-
- private static SortField sortFieldFrom(MappedFieldType type) {
- if (type instanceof KeywordFieldMapper.KeywordFieldType) {
- return new SortedSetSortField(type.name(), false);
- } else if (type instanceof DateFieldMapper.DateFieldType) {
- return new SortedNumericSortField(type.name(), SortField.Type.LONG, false);
- } else if (type instanceof NumberFieldMapper.NumberFieldType) {
- switch (type.typeName()) {
- case "byte":
- case "short":
- case "integer":
- return new SortedNumericSortField(type.name(), SortField.Type.INT, false);
- case "long":
- return new SortedNumericSortField(type.name(), SortField.Type.LONG, false);
- case "float":
- case "double":
- return new SortedNumericSortField(type.name(), SortField.Type.DOUBLE, false);
- default:
- return null;
- }
- }
- return null;
- }
}
diff --git a/server/src/test/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileUtilsTests.java b/server/src/test/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileUtilsTests.java
index dfe4034650594..1443208a1d2fc 100644
--- a/server/src/test/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileUtilsTests.java
+++ b/server/src/test/java/org/opensearch/search/aggregations/bucket/geogrid/GeoTileUtilsTests.java
@@ -34,14 +34,15 @@
import org.opensearch.common.geo.GeoPoint;
import org.opensearch.geometry.Rectangle;
+import org.opensearch.search.aggregations.bucket.GeoTileUtils;
import org.opensearch.test.OpenSearchTestCase;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.MAX_ZOOM;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.checkPrecisionRange;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.hashToGeoPoint;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.keyToGeoPoint;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.longEncode;
-import static org.opensearch.search.aggregations.bucket.geogrid.GeoTileUtils.stringEncode;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.MAX_ZOOM;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.checkPrecisionRange;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.hashToGeoPoint;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.keyToGeoPoint;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.longEncode;
+import static org.opensearch.search.aggregations.bucket.GeoTileUtils.stringEncode;
import static org.hamcrest.Matchers.anyOf;
import static org.hamcrest.Matchers.closeTo;
import static org.hamcrest.Matchers.containsString;
diff --git a/test/framework/src/main/java/org/opensearch/search/aggregations/composite/BaseCompositeAggregatorTestCase.java b/test/framework/src/main/java/org/opensearch/search/aggregations/composite/BaseCompositeAggregatorTestCase.java
new file mode 100644
index 0000000000000..7d00772913d6e
--- /dev/null
+++ b/test/framework/src/main/java/org/opensearch/search/aggregations/composite/BaseCompositeAggregatorTestCase.java
@@ -0,0 +1,310 @@
+/*
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * The OpenSearch Contributors require contributions made to
+ * this file be licensed under the Apache-2.0 license or a
+ * compatible open source license.
+ */
+
+package org.opensearch.search.aggregations.composite;
+
+import org.apache.lucene.document.Document;
+import org.apache.lucene.document.DoublePoint;
+import org.apache.lucene.document.Field;
+import org.apache.lucene.document.InetAddressPoint;
+import org.apache.lucene.document.IntPoint;
+import org.apache.lucene.document.LongPoint;
+import org.apache.lucene.document.SortedNumericDocValuesField;
+import org.apache.lucene.document.SortedSetDocValuesField;
+import org.apache.lucene.document.StringField;
+import org.apache.lucene.index.DirectoryReader;
+import org.apache.lucene.index.IndexReader;
+import org.apache.lucene.index.IndexWriterConfig;
+import org.apache.lucene.index.Term;
+import org.apache.lucene.search.IndexSearcher;
+import org.apache.lucene.search.Query;
+import org.apache.lucene.search.Sort;
+import org.apache.lucene.search.SortField;
+import org.apache.lucene.search.SortedNumericSortField;
+import org.apache.lucene.search.SortedSetSortField;
+import org.apache.lucene.store.Directory;
+import org.apache.lucene.tests.analysis.MockAnalyzer;
+import org.apache.lucene.tests.index.RandomIndexWriter;
+import org.apache.lucene.tests.util.TestUtil;
+import org.apache.lucene.util.BytesRef;
+import org.apache.lucene.util.NumericUtils;
+import org.junit.After;
+import org.junit.Before;
+import org.opensearch.common.settings.Settings;
+import org.opensearch.common.text.Text;
+import org.opensearch.common.time.DateFormatter;
+import org.opensearch.common.time.DateFormatters;
+import org.opensearch.index.Index;
+import org.opensearch.index.IndexSettings;
+import org.opensearch.index.mapper.DateFieldMapper;
+import org.opensearch.index.mapper.DocumentMapper;
+import org.opensearch.index.mapper.IpFieldMapper;
+import org.opensearch.index.mapper.KeywordFieldMapper;
+import org.opensearch.index.mapper.MappedFieldType;
+import org.opensearch.index.mapper.MapperService;
+import org.opensearch.index.mapper.NumberFieldMapper;
+import org.opensearch.search.aggregations.AggregatorTestCase;
+import org.opensearch.search.aggregations.bucket.composite.CompositeAggregationBuilder;
+import org.opensearch.search.aggregations.bucket.composite.CompositeValuesSourceBuilder;
+import org.opensearch.search.aggregations.bucket.composite.InternalComposite;
+import org.opensearch.test.IndexSettingsModule;
+
+import java.io.IOException;
+import java.net.InetAddress;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.function.Consumer;
+import java.util.function.Function;
+import java.util.function.Supplier;
+import java.util.stream.Collectors;
+
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+
+/**
+ * Base class for the Aggregator Tests which are registered under Composite Aggregation.
+ */
+public class BaseCompositeAggregatorTestCase extends AggregatorTestCase {
+
+ protected static List FIELD_TYPES;
+
+ @Override
+ @Before
+ public void setUp() throws Exception {
+ super.setUp();
+ FIELD_TYPES = new ArrayList<>();
+ FIELD_TYPES.add(new KeywordFieldMapper.KeywordFieldType("keyword"));
+ FIELD_TYPES.add(new NumberFieldMapper.NumberFieldType("long", NumberFieldMapper.NumberType.LONG));
+ FIELD_TYPES.add(new NumberFieldMapper.NumberFieldType("double", NumberFieldMapper.NumberType.DOUBLE));
+ FIELD_TYPES.add(new DateFieldMapper.DateFieldType("date", DateFormatter.forPattern("yyyy-MM-dd||epoch_millis")));
+ FIELD_TYPES.add(new NumberFieldMapper.NumberFieldType("price", NumberFieldMapper.NumberType.INTEGER));
+ FIELD_TYPES.add(new KeywordFieldMapper.KeywordFieldType("terms"));
+ FIELD_TYPES.add(new IpFieldMapper.IpFieldType("ip"));
+ }
+
+ @Override
+ @After
+ public void tearDown() throws Exception {
+ super.tearDown();
+ FIELD_TYPES = null;
+ }
+
+ @Override
+ protected MapperService mapperServiceMock() {
+ MapperService mapperService = mock(MapperService.class);
+ DocumentMapper mapper = mock(DocumentMapper.class);
+ when(mapper.typeText()).thenReturn(new Text("_doc"));
+ when(mapper.type()).thenReturn("_doc");
+ when(mapperService.documentMapper()).thenReturn(mapper);
+ return mapperService;
+ }
+
+ protected static Map> createDocument(Object... fields) {
+ assert fields.length % 2 == 0;
+ final Map> map = new HashMap<>();
+ for (int i = 0; i < fields.length; i += 2) {
+ String field = (String) fields[i];
+ if (fields[i + 1] instanceof List) {
+ map.put(field, (List) fields[i + 1]);
+ } else {
+ map.put(field, Collections.singletonList(fields[i + 1]));
+ }
+ }
+ return map;
+ }
+
+ protected void testSearchCase(
+ List queries,
+ List>> dataset,
+ Supplier create,
+ Consumer verify
+ ) throws IOException {
+ for (Query query : queries) {
+ executeTestCase(false, false, query, dataset, create, verify);
+ executeTestCase(false, true, query, dataset, create, verify);
+ }
+ }
+
+ protected void executeTestCase(
+ boolean forceMerge,
+ boolean useIndexSort,
+ Query query,
+ List>> dataset,
+ Supplier create,
+ Consumer verify
+ ) throws IOException {
+ Map types = FIELD_TYPES.stream().collect(Collectors.toMap(MappedFieldType::name, Function.identity()));
+ CompositeAggregationBuilder aggregationBuilder = create.get();
+ Sort indexSort = useIndexSort ? buildIndexSort(aggregationBuilder.sources(), types) : null;
+ IndexSettings indexSettings = createIndexSettings(indexSort);
+ try (Directory directory = newDirectory()) {
+ IndexWriterConfig config = newIndexWriterConfig(random(), new MockAnalyzer(random()));
+ if (indexSort != null) {
+ config.setIndexSort(indexSort);
+ config.setCodec(TestUtil.getDefaultCodec());
+ }
+ try (RandomIndexWriter indexWriter = new RandomIndexWriter(random(), directory, config)) {
+ Document document = new Document();
+ int id = 0;
+ for (Map> fields : dataset) {
+ document.clear();
+ addToDocument(id, document, fields);
+ indexWriter.addDocument(document);
+ id++;
+ }
+ if (forceMerge || rarely()) {
+ // forceMerge randomly or if the collector-per-leaf testing stuff would break the tests.
+ indexWriter.forceMerge(1);
+ } else {
+ if (dataset.size() > 0) {
+ int numDeletes = randomIntBetween(1, 25);
+ for (int i = 0; i < numDeletes; i++) {
+ id = randomIntBetween(0, dataset.size() - 1);
+ indexWriter.deleteDocuments(new Term("id", Integer.toString(id)));
+ document.clear();
+ addToDocument(id, document, dataset.get(id));
+ indexWriter.addDocument(document);
+ }
+ }
+
+ }
+ }
+ try (IndexReader indexReader = DirectoryReader.open(directory)) {
+ IndexSearcher indexSearcher = new IndexSearcher(indexReader);
+ InternalComposite composite = searchAndReduce(
+ indexSettings,
+ indexSearcher,
+ query,
+ aggregationBuilder,
+ FIELD_TYPES.toArray(new MappedFieldType[0])
+ );
+ verify.accept(composite);
+ }
+ }
+ }
+
+ protected void addToDocument(int id, Document doc, Map> keys) {
+ doc.add(new StringField("id", Integer.toString(id), Field.Store.NO));
+ for (Map.Entry> entry : keys.entrySet()) {
+ final String name = entry.getKey();
+ for (Object value : entry.getValue()) {
+ if (value instanceof Integer) {
+ doc.add(new SortedNumericDocValuesField(name, (int) value));
+ doc.add(new IntPoint(name, (int) value));
+ } else if (value instanceof Long) {
+ doc.add(new SortedNumericDocValuesField(name, (long) value));
+ doc.add(new LongPoint(name, (long) value));
+ } else if (value instanceof Double) {
+ doc.add(new SortedNumericDocValuesField(name, NumericUtils.doubleToSortableLong((double) value)));
+ doc.add(new DoublePoint(name, (double) value));
+ } else if (value instanceof String) {
+ doc.add(new SortedSetDocValuesField(name, new BytesRef((String) value)));
+ doc.add(new StringField(name, new BytesRef((String) value), Field.Store.NO));
+ } else if (value instanceof InetAddress) {
+ doc.add(new SortedSetDocValuesField(name, new BytesRef(InetAddressPoint.encode((InetAddress) value))));
+ doc.add(new InetAddressPoint(name, (InetAddress) value));
+ } else {
+ if (!addValueToDocument(doc, name, value)) throw new AssertionError(
+ "invalid object: " + value.getClass().getSimpleName()
+ );
+ }
+ }
+ }
+ }
+
+ /**
+ * Override this function to handle any specific type of value you want to add in the document for doing the
+ * composite aggregation. If you have added another Composite Aggregation Type then you must override this
+ * function so that your field value can be added in the document correctly.
+ *
+ * @param doc {@link Document}
+ * @param name {@link String} Field Name
+ * @param value {@link Object} Field value
+ * @return boolean true or false, based on if value is added or not
+ */
+ protected boolean addValueToDocument(final Document doc, final String name, final Object value) {
+ return false;
+ }
+
+ protected static Sort buildIndexSort(List> sources, Map fieldTypes) {
+ List sortFields = new ArrayList<>();
+ Map remainingFieldTypes = new HashMap<>(fieldTypes);
+ for (CompositeValuesSourceBuilder> source : sources) {
+ MappedFieldType type = fieldTypes.remove(source.field());
+ remainingFieldTypes.remove(source.field());
+ SortField sortField = sortFieldFrom(type);
+ if (sortField == null) {
+ break;
+ }
+ sortFields.add(sortField);
+ }
+ while (remainingFieldTypes.size() > 0 && randomBoolean()) {
+ // Add extra unused sorts
+ List fields = new ArrayList<>(remainingFieldTypes.keySet());
+ Collections.sort(fields);
+ String field = fields.get(between(0, fields.size() - 1));
+ SortField sortField = sortFieldFrom(remainingFieldTypes.remove(field));
+ if (sortField != null) {
+ sortFields.add(sortField);
+ }
+ }
+ return sortFields.size() > 0 ? new Sort(sortFields.toArray(new SortField[0])) : null;
+ }
+
+ protected static SortField sortFieldFrom(MappedFieldType type) {
+ if (type instanceof KeywordFieldMapper.KeywordFieldType) {
+ return new SortedSetSortField(type.name(), false);
+ } else if (type instanceof DateFieldMapper.DateFieldType) {
+ return new SortedNumericSortField(type.name(), SortField.Type.LONG, false);
+ } else if (type instanceof NumberFieldMapper.NumberFieldType) {
+ switch (type.typeName()) {
+ case "byte":
+ case "short":
+ case "integer":
+ return new SortedNumericSortField(type.name(), SortField.Type.INT, false);
+ case "long":
+ return new SortedNumericSortField(type.name(), SortField.Type.LONG, false);
+ case "float":
+ case "double":
+ return new SortedNumericSortField(type.name(), SortField.Type.DOUBLE, false);
+ default:
+ return null;
+ }
+ }
+ return null;
+ }
+
+ protected static IndexSettings createIndexSettings(Sort sort) {
+ Settings.Builder builder = Settings.builder();
+ if (sort != null) {
+ String[] fields = Arrays.stream(sort.getSort()).map(SortField::getField).toArray(String[]::new);
+ String[] orders = Arrays.stream(sort.getSort()).map((o) -> o.getReverse() ? "desc" : "asc").toArray(String[]::new);
+ builder.putList("index.sort.field", fields);
+ builder.putList("index.sort.order", orders);
+ }
+ return IndexSettingsModule.newIndexSettings(new Index("_index", "0"), builder.build());
+ }
+
+ protected static Map createAfterKey(Object... fields) {
+ assert fields.length % 2 == 0;
+ final Map map = new HashMap<>();
+ for (int i = 0; i < fields.length; i += 2) {
+ String field = (String) fields[i];
+ map.put(field, fields[i + 1]);
+ }
+ return map;
+ }
+
+ protected static long asLong(String dateTime) {
+ return DateFormatters.from(DateFieldMapper.DEFAULT_DATE_TIME_FORMATTER.parse(dateTime)).toInstant().toEpochMilli();
+ }
+}
diff --git a/test/framework/src/main/java/org/opensearch/test/InternalAggregationTestCase.java b/test/framework/src/main/java/org/opensearch/test/InternalAggregationTestCase.java
index a4099d66de28e..5325c48e16913 100644
--- a/test/framework/src/main/java/org/opensearch/test/InternalAggregationTestCase.java
+++ b/test/framework/src/main/java/org/opensearch/test/InternalAggregationTestCase.java
@@ -68,10 +68,6 @@
import org.opensearch.search.aggregations.bucket.filter.FiltersAggregationBuilder;
import org.opensearch.search.aggregations.bucket.filter.ParsedFilter;
import org.opensearch.search.aggregations.bucket.filter.ParsedFilters;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoHashGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.GeoTileGridAggregationBuilder;
-import org.opensearch.search.aggregations.bucket.geogrid.ParsedGeoHashGrid;
-import org.opensearch.search.aggregations.bucket.geogrid.ParsedGeoTileGrid;
import org.opensearch.search.aggregations.bucket.global.GlobalAggregationBuilder;
import org.opensearch.search.aggregations.bucket.global.ParsedGlobal;
import org.opensearch.search.aggregations.bucket.histogram.AutoDateHistogramAggregationBuilder;
@@ -275,8 +271,6 @@ public ReduceContext forFinalReduction() {
map.put(GlobalAggregationBuilder.NAME, (p, c) -> ParsedGlobal.fromXContent(p, (String) c));
map.put(FilterAggregationBuilder.NAME, (p, c) -> ParsedFilter.fromXContent(p, (String) c));
map.put(InternalSampler.PARSER_NAME, (p, c) -> ParsedSampler.fromXContent(p, (String) c));
- map.put(GeoHashGridAggregationBuilder.NAME, (p, c) -> ParsedGeoHashGrid.fromXContent(p, (String) c));
- map.put(GeoTileGridAggregationBuilder.NAME, (p, c) -> ParsedGeoTileGrid.fromXContent(p, (String) c));
map.put(RangeAggregationBuilder.NAME, (p, c) -> ParsedRange.fromXContent(p, (String) c));
map.put(DateRangeAggregationBuilder.NAME, (p, c) -> ParsedDateRange.fromXContent(p, (String) c));
map.put(GeoDistanceAggregationBuilder.NAME, (p, c) -> ParsedGeoDistance.fromXContent(p, (String) c));