use of org.opengis.filter.identity.FeatureId in project spatial-portal by AtlasOfLivingAustralia.
the class AreaUploadShapefileWizardController method onClick$btnRefresh.
public void onClick$btnRefresh(Event event) {
Iterator<Listitem> it = lAttributes.getSelectedItems().iterator();
FilterFactory2 ff = CommonFactoryFinder.getFilterFactory2(GeoTools.getDefaultHints());
Set<FeatureId> fids = new HashSet<FeatureId>();
while (it.hasNext()) {
Listitem li = it.next();
fids.add(ff.featureId(li.getValue().toString()));
}
executeShapeImageRenderer(ff.id(fids));
}
use of org.opengis.filter.identity.FeatureId in project GeoGig by boundlessgeo.
the class FeatureBuilder method buildLazy.
public Feature buildLazy(final String id, final Node node, final RevObjectParse parser) {
Supplier<? extends List<Optional<Object>>> valueSupplier = new LazyFeatureLoader(node.getObjectId(), parser);
valueSupplier = Suppliers.memoize(valueSupplier);
final FeatureId fid = new LazyVersionedFeatureId(id, node.getObjectId());
GeogigSimpleFeature feature = new GeogigSimpleFeature(valueSupplier, (SimpleFeatureType) featureType, fid, attNameToRevTypeIndex, node);
return feature;
}
use of org.opengis.filter.identity.FeatureId in project GeoGig by boundlessgeo.
the class GeoGigFeatureStoreTest method testAddFeaturesOnASeparateBranch.
@Test
public void testAddFeaturesOnASeparateBranch() throws Exception {
final String branchName = "addtest";
final Ref branchRef = geogig.command(BranchCreateOp.class).setName(branchName).call();
dataStore.setHead(branchName);
FeatureCollection<SimpleFeatureType, SimpleFeature> collection;
collection = DataUtilities.collection(Arrays.asList((SimpleFeature) points1, (SimpleFeature) points2, (SimpleFeature) points3));
Transaction tx = new DefaultTransaction();
points.setTransaction(tx);
assertSame(tx, points.getTransaction());
try {
List<FeatureId> addedFeatures = points.addFeatures(collection);
assertNotNull(addedFeatures);
assertEquals(3, addedFeatures.size());
// assert transaction isolation
assertEquals(3, points.getFeatures().size());
assertEquals(0, dataStore.getFeatureSource(pointsTypeName).getFeatures().size());
tx.commit();
assertEquals(3, dataStore.getFeatureSource(pointsTypeName).getFeatures().size());
} catch (Exception e) {
tx.rollback();
throw e;
} finally {
tx.close();
}
}
use of org.opengis.filter.identity.FeatureId in project GeoGig by boundlessgeo.
the class GeoGigFeatureStoreTest method testUseProvidedFIDSupported.
@Test
public void testUseProvidedFIDSupported() throws Exception {
assertTrue(points.getQueryCapabilities().isUseProvidedFIDSupported());
FeatureCollection<SimpleFeatureType, SimpleFeature> collection;
collection = DataUtilities.collection(Arrays.asList((SimpleFeature) points1, (SimpleFeature) points2, (SimpleFeature) points3));
Transaction tx = new DefaultTransaction();
points.setTransaction(tx);
try {
List<FeatureId> newFids = points.addFeatures(collection);
assertNotNull(newFids);
assertEquals(3, newFids.size());
FeatureId fid1 = newFids.get(0);
FeatureId fid2 = newFids.get(1);
FeatureId fid3 = newFids.get(2);
// new ids should have been generated...
assertFalse(idP1.equals(fid1.getID()));
assertFalse(idP1.equals(fid1.getID()));
assertFalse(idP1.equals(fid1.getID()));
// now force the use of provided feature ids
points1.getUserData().put(Hints.USE_PROVIDED_FID, Boolean.TRUE);
points2.getUserData().put(Hints.USE_PROVIDED_FID, Boolean.TRUE);
points3.getUserData().put(Hints.USE_PROVIDED_FID, Boolean.TRUE);
List<FeatureId> providedFids = points.addFeatures(collection);
assertNotNull(providedFids);
assertEquals(3, providedFids.size());
FeatureId fid11 = providedFids.get(0);
FeatureId fid21 = providedFids.get(1);
FeatureId fid31 = providedFids.get(2);
// ids should match provided
assertEquals(idP1, fid11.getID());
assertEquals(idP2, fid21.getID());
assertEquals(idP3, fid31.getID());
tx.commit();
assertEquals(1, points.getFeatures(ff.id(Collections.singleton(fid1))).size());
assertEquals(1, points.getFeatures(ff.id(Collections.singleton(fid2))).size());
assertEquals(1, points.getFeatures(ff.id(Collections.singleton(fid3))).size());
assertEquals(1, points.getFeatures(ff.id(Collections.singleton(fid11))).size());
assertEquals(1, points.getFeatures(ff.id(Collections.singleton(fid21))).size());
assertEquals(1, points.getFeatures(ff.id(Collections.singleton(fid31))).size());
} catch (Exception e) {
tx.rollback();
throw e;
} finally {
tx.close();
}
}
use of org.opengis.filter.identity.FeatureId in project GeoGig by boundlessgeo.
the class GeoGigFeatureStoreTest method testAddFeatures.
@Test
public void testAddFeatures() throws Exception {
FeatureCollection<SimpleFeatureType, SimpleFeature> collection;
collection = DataUtilities.collection(Arrays.asList((SimpleFeature) points1, (SimpleFeature) points2, (SimpleFeature) points3));
try {
points.addFeatures(collection);
fail("Expected UnsupportedOperationException on AUTO_COMMIT");
} catch (UnsupportedOperationException e) {
assertTrue(e.getMessage().contains("AUTO_COMMIT"));
}
Transaction tx = new DefaultTransaction();
points.setTransaction(tx);
assertSame(tx, points.getTransaction());
try {
List<FeatureId> addedFeatures = points.addFeatures(collection);
assertNotNull(addedFeatures);
assertEquals(3, addedFeatures.size());
for (FeatureId id : addedFeatures) {
assertFalse(id instanceof ResourceId);
assertNotNull(id.getFeatureVersion());
}
// assert transaction isolation
assertEquals(3, points.getFeatures().size());
assertEquals(0, dataStore.getFeatureSource(pointsTypeName).getFeatures().size());
tx.commit();
assertEquals(3, dataStore.getFeatureSource(pointsTypeName).getFeatures().size());
} catch (Exception e) {
tx.rollback();
throw e;
} finally {
tx.close();
}
}
Aggregations