use of com.sldeditor.datasource.checks.CheckAttributeInterface in project sldeditor by robward-scisys.
the class DataSourceImpl method connect.
/**
* Connect to data source.
*
* @param typeName the type name
* @param editorFile the editor file
* @param checkList the check list
*/
@Override
public void connect(String typeName, SLDEditorFileInterface editorFile, List<CheckAttributeInterface> checkList) {
logger.debug("connect : " + typeName);
reset();
this.editorFileInterface = editorFile;
if (editorFileInterface != null) {
this.dataSourceProperties = editorFileInterface.getDataSource();
if (this.dataSourceProperties != null) {
if (this.dataSourceProperties.isEmpty()) {
openWithoutDataSource();
} else {
openExternalDataSource(typeName);
}
// Create the example data to show in the render panel
createExampleDataSource();
createUserLayerDataSources();
// Report any attributes used in SLD but not in data source
if (checkList != null) {
for (CheckAttributeInterface check : checkList) {
check.checkAttributes(editorFile);
}
}
notifyDataSourceLoaded();
} else {
logger.error("dataSourceProperties is empty");
}
}
}
use of com.sldeditor.datasource.checks.CheckAttributeInterface in project sldeditor by robward-scisys.
the class VectorToolTest method testVectorToolDBDataSource.
@Test
public void testVectorToolDBDataSource() {
TestMissingSLDAttributes testAttribute = new TestMissingSLDAttributes();
List<CheckAttributeInterface> checkList = new ArrayList<CheckAttributeInterface>();
checkList.add(testAttribute);
CheckAttributeFactory.setOverideCheckList(checkList);
String testsldfile = "/polygon/sld/polygon_polygonwithdefaultlabel.sld";
TestSLDEditor testSLDEditor = null;
try {
testSLDEditor = TestSLDEditor.createAndShowGUI2(null, null, true, null);
} catch (Exception e) {
e.printStackTrace();
}
RenderPanelImpl.setUnderTest(true);
InputStream inputStream = VectorToolTest.class.getResourceAsStream(testsldfile);
if (inputStream == null) {
Assert.assertNotNull("Failed to find sld test file : " + testsldfile, inputStream);
} else {
File f = null;
try {
f = stream2file(inputStream);
try {
testSLDEditor.openFile(f.toURI().toURL());
} catch (NullPointerException nullException) {
nullException.printStackTrace();
StackTraceElement[] stackTraceElements = nullException.getStackTrace();
System.out.println(stackTraceElements[0].getMethodName());
}
f.delete();
} catch (IOException e1) {
e1.printStackTrace();
}
}
// Fields extracted from the SLD file
DataSourceInterface dataSource = DataSourceFactory.createDataSource(null);
Collection<PropertyDescriptor> propertyList = dataSource.getPropertyDescriptorList();
assertEquals(2, propertyList.size());
Map<String, PropertyDescriptor> map = new HashMap<String, PropertyDescriptor>();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
AttributeDescriptor name = (AttributeDescriptor) map.get("name");
assertNotNull(name);
GeometryDescriptor geometry = (GeometryDescriptor) map.get("geom");
assertNotNull(geometry);
File tempFolder = Files.createTempDir();
TestVectorTool vectorTool = new TestVectorTool(testSLDEditor);
try {
InputStream gpkgInputStream = VectorToolTest.class.getResourceAsStream("/test/sld_cookbook_polygon.gpkg");
final File gpkgFile = new File(tempFolder, "sld_cookbook_polygon.gpkg");
try (FileOutputStream out = new FileOutputStream(gpkgFile)) {
IOUtils.copy(gpkgInputStream, out);
}
DatabaseConnection databaseConnection = DatabaseConnectionFactory.getConnection(gpkgFile.getAbsolutePath());
DatabaseFeatureClassNode dbFCTreeNode = new DatabaseFeatureClassNode(null, databaseConnection, "sld_cookbook_polygon");
DatabaseConnectionManager.getInstance().addNewConnection(null, databaseConnection);
vectorTool.testSetDataSource(dbFCTreeNode);
dataSource = DataSourceFactory.createDataSource(null);
propertyList = dataSource.getPropertyDescriptorList();
assertEquals(3, propertyList.size());
map.clear();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
name = (AttributeDescriptor) map.get("name");
assertNotNull(name);
geometry = (GeometryDescriptor) map.get("geometry");
assertNotNull(geometry);
AttributeDescriptor pop = (AttributeDescriptor) map.get("pop");
assertNotNull(pop);
// Create SLD from geopackage layer
vectorTool.testImportFeatureClass(dbFCTreeNode);
dataSource = DataSourceFactory.createDataSource(null);
propertyList = dataSource.getPropertyDescriptorList();
assertEquals(3, propertyList.size());
map.clear();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
name = (AttributeDescriptor) map.get("name");
assertNotNull(name);
geometry = (GeometryDescriptor) map.get("geometry");
assertNotNull(geometry);
pop = (AttributeDescriptor) map.get("pop");
assertNotNull(pop);
// Release locks
dataSource.reset();
} catch (IOException e) {
e.printStackTrace();
fail();
}
// Tidy up so the remaining unit tests are ok
JFrame frame = testSLDEditor.getApplicationFrame();
frame.dispatchEvent(new WindowEvent(frame, WindowEvent.WINDOW_CLOSING));
testSLDEditor = null;
clearDown();
// Delete the shape files we extracted
purgeDirectory(tempFolder);
}
use of com.sldeditor.datasource.checks.CheckAttributeInterface in project sldeditor by robward-scisys.
the class VectorToolTest method testVectorToolFileDataSource.
/**
* Test method for {@link com.sldeditor.tool.vector.VectorTool#VectorTool(com.sldeditor.common.SLDEditorInterface)}.
*/
@Test
public void testVectorToolFileDataSource() {
TestMissingSLDAttributes testAttribute = new TestMissingSLDAttributes();
List<CheckAttributeInterface> checkList = new ArrayList<CheckAttributeInterface>();
checkList.add(testAttribute);
CheckAttributeFactory.setOverideCheckList(checkList);
String testsldfile = "/polygon/sld/polygon_polygonwithdefaultlabel.sld";
TestSLDEditor testSLDEditor = null;
try {
testSLDEditor = TestSLDEditor.createAndShowGUI2(null, null, true, null);
} catch (Exception e) {
e.printStackTrace();
}
InputStream inputStream = VectorToolTest.class.getResourceAsStream(testsldfile);
if (inputStream == null) {
Assert.assertNotNull("Failed to find sld test file : " + testsldfile, inputStream);
} else {
File f = null;
try {
f = stream2file(inputStream);
try {
testSLDEditor.openFile(f.toURI().toURL());
} catch (NullPointerException nullException) {
nullException.printStackTrace();
StackTraceElement[] stackTraceElements = nullException.getStackTrace();
System.out.println(stackTraceElements[0].getMethodName());
}
f.delete();
} catch (IOException e1) {
e1.printStackTrace();
}
}
// Fields extracted from the SLD file
DataSourceInterface dataSource = DataSourceFactory.createDataSource(null);
Collection<PropertyDescriptor> propertyList = dataSource.getPropertyDescriptorList();
assertEquals(2, propertyList.size());
Map<String, PropertyDescriptor> map = new HashMap<String, PropertyDescriptor>();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
AttributeDescriptor name = (AttributeDescriptor) map.get("name");
assertNotNull(name);
GeometryDescriptor geometry = (GeometryDescriptor) map.get("geom");
assertNotNull(geometry);
File tempFolder = Files.createTempDir();
TestVectorTool vectorTool = new TestVectorTool(testSLDEditor);
try {
// Set a shape file as a data source - that matches the SLD
File matchingShpFile = extractShapeFile(tempFolder, "/test/sld_cookbook_polygon.zip");
FileTreeNode fileTreeNode = new FileTreeNode(matchingShpFile.getParentFile(), matchingShpFile.getName());
vectorTool.testSetDataSource(fileTreeNode);
dataSource = DataSourceFactory.createDataSource(null);
propertyList = dataSource.getPropertyDescriptorList();
assertEquals(3, propertyList.size());
map.clear();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
name = (AttributeDescriptor) map.get("name");
assertNotNull(name);
geometry = (GeometryDescriptor) map.get("the_geom");
assertNotNull(geometry);
AttributeDescriptor pop = (AttributeDescriptor) map.get("pop");
assertNotNull(pop);
// Set a shape file as a data source - that does not match the SLD
File nonMatchingShpFile = extractShapeFile(tempFolder, "/test/states.zip");
FileTreeNode fileTreeNode2 = new FileTreeNode(nonMatchingShpFile.getParentFile(), nonMatchingShpFile.getName());
vectorTool.testSetDataSource(fileTreeNode2);
dataSource = DataSourceFactory.createDataSource(null);
propertyList = dataSource.getPropertyDescriptorList();
assertEquals(23, propertyList.size());
map.clear();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
name = (AttributeDescriptor) map.get("name");
assertNull(name);
geometry = (GeometryDescriptor) map.get("the_geom");
assertNotNull(geometry);
pop = (AttributeDescriptor) map.get("pop");
assertNull(pop);
assertEquals(1, testAttribute.getMissingFieldList().size());
assertEquals("name", testAttribute.getMissingFieldList().get(0));
// Create SLD from shape file
vectorTool.testImportFile(fileTreeNode);
dataSource = DataSourceFactory.createDataSource(null);
propertyList = dataSource.getPropertyDescriptorList();
assertEquals(3, propertyList.size());
map.clear();
for (PropertyDescriptor property : propertyList) {
map.put(property.getName().getLocalPart(), property);
}
name = (AttributeDescriptor) map.get("name");
assertNotNull(name);
geometry = (GeometryDescriptor) map.get("the_geom");
assertNotNull(geometry);
pop = (AttributeDescriptor) map.get("pop");
assertNotNull(pop);
// Release locks
dataSource.reset();
} catch (IOException e) {
e.printStackTrace();
fail();
}
// Tidy up so the remaining unit tests are ok
JFrame frame = testSLDEditor.getApplicationFrame();
frame.dispatchEvent(new WindowEvent(frame, WindowEvent.WINDOW_CLOSING));
testSLDEditor = null;
clearDown();
// Delete the shape files we extracted
purgeDirectory(tempFolder);
}
Aggregations