/*
* 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.jdbc;
import org.geotools.feature.FeatureCollection;
import org.geotools.feature.FeatureIterator;
import org.geotools.feature.simple.SimpleFeatureBuilder;
import org.opengis.feature.simple.SimpleFeature;
import org.opengis.feature.simple.SimpleFeatureType;
import com.vividsolutions.jts.geom.Coordinate;
import com.vividsolutions.jts.geom.GeometryFactory;
public abstract class JDBCPrimaryKeyFinderTest extends JDBCTestSupport {
@Override
protected abstract JDBCPrimaryKeyFinderTestSetup createTestSetup();
@Override
protected void setUp() throws Exception {
super.setUp();
dataStore.setDatabaseSchema(null);
}
public void testSequencedPrimaryKey() throws Exception {
JDBCFeatureStore fs = (JDBCFeatureStore) dataStore.getFeatureSource(tname("seqtable"));
assertEquals( 1, fs.getPrimaryKey().getColumns().size() );
assertTrue( fs.getPrimaryKey().getColumns().get(0) instanceof SequencedPrimaryKeyColumn );
FeatureCollection features = fs.getFeatures();
assertPrimaryKeyValues(features, 3);
addFeature(fs.getSchema(),features);
assertPrimaryKeyValues(features,4);
}
public void testAssignedSinglePKeyView() throws Exception {
JDBCFeatureStore fs = (JDBCFeatureStore) dataStore.getFeatureSource(tname("assignedsinglepk"));
assertEquals( 1, fs.getPrimaryKey().getColumns().size() );
assertTrue( fs.getPrimaryKey().getColumns().get(0) instanceof NonIncrementingPrimaryKeyColumn );
FeatureCollection features = fs.getFeatures();
assertPrimaryKeyValues(features, 3);
}
public void testAssignedMultiPKeyView() throws Exception {
JDBCFeatureStore fs = (JDBCFeatureStore) dataStore.getFeatureSource(tname("assignedmultipk"));
assertEquals( 2, fs.getPrimaryKey().getColumns().size() );
assertTrue( fs.getPrimaryKey().getColumns().get(0) instanceof NonIncrementingPrimaryKeyColumn );
assertTrue( fs.getPrimaryKey().getColumns().get(1) instanceof NonIncrementingPrimaryKeyColumn );
FeatureIterator i = fs.getFeatures().features();
for ( int j = 1; i.hasNext(); j++ ) {
SimpleFeature f = (SimpleFeature) i.next();
assertEquals( tname("assignedmultipk") + "." + j + "." + (j + 1) , f.getID() );
}
i.close();
}
void addFeature( SimpleFeatureType featureType, FeatureCollection features ) throws Exception {
SimpleFeatureBuilder b = new SimpleFeatureBuilder( featureType );
b.add("four");
b.add( new GeometryFactory().createPoint( new Coordinate(4,4) ) );
SimpleFeature f = b.buildFeature(null);
features.add( f );
//pattern match to handle the multi primary key case
assertTrue(((String)f.getUserData().get( "fid" )).matches( tname(featureType.getTypeName()) + ".4(\\..*)?"));
}
void assertPrimaryKeyValues( FeatureCollection features, int count ) throws Exception {
FeatureIterator i = features.features();
for ( int j = 1; j <= count; j++ ) {
assertTrue( i.hasNext() );
SimpleFeature f = (SimpleFeature) i.next();
assertEquals( tname(features.getSchema().getName().getLocalPart()) + "." + j , f.getID() );
}
features.close( i );
}
}