Search in sources :

Example 1 with MapFeatureRow

use of net.geoprism.registry.excel.MapFeatureRow in project geoprism-registry by terraframe.

the class BusinessObjectImporterTest method testUpdateValue.

@Test
@Request
public void testUpdateValue() throws InterruptedException {
    BusinessObject object = BusinessObject.newInstance(type);
    object.setCode(TEST_CODE);
    object.apply();
    try {
        String value = "Test Text";
        String rowAttribute = "Bad";
        HashMap<String, Object> row = new HashMap<String, Object>();
        row.put(rowAttribute, value);
        row.put(BusinessObject.CODE, TEST_CODE);
        BusinessObjectImportConfiguration configuration = new BusinessObjectImportConfiguration();
        configuration.setImportStrategy(ImportStrategy.UPDATE_ONLY);
        configuration.setType(type);
        configuration.setDate(FastTestDataset.DEFAULT_END_TIME_DATE);
        configuration.setCopyBlank(false);
        configuration.setFunction(attributeType.getName(), new BasicColumnFunction(rowAttribute));
        configuration.setFunction(BusinessObject.CODE, new BasicColumnFunction(BusinessObject.CODE));
        BusinessObjectImporter importer = new BusinessObjectImporter(configuration, new NullImportProgressListener());
        importer.importRow(new MapFeatureRow(row));
        Assert.assertFalse(configuration.hasExceptions());
        BusinessObject result = BusinessObject.getByCode(type, TEST_CODE);
        Assert.assertEquals(result.getObjectValue(attributeType.getName()), value);
    } finally {
        if (object != null) {
            object.delete();
        }
    }
}
Also used : HashMap(java.util.HashMap) BasicColumnFunction(net.geoprism.data.importer.BasicColumnFunction) BusinessObjectImportConfiguration(net.geoprism.registry.etl.upload.BusinessObjectImportConfiguration) NullImportProgressListener(net.geoprism.registry.etl.NullImportProgressListener) JsonObject(com.google.gson.JsonObject) JSONObject(org.json.JSONObject) VertexServerGeoObject(net.geoprism.registry.model.graph.VertexServerGeoObject) BusinessObject(net.geoprism.registry.model.BusinessObject) BusinessObject(net.geoprism.registry.model.BusinessObject) BusinessObjectImporter(net.geoprism.registry.etl.upload.BusinessObjectImporter) MapFeatureRow(net.geoprism.registry.excel.MapFeatureRow) Test(org.junit.Test) Request(com.runwaysdk.session.Request)

Example 2 with MapFeatureRow

use of net.geoprism.registry.excel.MapFeatureRow in project geoprism-registry by terraframe.

the class BusinessObjectImporterTest method testImportValueExistingNewOnly.

@Test
@Request
public void testImportValueExistingNewOnly() throws InterruptedException {
    BusinessObject object = BusinessObject.newInstance(type);
    object.setCode(TEST_CODE);
    object.apply();
    try {
        String value = "Test Text";
        String rowAttribute = "Bad";
        HashMap<String, Object> row = new HashMap<String, Object>();
        row.put(rowAttribute, value);
        row.put(BusinessObject.CODE, TEST_CODE);
        BusinessObjectImportConfiguration configuration = new BusinessObjectImportConfiguration();
        configuration.setImportStrategy(ImportStrategy.NEW_ONLY);
        configuration.setType(type);
        configuration.setDate(FastTestDataset.DEFAULT_END_TIME_DATE);
        configuration.setCopyBlank(false);
        configuration.setFunction(attributeType.getName(), new BasicColumnFunction(rowAttribute));
        configuration.setFunction(BusinessObject.CODE, new BasicColumnFunction(BusinessObject.CODE));
        BusinessObjectImporter importer = new BusinessObjectImporter(configuration, new NullImportProgressListener());
        importer.importRow(new MapFeatureRow(row));
        Assert.assertTrue(configuration.hasExceptions());
        LinkedList<BusinessObjectRecordedErrorException> exceptions = configuration.getExceptions();
        Assert.assertEquals(1, exceptions.size());
        BusinessObjectRecordedErrorException exception = exceptions.get(0);
        Assert.assertTrue(exception.getError() instanceof DuplicateDataException);
    } finally {
        if (object != null) {
            object.delete();
        }
    }
}
Also used : HashMap(java.util.HashMap) BasicColumnFunction(net.geoprism.data.importer.BasicColumnFunction) BusinessObjectImportConfiguration(net.geoprism.registry.etl.upload.BusinessObjectImportConfiguration) BusinessObject(net.geoprism.registry.model.BusinessObject) BusinessObjectImporter(net.geoprism.registry.etl.upload.BusinessObjectImporter) DuplicateDataException(com.runwaysdk.dataaccess.DuplicateDataException) BusinessObjectRecordedErrorException(net.geoprism.registry.etl.upload.BusinessObjectRecordedErrorException) NullImportProgressListener(net.geoprism.registry.etl.NullImportProgressListener) JsonObject(com.google.gson.JsonObject) JSONObject(org.json.JSONObject) VertexServerGeoObject(net.geoprism.registry.model.graph.VertexServerGeoObject) BusinessObject(net.geoprism.registry.model.BusinessObject) MapFeatureRow(net.geoprism.registry.excel.MapFeatureRow) Test(org.junit.Test) Request(com.runwaysdk.session.Request)

Example 3 with MapFeatureRow

use of net.geoprism.registry.excel.MapFeatureRow in project geoprism-registry by terraframe.

the class BusinessObjectImporterTest method testImportValueUpdateAndNew.

@Test
@Request
public void testImportValueUpdateAndNew() throws InterruptedException {
    String value = "Test Text";
    String rowAttribute = "Bad";
    HashMap<String, Object> row = new HashMap<String, Object>();
    row.put(rowAttribute, value);
    row.put(BusinessObject.CODE, TEST_CODE);
    BusinessObjectImportConfiguration configuration = new BusinessObjectImportConfiguration();
    configuration.setImportStrategy(ImportStrategy.NEW_AND_UPDATE);
    configuration.setType(type);
    configuration.setDate(FastTestDataset.DEFAULT_END_TIME_DATE);
    configuration.setCopyBlank(false);
    configuration.setFunction(attributeType.getName(), new BasicColumnFunction(rowAttribute));
    configuration.setFunction(BusinessObject.CODE, new BasicColumnFunction(BusinessObject.CODE));
    BusinessObjectImporter importer = new BusinessObjectImporter(configuration, new NullImportProgressListener());
    importer.importRow(new MapFeatureRow(row));
    BusinessObject result = BusinessObject.get(type, attributeType.getName(), value);
    try {
        Assert.assertNotNull(result);
    } finally {
        if (result != null) {
            result.delete();
        }
    }
}
Also used : HashMap(java.util.HashMap) BasicColumnFunction(net.geoprism.data.importer.BasicColumnFunction) BusinessObjectImportConfiguration(net.geoprism.registry.etl.upload.BusinessObjectImportConfiguration) NullImportProgressListener(net.geoprism.registry.etl.NullImportProgressListener) JsonObject(com.google.gson.JsonObject) JSONObject(org.json.JSONObject) VertexServerGeoObject(net.geoprism.registry.model.graph.VertexServerGeoObject) BusinessObject(net.geoprism.registry.model.BusinessObject) BusinessObjectImporter(net.geoprism.registry.etl.upload.BusinessObjectImporter) MapFeatureRow(net.geoprism.registry.excel.MapFeatureRow) BusinessObject(net.geoprism.registry.model.BusinessObject) Test(org.junit.Test) Request(com.runwaysdk.session.Request)

Aggregations

JsonObject (com.google.gson.JsonObject)3 Request (com.runwaysdk.session.Request)3 HashMap (java.util.HashMap)3 BasicColumnFunction (net.geoprism.data.importer.BasicColumnFunction)3 NullImportProgressListener (net.geoprism.registry.etl.NullImportProgressListener)3 BusinessObjectImportConfiguration (net.geoprism.registry.etl.upload.BusinessObjectImportConfiguration)3 BusinessObjectImporter (net.geoprism.registry.etl.upload.BusinessObjectImporter)3 MapFeatureRow (net.geoprism.registry.excel.MapFeatureRow)3 BusinessObject (net.geoprism.registry.model.BusinessObject)3 VertexServerGeoObject (net.geoprism.registry.model.graph.VertexServerGeoObject)3 JSONObject (org.json.JSONObject)3 Test (org.junit.Test)3 DuplicateDataException (com.runwaysdk.dataaccess.DuplicateDataException)1 BusinessObjectRecordedErrorException (net.geoprism.registry.etl.upload.BusinessObjectRecordedErrorException)1