/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 2002-2008, Open Source Geospatial Foundation (OSGeo)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*/
package org.geotools.kml.bindings;
import javax.xml.namespace.QName;
import com.vividsolutions.jts.geom.Coordinate;
import com.vividsolutions.jts.geom.GeometryFactory;
import com.vividsolutions.jts.geom.LinearRing;
import com.vividsolutions.jts.geom.Polygon;
import org.geotools.kml.KML;
import org.geotools.kml.KMLTestSupport;
import org.geotools.xml.Binding;
import org.w3c.dom.Document;
public class PolygonTypeBindingTest extends KMLTestSupport {
public void testType() {
assertEquals(Polygon.class, binding(KML.PolygonType).getType());
}
public void testExecutionMode() {
assertEquals(Binding.OVERRIDE, binding(KML.PolygonType).getExecutionMode());
}
public void testParse() throws Exception {
String xml = "<Polygon>" + "<outerBoundaryIs>"
+ "<LinearRing><coordinates>1,1 2,2 3,3 1,1</coordinates></LinearRing>"
+ "</outerBoundaryIs>" + "<innerBoundaryIs>"
+ "<LinearRing><coordinates>1,1 2,2 3,3 1,1</coordinates></LinearRing>"
+ "</innerBoundaryIs>" + "</Polygon>";
buildDocument(xml);
Polygon p = (Polygon) parse();
assertEquals(1, p.getNumInteriorRing());
}
public void testEncode() throws Exception {
Polygon p = new GeometryFactory().createPolygon(
new GeometryFactory().createLinearRing(
new Coordinate[]{ new Coordinate(1,1), new Coordinate(2,2),
new Coordinate(3,3), new Coordinate(1,1) }
), new LinearRing[] {
new GeometryFactory().createLinearRing(
new Coordinate[]{ new Coordinate(1,1), new Coordinate(2,2),
new Coordinate(3,3), new Coordinate(1,1) }
)
}
);
Document dom = encode( p, KML.Polygon );
assertNotNull( getElementByQName(dom, new QName( KML.NAMESPACE, "outerBoundaryIs") ) );
assertNotNull( getElementByQName(dom, new QName( KML.NAMESPACE, "innerBoundaryIs") ) );
}
}