/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 2011, Open Source Geospatial Foundation (OSGeo)
* (C) 2001-2007 TOPP - www.openplans.org.
*
* 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.process.vector;
import static org.junit.Assert.*;
import org.geotools.data.simple.SimpleFeatureCollection;
import org.geotools.process.vector.FeatureProcess;
import org.geotools.referencing.CRS;
import org.junit.Test;
import org.opengis.feature.simple.SimpleFeature;
import org.opengis.feature.simple.SimpleFeatureType;
import org.opengis.feature.type.GeometryDescriptor;
import org.opengis.referencing.crs.CoordinateReferenceSystem;
import com.vividsolutions.jts.geom.Geometry;
import com.vividsolutions.jts.geom.Polygon;
import com.vividsolutions.jts.io.WKTReader;
/**
*
*
* @source $URL$
*/
public class FeatureProcessTest {
@Test
public void testFeatureCollection() throws Exception {
Geometry poly = new WKTReader().read("POLYGON((0 0, 0 10, 10 10, 10 0, 0 0))");
CoordinateReferenceSystem utm32n = CRS.decode("EPSG:32632");
poly.setUserData(utm32n);
SimpleFeatureCollection fc = new FeatureProcess().execute(poly, null, "testft");
assertNotNull(fc);
assertEquals(1, fc.size());
SimpleFeatureType schema = fc.getSchema();
assertEquals("testft", schema.getTypeName());
assertEquals(1, schema.getAttributeCount());
GeometryDescriptor ad = (GeometryDescriptor) schema.getDescriptor("geom");
assertEquals(Polygon.class, ad.getType().getBinding());
assertEquals(utm32n, ad.getCoordinateReferenceSystem());
SimpleFeature sf = fc.features().next();
assertEquals(poly, sf.getDefaultGeometry());
}
}