2018-01-16 01:11:38 +05:30
|
|
|
package com.baeldung.elasticsearch;
|
|
|
|
|
2018-01-20 13:33:02 +01:00
|
|
|
import com.baeldung.spring.data.es.config.Config;
|
2018-01-16 01:11:38 +05:30
|
|
|
import org.elasticsearch.action.admin.indices.create.CreateIndexRequest;
|
|
|
|
import org.elasticsearch.action.index.IndexResponse;
|
|
|
|
import org.elasticsearch.action.search.SearchResponse;
|
|
|
|
import org.elasticsearch.client.Client;
|
|
|
|
import org.elasticsearch.common.geo.ShapeRelation;
|
|
|
|
import org.elasticsearch.common.geo.builders.ShapeBuilder;
|
|
|
|
import org.elasticsearch.common.unit.DistanceUnit;
|
|
|
|
import org.elasticsearch.index.query.QueryBuilder;
|
|
|
|
import org.elasticsearch.index.query.QueryBuilders;
|
2018-01-20 13:33:02 +01:00
|
|
|
import org.elasticsearch.search.SearchHit;
|
2018-01-16 01:11:38 +05:30
|
|
|
import org.junit.After;
|
|
|
|
import org.junit.Before;
|
|
|
|
import org.junit.Test;
|
|
|
|
import org.junit.runner.RunWith;
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.data.elasticsearch.core.ElasticsearchTemplate;
|
|
|
|
import org.springframework.test.context.ContextConfiguration;
|
|
|
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
|
|
|
2018-01-20 13:33:02 +01:00
|
|
|
import java.util.Arrays;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
import static org.junit.Assert.assertTrue;
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
@RunWith(SpringJUnit4ClassRunner.class)
|
|
|
|
@ContextConfiguration(classes = Config.class)
|
2018-04-10 06:54:31 +02:00
|
|
|
public class GeoQueriesIntegrationTest {
|
2018-01-16 01:11:38 +05:30
|
|
|
|
2018-01-20 13:33:02 +01:00
|
|
|
private static final String WONDERS_OF_WORLD = "wonders-of-world";
|
|
|
|
private static final String WONDERS = "Wonders";
|
|
|
|
|
2018-01-16 01:11:38 +05:30
|
|
|
@Autowired
|
|
|
|
private ElasticsearchTemplate elasticsearchTemplate;
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
private Client client;
|
|
|
|
|
|
|
|
@Before
|
|
|
|
public void setUp() {
|
|
|
|
String jsonObject = "{\"Wonders\":{\"properties\":{\"name\":{\"type\":\"string\",\"index\":\"not_analyzed\"},\"region\":{\"type\":\"geo_shape\",\"tree\":\"quadtree\",\"precision\":\"1m\"},\"location\":{\"type\":\"geo_point\"}}}}";
|
|
|
|
CreateIndexRequest req = new CreateIndexRequest(WONDERS_OF_WORLD);
|
|
|
|
req.mapping(WONDERS, jsonObject);
|
|
|
|
client.admin()
|
2018-01-20 13:33:02 +01:00
|
|
|
.indices()
|
|
|
|
.create(req)
|
|
|
|
.actionGet();
|
2018-01-16 01:11:38 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void givenGeoShapeData_whenExecutedGeoShapeQuery_thenResultNonEmpty() {
|
|
|
|
String jsonObject = "{\"name\":\"Agra\",\"region\":{\"type\":\"envelope\",\"coordinates\":[[75,25],[80.1,30.2]]}}";
|
|
|
|
IndexResponse response = client.prepareIndex(WONDERS_OF_WORLD, WONDERS)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setSource(jsonObject)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
String tajMahalId = response.getId();
|
|
|
|
client.admin()
|
2018-01-20 13:33:02 +01:00
|
|
|
.indices()
|
|
|
|
.prepareRefresh(WONDERS_OF_WORLD)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
QueryBuilder qb = QueryBuilders.geoShapeQuery("region", ShapeBuilder.newEnvelope()
|
2018-01-20 13:33:02 +01:00
|
|
|
.topLeft(74.00, 24.0)
|
|
|
|
.bottomRight(81.1, 31.2))
|
|
|
|
.relation(ShapeRelation.WITHIN);
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
SearchResponse searchResponse = client.prepareSearch(WONDERS_OF_WORLD)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setTypes(WONDERS)
|
|
|
|
.setQuery(qb)
|
|
|
|
.execute()
|
|
|
|
.actionGet();
|
2018-01-16 01:11:38 +05:30
|
|
|
List<String> ids = Arrays.stream(searchResponse.getHits()
|
2018-01-20 13:33:02 +01:00
|
|
|
.getHits())
|
|
|
|
.map(SearchHit::getId)
|
|
|
|
.collect(Collectors.toList());
|
2018-01-16 01:11:38 +05:30
|
|
|
assertTrue(ids.contains(tajMahalId));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void givenGeoPointData_whenExecutedGeoBoundingBoxQuery_thenResultNonEmpty() {
|
|
|
|
String jsonObject = "{\"name\":\"Pyramids of Giza\",\"location\":[31.131302,29.976480]}";
|
|
|
|
IndexResponse response = client.prepareIndex(WONDERS_OF_WORLD, WONDERS)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setSource(jsonObject)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
String pyramidsOfGizaId = response.getId();
|
|
|
|
client.admin()
|
2018-01-20 13:33:02 +01:00
|
|
|
.indices()
|
|
|
|
.prepareRefresh(WONDERS_OF_WORLD)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
QueryBuilder qb = QueryBuilders.geoBoundingBoxQuery("location")
|
2018-01-20 13:33:02 +01:00
|
|
|
.bottomLeft(28, 30)
|
|
|
|
.topRight(31, 32);
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
SearchResponse searchResponse = client.prepareSearch(WONDERS_OF_WORLD)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setTypes(WONDERS)
|
|
|
|
.setQuery(qb)
|
|
|
|
.execute()
|
|
|
|
.actionGet();
|
2018-01-16 01:11:38 +05:30
|
|
|
List<String> ids = Arrays.stream(searchResponse.getHits()
|
2018-01-20 13:33:02 +01:00
|
|
|
.getHits())
|
|
|
|
.map(SearchHit::getId)
|
|
|
|
.collect(Collectors.toList());
|
2018-01-16 01:11:38 +05:30
|
|
|
assertTrue(ids.contains(pyramidsOfGizaId));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void givenGeoPointData_whenExecutedGeoDistanceQuery_thenResultNonEmpty() {
|
|
|
|
String jsonObject = "{\"name\":\"Lighthouse of alexandria\",\"location\":[31.131302,29.976480]}";
|
|
|
|
IndexResponse response = client.prepareIndex(WONDERS_OF_WORLD, WONDERS)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setSource(jsonObject)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
String lighthouseOfAlexandriaId = response.getId();
|
|
|
|
client.admin()
|
2018-01-20 13:33:02 +01:00
|
|
|
.indices()
|
|
|
|
.prepareRefresh(WONDERS_OF_WORLD)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
QueryBuilder qb = QueryBuilders.geoDistanceQuery("location")
|
2018-01-20 13:33:02 +01:00
|
|
|
.point(29.976, 31.131)
|
|
|
|
.distance(10, DistanceUnit.MILES);
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
SearchResponse searchResponse = client.prepareSearch(WONDERS_OF_WORLD)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setTypes(WONDERS)
|
|
|
|
.setQuery(qb)
|
|
|
|
.execute()
|
|
|
|
.actionGet();
|
2018-01-16 01:11:38 +05:30
|
|
|
List<String> ids = Arrays.stream(searchResponse.getHits()
|
2018-01-20 13:33:02 +01:00
|
|
|
.getHits())
|
|
|
|
.map(SearchHit::getId)
|
|
|
|
.collect(Collectors.toList());
|
2018-01-16 01:11:38 +05:30
|
|
|
assertTrue(ids.contains(lighthouseOfAlexandriaId));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void givenGeoPointData_whenExecutedGeoPolygonQuery_thenResultNonEmpty() {
|
|
|
|
String jsonObject = "{\"name\":\"The Great Rann of Kutch\",\"location\":[69.859741,23.733732]}";
|
|
|
|
IndexResponse response = client.prepareIndex(WONDERS_OF_WORLD, WONDERS)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setSource(jsonObject)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
String greatRannOfKutchid = response.getId();
|
|
|
|
client.admin()
|
2018-01-20 13:33:02 +01:00
|
|
|
.indices()
|
|
|
|
.prepareRefresh(WONDERS_OF_WORLD)
|
|
|
|
.get();
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
QueryBuilder qb = QueryBuilders.geoPolygonQuery("location")
|
2018-01-20 13:33:02 +01:00
|
|
|
.addPoint(22.733, 68.859)
|
|
|
|
.addPoint(24.733, 68.859)
|
|
|
|
.addPoint(23, 70.859);
|
2018-01-16 01:11:38 +05:30
|
|
|
|
|
|
|
SearchResponse searchResponse = client.prepareSearch(WONDERS_OF_WORLD)
|
2018-01-20 13:33:02 +01:00
|
|
|
.setTypes(WONDERS)
|
|
|
|
.setQuery(qb)
|
|
|
|
.execute()
|
|
|
|
.actionGet();
|
2018-01-16 01:11:38 +05:30
|
|
|
List<String> ids = Arrays.stream(searchResponse.getHits()
|
2018-01-20 13:33:02 +01:00
|
|
|
.getHits())
|
|
|
|
.map(SearchHit::getId)
|
|
|
|
.collect(Collectors.toList());
|
2018-01-16 01:11:38 +05:30
|
|
|
assertTrue(ids.contains(greatRannOfKutchid));
|
|
|
|
}
|
|
|
|
|
|
|
|
@After
|
|
|
|
public void destroy() {
|
|
|
|
elasticsearchTemplate.deleteIndex(WONDERS_OF_WORLD);
|
|
|
|
}
|
|
|
|
}
|