Geo Point Fieldmapper: Allow distance for geohash precision
Even though mentioned differently in the docs, the geohash precision needed to be an integer instead of a DistanceUnit. Closes #5448
This commit is contained in:
parent
0ef3b03be1
commit
0ca7fddb66
|
@ -226,7 +226,11 @@ public class GeoPointFieldMapper extends AbstractFieldMapper<GeoPoint> implement
|
||||||
} else if (fieldName.equals("precision_step")) {
|
} else if (fieldName.equals("precision_step")) {
|
||||||
builder.precisionStep(XContentMapValues.nodeIntegerValue(fieldNode));
|
builder.precisionStep(XContentMapValues.nodeIntegerValue(fieldNode));
|
||||||
} else if (fieldName.equals("geohash_precision")) {
|
} else if (fieldName.equals("geohash_precision")) {
|
||||||
|
if (fieldNode instanceof Integer) {
|
||||||
builder.geoHashPrecision(XContentMapValues.nodeIntegerValue(fieldNode));
|
builder.geoHashPrecision(XContentMapValues.nodeIntegerValue(fieldNode));
|
||||||
|
} else {
|
||||||
|
builder.geoHashPrecision(GeoUtils.geoHashLevelsForPrecision(fieldNode.toString()));
|
||||||
|
}
|
||||||
} else if (fieldName.equals("validate")) {
|
} else if (fieldName.equals("validate")) {
|
||||||
builder.validateLat = XContentMapValues.nodeBooleanValue(fieldNode);
|
builder.validateLat = XContentMapValues.nodeBooleanValue(fieldNode);
|
||||||
builder.validateLon = XContentMapValues.nodeBooleanValue(fieldNode);
|
builder.validateLon = XContentMapValues.nodeBooleanValue(fieldNode);
|
||||||
|
@ -452,6 +456,10 @@ public class GeoPointFieldMapper extends AbstractFieldMapper<GeoPoint> implement
|
||||||
return this.geohashMapper;
|
return this.geohashMapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int geoHashPrecision() {
|
||||||
|
return geoHashPrecision;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isEnableLatLon() {
|
public boolean isEnableLatLon() {
|
||||||
return enableLatLon;
|
return enableLatLon;
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@ package org.elasticsearch.index.mapper.geo;
|
||||||
import org.elasticsearch.common.geo.GeoHashUtils;
|
import org.elasticsearch.common.geo.GeoHashUtils;
|
||||||
import org.elasticsearch.common.xcontent.XContentFactory;
|
import org.elasticsearch.common.xcontent.XContentFactory;
|
||||||
import org.elasticsearch.index.mapper.DocumentMapper;
|
import org.elasticsearch.index.mapper.DocumentMapper;
|
||||||
|
import org.elasticsearch.index.mapper.FieldMapper;
|
||||||
import org.elasticsearch.index.mapper.MapperTestUtils;
|
import org.elasticsearch.index.mapper.MapperTestUtils;
|
||||||
import org.elasticsearch.index.mapper.ParsedDocument;
|
import org.elasticsearch.index.mapper.ParsedDocument;
|
||||||
import org.elasticsearch.test.ElasticsearchTestCase;
|
import org.elasticsearch.test.ElasticsearchTestCase;
|
||||||
|
@ -92,4 +93,28 @@ public class GeohashMappingGeoPointTests extends ElasticsearchTestCase {
|
||||||
MatcherAssert.assertThat(doc.rootDoc().get("point.geohash"), equalTo(GeoHashUtils.encode(1.2, 1.3)));
|
MatcherAssert.assertThat(doc.rootDoc().get("point.geohash"), equalTo(GeoHashUtils.encode(1.2, 1.3)));
|
||||||
MatcherAssert.assertThat(doc.rootDoc().get("point"), notNullValue());
|
MatcherAssert.assertThat(doc.rootDoc().get("point"), notNullValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGeoHashPrecisionAsInteger() throws Exception {
|
||||||
|
String mapping = XContentFactory.jsonBuilder().startObject().startObject("type")
|
||||||
|
.startObject("properties").startObject("point").field("type", "geo_point").field("geohash_precision", 10).endObject().endObject()
|
||||||
|
.endObject().endObject().string();
|
||||||
|
DocumentMapper defaultMapper = MapperTestUtils.newParser().parse(mapping);
|
||||||
|
FieldMapper mapper = defaultMapper.mappers().smartName("point").mapper();
|
||||||
|
assertThat(mapper, instanceOf(GeoPointFieldMapper.class));
|
||||||
|
GeoPointFieldMapper geoPointFieldMapper = (GeoPointFieldMapper) mapper;
|
||||||
|
assertThat(geoPointFieldMapper.geoHashPrecision(), is(10));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGeoHashPrecisionAsLength() throws Exception {
|
||||||
|
String mapping = XContentFactory.jsonBuilder().startObject().startObject("type")
|
||||||
|
.startObject("properties").startObject("point").field("type", "geo_point").field("geohash_precision", "5m").endObject().endObject()
|
||||||
|
.endObject().endObject().string();
|
||||||
|
DocumentMapper defaultMapper = MapperTestUtils.newParser().parse(mapping);
|
||||||
|
FieldMapper mapper = defaultMapper.mappers().smartName("point").mapper();
|
||||||
|
assertThat(mapper, instanceOf(GeoPointFieldMapper.class));
|
||||||
|
GeoPointFieldMapper geoPointFieldMapper = (GeoPointFieldMapper) mapper;
|
||||||
|
assertThat(geoPointFieldMapper.geoHashPrecision(), is(10));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue