/* * GeoTools - The Open Source Java GIS Toolkit * http://geotools.org * * (C) 2003-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. * * Created on July 21, 2003, 4:00 PM */ package org.geotools.feature; import java.lang.reflect.Array; import java.net.URI; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; import junit.framework.Test; import junit.framework.TestSuite; import org.geotools.data.DataTestCase; import org.geotools.data.DataUtilities; import org.geotools.feature.simple.SimpleFeatureBuilder; import org.geotools.feature.simple.SimpleFeatureTypeBuilder; import org.geotools.feature.type.BasicFeatureTypes; import org.opengis.feature.simple.SimpleFeature; import org.opengis.feature.simple.SimpleFeatureType; import org.opengis.feature.type.AttributeDescriptor; import org.opengis.feature.type.FeatureType; import com.vividsolutions.jts.geom.Coordinate; import com.vividsolutions.jts.geom.Geometry; import com.vividsolutions.jts.geom.GeometryFactory; /** * * @author en * @author jgarnett * * @source $URL$ */ public class FeatureTypeTest extends DataTestCase { public FeatureTypeTest(String testName){ super(testName); } public static void main(String[] args) { junit.textui.TestRunner.run(suite()); } public static Test suite() { TestSuite suite = new TestSuite(FeatureTypeTest.class); return suite; } public void testAbstractType() throws Exception { SimpleFeatureTypeBuilder tb = new SimpleFeatureTypeBuilder(); tb.setName("AbstractThing"); tb.setAbstract(true); tb.setNamespaceURI( new URI("http://www.nowhereinparticular.net")); SimpleFeatureType abstractType = tb.buildFeatureType(); tb.setName( "AbstractType2" ); tb.setSuperType(abstractType); tb.add( "X", String.class ); SimpleFeatureType abstractType2 = tb.buildFeatureType(); assertTrue(abstractType.isAbstract()); assertTrue(abstractType2.isAbstract()); //assertTrue("extends gml feature", FeatureTypes.isDecendedFrom(abstractType, new URI("http://www.opengis.net/gml"),"Feature")); //assertTrue("extends gml feature", FeatureTypes.isDecendedFrom(abstractType2, new URI("http://www.opengis.net/gml"),"Feature")); assertTrue("abstractType2 --|> abstractType", FeatureTypes.isDecendedFrom(abstractType2, abstractType)); assertFalse("abstractType2 !--|> abstractType", FeatureTypes.isDecendedFrom(abstractType,abstractType2)); try { SimpleFeatureBuilder.build(abstractType, new Object[0], null); fail("abstract type allowed create"); } catch (IllegalArgumentException iae) { } catch (UnsupportedOperationException uoe) { } try { SimpleFeatureBuilder.build(abstractType2, new Object[0], null); fail("abstract type allowed create"); } catch (IllegalArgumentException iae) { } catch (UnsupportedOperationException uoe) { } } public void testEquals() throws Exception { SimpleFeatureTypeBuilder tb = new SimpleFeatureTypeBuilder(); tb.setName("Thing"); tb.setNamespaceURI("http://www.nowhereinparticular.net"); tb.add( "X", String.class ); final SimpleFeatureType ft = tb.buildFeatureType(); tb = new SimpleFeatureTypeBuilder(); tb.setName( "Thing" ); tb.setNamespaceURI("http://www.nowhereinparticular.net"); tb.add( "X", String.class ); SimpleFeatureType ft2 = tb.buildFeatureType(); assertEquals(ft,ft2); tb.setName("Thingee"); assertTrue(! ft.equals(tb.buildFeatureType())); tb.init(ft); tb.setNamespaceURI("http://www.somewhereelse.net"); assertTrue(! ft.equals(tb.buildFeatureType())); assertTrue(! ft.equals(null)); } public void testCopyFeature() throws Exception { SimpleFeature feature = lakeFeatures[0]; assertDuplicate( "feature", feature, SimpleFeatureBuilder.copy( feature ) ); } /** * Test FeatureTypes.getAncestors() by constructing three levels of derived types and testing * that the expected ancestors are returned at each level in reverse order. * * <p> * * UML type hierarchy of test types: Feature <|-- A <|-- B <|-- C * * @throws Exception */ @SuppressWarnings("serial") public void testAncestors() throws Exception { URI uri = new URI("http://www.geotools.org/example"); SimpleFeatureTypeBuilder tb; tb = new SimpleFeatureTypeBuilder(); tb.setName("A"); tb.setNamespaceURI(uri); final SimpleFeatureType typeA = tb.buildFeatureType(); tb = new SimpleFeatureTypeBuilder(); tb.setName("B"); tb.setNamespaceURI(uri); tb.setSuperType(typeA); tb.add("b", String.class); final SimpleFeatureType typeB = tb.buildFeatureType(); tb = new SimpleFeatureTypeBuilder(); tb.setName("C"); tb.setNamespaceURI(uri); tb.setSuperType(typeB); tb.add("c", Integer.class); final SimpleFeatureType typeC = tb.buildFeatureType(); // base type should have no ancestors assertEquals("Ancestors of Feature, nearest first", Collections.<FeatureType> emptyList(), FeatureTypes.getAncestors(BasicFeatureTypes.FEATURE)); assertEquals("Ancestors of A, nearest first", new ArrayList<FeatureType>() { { add(BasicFeatureTypes.FEATURE); } }, FeatureTypes.getAncestors(typeA)); assertEquals("Ancestors of B, nearest first", new ArrayList<FeatureType>() { { add(typeA); add(BasicFeatureTypes.FEATURE); } }, FeatureTypes.getAncestors(typeB)); assertEquals("Ancestors of C, nearest first", new ArrayList<FeatureType>() { { add(typeB); add(typeA); add(BasicFeatureTypes.FEATURE); } }, FeatureTypes.getAncestors(typeC)); } public void testDeepCopy() throws Exception { // primative String str = "FooBar"; Integer i = new Integer(3); Float f = new Float( 3.14); Double d = new Double( 3.14159 ); AttributeTypeBuilder ab = new AttributeTypeBuilder(); AttributeDescriptor testType = ab.binding(Object.class).buildDescriptor( "test" ); assertSame( "String", str, DataUtilities.duplicate( str ) ); assertSame( "Integer", i, DataUtilities.duplicate( i ) ); assertSame( "Float", f, DataUtilities.duplicate( f ) ); assertSame( "Double", d, DataUtilities.duplicate( d ) ); // collections Object objs[] = new Object[]{ str, i, f, d, }; int ints[] = new int[]{ 1, 2, 3, 4, }; List list = new ArrayList(); list.add( str ); list.add( i ); list.add( f ); list.add( d ); Map map = new HashMap(); map.put("a", str ); map.put("b", i ); map.put("c", f ); map.put("d", d ); assertDuplicate( "objs", objs, DataUtilities.duplicate( objs ) ); assertDuplicate( "ints", ints, DataUtilities.duplicate( ints ) ); assertDuplicate( "list", list, DataUtilities.duplicate( list ) ); assertDuplicate( "map", map, DataUtilities.duplicate( map ) ); // complex type SimpleFeature feature = lakeFeatures[0]; Coordinate coords = new Coordinate(1, 3); Coordinate coords2 = new Coordinate(1, 3); GeometryFactory gf = new GeometryFactory(); Geometry point = gf.createPoint(coords); Geometry point2 = gf.createPoint( coords2); assertDuplicate( "jts duplicate", point, point2 ); assertDuplicate( "feature", feature, DataUtilities.duplicate( feature ) ); assertDuplicate( "point", point, DataUtilities.duplicate( point ) ); } static Set immutable; static { immutable = new HashSet(); immutable.add( String.class ); immutable.add( Integer.class ); immutable.add( Double.class ); immutable.add( Float.class ); } protected void assertDuplicate( String message, Object expected, Object value ){ // Ensure value is equal to expected if (expected.getClass().isArray()){ int length1 = Array.getLength( expected ); int length2 = Array.getLength( value ); assertEquals( message, length1, length2); for( int i=0; i<length1; i++){ assertDuplicate( message+"["+i+"]", Array.get( expected, i), Array.get( value, i) ); } //assertNotSame( message, expected, value ); } else if (expected instanceof SimpleFeature) { assertDuplicate(message, ((SimpleFeature)expected).getAttributes(), ((SimpleFeature)value).getAttributes()); } else { assertEquals( message, expected, value ); } // Ensure Non Immutables are actually copied if( ! immutable.contains( expected.getClass() )){ //assertNotSame( message, expected, value ); } } }