import java.awt.Color;\r
import java.io.IOException;\r
import java.io.InputStream;\r
+import java.io.InputStreamReader;\r
import java.net.HttpURLConnection;\r
import java.net.MalformedURLException;\r
import java.net.URI;\r
import org.apache.commons.lang.StringUtils;\r
import org.apache.http.client.ClientProtocolException;\r
import org.apache.log4j.Logger;\r
+import org.junit.Assert;\r
import org.junit.Before;\r
import org.junit.Test;\r
import org.unitils.spring.annotation.SpringBeanByType;\r
\r
import eu.etaxonomy.cdm.api.service.ITermService;\r
+import eu.etaxonomy.cdm.api.service.IVocabularyService;\r
import eu.etaxonomy.cdm.common.StreamUtils;\r
import eu.etaxonomy.cdm.common.UriUtils;\r
+import eu.etaxonomy.cdm.model.common.DefinedTermBase;\r
import eu.etaxonomy.cdm.model.common.Language;\r
import eu.etaxonomy.cdm.model.common.TermType;\r
import eu.etaxonomy.cdm.model.common.TermVocabulary;\r
import eu.etaxonomy.cdm.model.description.Distribution;\r
import eu.etaxonomy.cdm.model.description.PresenceAbsenceTermBase;\r
import eu.etaxonomy.cdm.model.description.PresenceTerm;\r
+import eu.etaxonomy.cdm.model.location.Country;\r
import eu.etaxonomy.cdm.model.location.NamedArea;\r
import eu.etaxonomy.cdm.model.location.NamedAreaLevel;\r
import eu.etaxonomy.cdm.model.location.NamedAreaType;\r
import eu.etaxonomy.cdm.persistence.dao.common.IDefinedTermDao;\r
-import eu.etaxonomy.cdm.test.integration.CdmIntegrationTest;\r
+import eu.etaxonomy.cdm.test.integration.CdmTransactionalIntegrationTest;\r
\r
/**\r
* @author a.mueller\r
* @created 08.10.2008\r
*/\r
-public class EditGeoServiceTest extends CdmIntegrationTest {\r
+public class EditGeoServiceTest extends CdmTransactionalIntegrationTest {\r
private static final Logger logger = Logger.getLogger(EditGeoServiceTest.class);\r
\r
private static final String EDIT_MAPSERVICE_URI_STING = "http://edit.africamuseum.be/edit_wp5/v1.2/rest_gen.php";\r
@SpringBeanByType\r
private ITermService termService;\r
\r
+ @SpringBeanByType\r
+ private IVocabularyService vocabService;\r
+\r
@SpringBeanByType\r
private GeoServiceAreaAnnotatedMapping mapping;\r
\r
+ @SpringBeanByType\r
+ private IEditGeoService editGeoService;\r
//\r
// /**\r
// * @throws java.lang.Exception\r
\r
\r
//******************************************** TESTS**************\r
+\r
+ @Test\r
+ public void testGetWebServiceUrlCountry() throws MalformedURLException, IOException {\r
+ Set<Distribution> distributions = new HashSet<Distribution>();\r
+ Country germany = termService.findByIdInVocabulary("DEU", Country.uuidCountryVocabulary, Country.class);\r
+// germany = (Country)termService.find(665);\r
+// germany = (Country)termService.find(UUID.fromString("cbe7ce69-2952-4309-85dd-0d7d4a4830a1"));\r
+\r
+// germany = Country.GERMANY();\r
+\r
+ distributions.add(Distribution.NewInstance(germany, PresenceTerm.PRESENT()));\r
+ distributions.add(Distribution.NewInstance(termService.findByIdInVocabulary("DE", Country.uuidCountryVocabulary, Country.class), PresenceTerm.INTRODUCED()));\r
+ Map<PresenceAbsenceTermBase<?>, Color> presenceAbsenceColorMap = new HashMap<PresenceAbsenceTermBase<?>, Color>();\r
+ presenceAbsenceColorMap.put(PresenceTerm.PRESENT(), Color.BLUE);\r
+ presenceAbsenceColorMap.put(PresenceTerm.INTRODUCED(), Color.BLACK);\r
+ List<Language> languages = new ArrayList<Language>();\r
+\r
+ boolean subAreaPreference = false;\r
+ boolean statusOrderPreference = false;\r
+ String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions,\r
+ subAreaPreference, statusOrderPreference, null, mapping,\r
+ presenceAbsenceColorMap, null, languages );\r
+ logger.warn(result);\r
+ Assert.assertTrue("WebServiceUrl must contain country part for Germany", result.matches(".*ad=country_earth(%3A|:)gmi_cntry:a:DEU.*"));\r
+\r
+ }\r
+\r
@Test\r
public void testGetWebServiceUrlTdwg() throws MalformedURLException, IOException {\r
//String webServiceUrl = "http://www.test.de/webservice";\r
String bbox="-20,0,120,70";\r
List<Language> languages = new ArrayList<Language>();\r
\r
- String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions, mapping, presenceAbsenceColorMap, 600, 300, bbox,backLayer, null, languages );\r
+ boolean subAreaPreference = false;\r
+ boolean statusOrderPreference = false;\r
+ String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions,\r
+ subAreaPreference ,\r
+ statusOrderPreference,\r
+ null, mapping, presenceAbsenceColorMap, null, languages );\r
//TODO Set semantics is not determined\r
//String expected = "http://www.test.de/webservice?l=tdwg3&ad=tdwg3:a:GER|b:OKL|c:BGM|b:SPA|d:FRA&as=a:005500|b:00FF00|c:FFFFFF|d:001100&bbox=-20,40,40,40&ms=400x300";\r
- System.out.println(result);\r
-// assertTrue(result.matches(".*l=earth.*"));\r
- assertTrue(result.matches(".*ms=600,300.*"));\r
+ logger.debug(result);\r
assertTrue(result.matches(".*ad=tdwg[1-4].*"));\r
assertTrue(result.matches(".*tdwg2:[a-d]:14[\\|&].*") );\r
assertTrue(result.matches(".*[a-d]:FRA,BGM[\\|&].*") || result.matches(".*[a-d]:BGM,FRA[\\|&].*") );\r
assertTrue(result.matches(".*[a-d]:GER[\\|&].*") );\r
assertTrue(result.matches(".*[a-d]:SPA[\\|&].*") );\r
-// assertTrue(result.matches(".*tdwg4:[a-d]:INDAP[\\|&].*") );\r
- assertTrue(result.matches(".*tdwg4:[a-h]:INDAP[\\|&].*") );\r
+ assertTrue(result.matches(".*tdwg4:[a-d]:INDAP[\\|&].*") );\r
//assertTrue(result.matches("0000ff"));\r
//TODO continue\r
\r
String bbox="-20,0,120,70";\r
List<Language> languages = new ArrayList<Language>();\r
\r
- String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions, mapping, presenceAbsenceColorMap, 600, 300, bbox,backLayer, null, languages );\r
+ boolean subAreaPreference = false;\r
+ boolean statusOrderPreference = false;\r
+ String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions,\r
+ subAreaPreference ,\r
+ statusOrderPreference,\r
+ null, mapping, presenceAbsenceColorMap, null, languages );\r
//TODO Set semantics is not determined\r
//String expected = "http://www.test.de/webservice?l=tdwg3&ad=tdwg3:a:GER|b:OKL|c:BGM|b:SPA|d:FRA&as=a:005500|b:00FF00|c:FFFFFF|d:001100&bbox=-20,40,40,40&ms=400x300";\r
-// assertTrue(result.matches(".*l=earth.*"));\r
- assertTrue(result.matches(".*ms=600,300.*"));\r
assertTrue(result.matches(".*ad=cyprusdivs%3Abdcode:.*"));\r
assertTrue(result.matches(".*[a-d]:5,4[\\|&].*") || result.matches(".*[a-d]:4,5[\\|&].*") );\r
assertTrue(result.matches(".*[a-d]:1,6[\\|&].*") || result.matches(".*[a-d]:6,1[\\|&].*") );\r
subTestWithEditMapService(result);\r
}\r
\r
- private void subTestWithEditMapService(String result)throws MalformedURLException, IOException {\r
+ private void subTestWithEditMapService(String queryString)throws MalformedURLException, IOException {\r
if(UriUtils.isServiceAvailable(editMapServiceUri)){\r
- URL requestUrl = new URL(editMapServiceUri.toString() + "?img=false&" + result);\r
+ URL requestUrl = new URL(editMapServiceUri.toString() + "?img=false&bbox=-180,-90,180,90&ms=1000&" + queryString);\r
logger.debug("editMapServiceUri: " + requestUrl);\r
HttpURLConnection connection = (HttpURLConnection) requestUrl.openConnection();\r
connection.connect();\r
public static final UUID uuidCyprusDivisionsVocabulary = UUID.fromString("2119f610-1f93-4d87-af28-40aeefaca100");\r
private final Map<String, NamedArea> divisions = new HashMap<String, NamedArea>();\r
\r
- private boolean makeCyprusAreas() {\r
+ private boolean makeCyprusAreas() throws IOException {\r
//divisions\r
\r
\r
NamedAreaType areaType = NamedAreaType.NATURAL_AREA();\r
NamedAreaLevel areaLevel = NamedAreaLevel.NewInstance("Cyprus Division", "Cyprus Division", null);\r
\r
+ termService.saveOrUpdate(areaLevel);\r
+\r
TermVocabulary<NamedArea> areaVocabulary = TermVocabulary.NewInstance(TermType.NamedArea, "Cyprus devisions", "Cyprus divisions", null, null);\r
areaVocabulary.setUuid(uuidCyprusDivisionsVocabulary);\r
\r
+\r
for(int i = 1; i <= 8; i++){\r
UUID divisionUuid = getNamedAreaUuid(String.valueOf(i));\r
NamedArea division = this.newNamedArea(\r
divisions.put(String.valueOf(i), division);\r
}\r
\r
+ vocabService.saveOrUpdate(areaVocabulary);\r
+ commitAndStartNewTransaction(null);\r
+\r
+\r
+ // import and map shapefile attributes from csv\r
+ InputStream is = getClass().getClassLoader().getResourceAsStream("eu/etaxonomy/cdm/ext/geo/cyprusdivs.csv");\r
+ List<String> idSearchFields = new ArrayList<String>();\r
+ idSearchFields.add("bdcode");\r
+ String wmsLayerName = "cyprusdivs";\r
+ editGeoService.mapShapeFileToNamedAreas(new InputStreamReader(is), idSearchFields, wmsLayerName, uuidCyprusDivisionsVocabulary, null);\r
+\r
+ divisions.clear();\r
+ Set<DefinedTermBase> terms = vocabService.load(uuidCyprusDivisionsVocabulary).getTerms();\r
+ for(DefinedTermBase dtb : terms){\r
+ divisions.put(dtb.getIdInVocabulary(), (NamedArea) dtb);\r
+ }\r
+\r
+\r
// indigenousStatus = (PresenceTerm)getTermService().find(CyprusTransformer.indigenousUuid);\r
// casualStatus = (PresenceTerm)getTermService().find(CyprusTransformer.casualUuid);\r
// nonInvasiveStatus = (PresenceTerm)getTermService().find(CyprusTransformer.nonInvasiveUuid);\r
Map<PresenceAbsenceTermBase<?>, Color> presenceAbsenceColorMap = new HashMap<PresenceAbsenceTermBase<?>, Color>();\r
presenceAbsenceColorMap.put(PresenceTerm.PRESENT(), Color.BLUE);\r
\r
- String backLayer ="";\r
presenceAbsenceColorMap = null;\r
- String bbox="90,-8,130,8";\r
List<Language> languages = new ArrayList<Language>();\r
\r
- String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions, mapping, presenceAbsenceColorMap, 600, 300, bbox,backLayer, null, languages );\r
+ boolean subAreaPreference = false;\r
+ boolean statusOrderPreference = false;\r
+ String result = EditGeoServiceUtilities.getDistributionServiceRequestParameterString(distributions,\r
+ subAreaPreference ,\r
+ statusOrderPreference,\r
+ null, mapping, presenceAbsenceColorMap, null, languages );\r
//TODO Set semantics is not determined\r
//String expected = "http://www.test.de/webservice?l=tdwg3&ad=tdwg3:a:GER|b:OKL|c:BGM|b:SPA|d:FRA&as=a:005500|b:00FF00|c:FFFFFF|d:001100&bbox=-20,40,40,40&ms=400x300";\r
\r
- System.out.println(result);\r
-\r
-// assertTrue(result.matches(".*l=earth.*"));\r
- assertTrue(result.matches(".*ms=600,300.*"));\r
+ logger.debug(result);\r
assertTrue(result.matches(".*ad=vmap0_as_bnd_political_boundary_a%3Anam:.*"));\r
assertTrue(result.matches(".*(PULAU\\+BANGKA%23SUMATERA\\+SELATAN).*") );\r
assertTrue(result.matches(".*(BALI).*") );\r