use of ddf.geo.formatter.LineString in project ddf by codice.
the class TestGeoJsonMetacardTransformer method testWithGeometryCollection.
@Test
public void testWithGeometryCollection() throws CatalogTransformerException, IOException, ParseException {
Date now = new Date();
MetacardImpl metacard = new MetacardImpl();
metacard.setLocation("GEOMETRYCOLLECTION(POINT(4 6),LINESTRING(4 6,7 10))");
setupBasicMetacard(now, metacard);
GeoJsonMetacardTransformer transformer = new GeoJsonMetacardTransformer();
BinaryContent content = transformer.transform(metacard, null);
assertEquals(content.getMimeTypeValue(), GeoJsonMetacardTransformer.DEFAULT_MIME_TYPE.getBaseType());
String jsonText = new String(content.getByteArray());
LOGGER.debug(jsonText);
Object object = PARSER.parse(jsonText);
JSONObject obj2 = (JSONObject) object;
Map geometryMap = (Map) obj2.get("geometry");
assertThat(geometryMap.get(CompositeGeometry.TYPE_KEY).toString(), is(GeometryCollection.TYPE));
assertThat(geometryMap.get(CompositeGeometry.GEOMETRIES_KEY), notNullValue());
verifyBasicMetacardJson(now, obj2);
}
use of ddf.geo.formatter.LineString in project ddf by codice.
the class TestGeoJsonMetacardTransformer method testwithLineStringGeo.
/**
* Tests that a LineString Geography can be returned in JSON
*
* @throws CatalogTransformerException
* @throws IOException
* @throws ParseException
*/
@Test
public void testwithLineStringGeo() throws CatalogTransformerException, IOException, ParseException {
Date now = new Date();
MetacardImpl metacard = new MetacardImpl();
metacard.setLocation("LINESTRING (30 10, 10 30, 40 40)");
setupBasicMetacard(now, metacard);
GeoJsonMetacardTransformer transformer = new GeoJsonMetacardTransformer();
BinaryContent content = transformer.transform(metacard, null);
assertEquals(content.getMimeTypeValue(), GeoJsonMetacardTransformer.DEFAULT_MIME_TYPE.getBaseType());
String jsonText = new String(content.getByteArray());
LOGGER.debug(jsonText);
Object object = PARSER.parse(jsonText);
JSONObject obj2 = (JSONObject) object;
Map geometryMap = (Map) obj2.get("geometry");
assertThat(geometryMap.get(CompositeGeometry.TYPE_KEY).toString(), is(LineString.TYPE));
List<List<Double>> coordsList = (List<List<Double>>) geometryMap.get(CompositeGeometry.COORDINATES_KEY);
assertThat(coordsList.size(), is(3));
for (List list : coordsList) {
assertEquals(list.size(), 2);
}
assertThat(coordsList.get(0).get(0), equalTo(30.0));
assertThat(coordsList.get(0).get(1), equalTo(10.0));
assertThat(coordsList.get(1).get(0), equalTo(10.0));
assertThat(coordsList.get(1).get(1), equalTo(30.0));
assertThat(coordsList.get(2).get(0), equalTo(40.0));
assertThat(coordsList.get(2).get(1), equalTo(40.0));
verifyBasicMetacardJson(now, obj2);
}
Aggregations