Workaround for GEOS-5986

This commit is contained in:
etj 2013-08-22 16:56:58 +02:00
parent 7deaac685f
commit 685c0d9d98
3 changed files with 38 additions and 21 deletions

View File

@ -27,6 +27,8 @@ package it.geosolutions.geoserver.rest;
import it.geosolutions.geoserver.rest.decoder.RESTCoverage; import it.geosolutions.geoserver.rest.decoder.RESTCoverage;
import it.geosolutions.geoserver.rest.decoder.RESTCoverageStore; import it.geosolutions.geoserver.rest.decoder.RESTCoverageStore;
import it.geosolutions.geoserver.rest.decoder.RESTStructuredCoverageGranulesList; import it.geosolutions.geoserver.rest.decoder.RESTStructuredCoverageGranulesList;
import it.geosolutions.geoserver.rest.decoder.RESTStyleList;
import it.geosolutions.geoserver.rest.decoder.utils.NameLinkElem;
import it.geosolutions.geoserver.rest.encoder.GSBackupEncoder; import it.geosolutions.geoserver.rest.encoder.GSBackupEncoder;
import it.geosolutions.geoserver.rest.encoder.GSLayerEncoder; import it.geosolutions.geoserver.rest.encoder.GSLayerEncoder;
import it.geosolutions.geoserver.rest.encoder.GSLayerGroupEncoder; import it.geosolutions.geoserver.rest.encoder.GSLayerGroupEncoder;
@ -2102,6 +2104,9 @@ public class GeoServerRESTPublisher {
workspace); workspace);
if (recurse) if (recurse)
url.append("?recurse=true"); url.append("?recurse=true");
deleteStylesForWorkspace(workspace); // !!! workaround
final URL deleteUrl = new URL(url.toString()); final URL deleteUrl = new URL(url.toString());
boolean deleted = HTTPUtils.delete(deleteUrl.toExternalForm(), gsuser, gspass); boolean deleted = HTTPUtils.delete(deleteUrl.toExternalForm(), gsuser, gspass);
if (!deleted) { if (!deleted) {
@ -2118,6 +2123,17 @@ public class GeoServerRESTPublisher {
} }
} }
/**
* workaround: geoserver does not delete styles inside workspaces
* https://jira.codehaus.org/browse/GEOS-5986
*/
private void deleteStylesForWorkspace(String workspace) {
RESTStyleList styles = styleManager.getStyles(workspace);
for (NameLinkElem nameLinkElem : styles) {
removeStyleInWorkspace(workspace, nameLinkElem.getName(), true);
}
}
/** /**
* Remove a layer group. * Remove a layer group.
* *

View File

@ -26,6 +26,8 @@
package it.geosolutions.geoserver.rest; package it.geosolutions.geoserver.rest;
import it.geosolutions.geoserver.rest.decoder.RESTStyle; import it.geosolutions.geoserver.rest.decoder.RESTStyle;
import java.util.ArrayList;
import java.util.List;
/** /**
* *
@ -36,18 +38,20 @@ public class Util {
/** /**
* Search for a stylename in global and in all workspaces. * Search for a stylename in global and in all workspaces.
*/ */
public static RESTStyle searchStyle(GeoServerRESTReader reader, String stylename) { public static List<RESTStyle> searchStyles(GeoServerRESTReader reader, String stylename) {
List<RESTStyle> styles = new ArrayList<RESTStyle>();
RESTStyle style = reader.getStyle(stylename); RESTStyle style = reader.getStyle(stylename);
if(style != null) if(style != null)
return style; styles.add(style);
for (String workspace : reader.getWorkspaceNames()) { for (String workspace : reader.getWorkspaceNames()) {
style = reader.getStyle(workspace, stylename); style = reader.getStyle(workspace, stylename);
if(style != null) if(style != null)
return style; styles.add(style);
} }
return null; return styles;
} }
} }

View File

@ -31,6 +31,7 @@ import it.geosolutions.geoserver.rest.decoder.RESTStyle;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.List;
import org.junit.Test; import org.junit.Test;
import static org.junit.Assert.*; import static org.junit.Assert.*;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -54,15 +55,14 @@ public class UtilTest extends GeoserverRESTTest {
final String WORKSPACE = "testWorkspace"; final String WORKSPACE = "testWorkspace";
final String STYLENAME = "restteststyle"; final String STYLENAME = "restteststyle";
final String STYLENAME2 = "restteststyle2";
File sldFile = new ClassPathResource("testdata/restteststyle.sld").getFile(); File sldFile = new ClassPathResource("testdata/restteststyle.sld").getFile();
publisher.createWorkspace(WORKSPACE); publisher.createWorkspace(WORKSPACE);
assertEquals(0, reader.getStyles().size()); assertEquals(0, reader.getStyles().size());
assertEquals(0, reader.getStyles(WORKSPACE).size()); assertEquals(0, reader.getStyles(WORKSPACE).size());
assertNull(Util.searchStyle(reader, STYLENAME)); assertEquals(0, Util.searchStyles(reader, STYLENAME).size());
assertNull(Util.searchStyle(reader, STYLENAME2));
// insert style in workspace // insert style in workspace
assertTrue(publisher.publishStyleInWorkspace(WORKSPACE, sldFile, STYLENAME)); assertTrue(publisher.publishStyleInWorkspace(WORKSPACE, sldFile, STYLENAME));
@ -70,29 +70,26 @@ public class UtilTest extends GeoserverRESTTest {
assertFalse(reader.existsStyle(STYLENAME)); assertFalse(reader.existsStyle(STYLENAME));
assertEquals(0, reader.getStyles().size()); assertEquals(0, reader.getStyles().size());
assertEquals(1, reader.getStyles(WORKSPACE).size()); assertEquals(1, reader.getStyles(WORKSPACE).size());
assertNotNull(Util.searchStyle(reader, STYLENAME)); assertEquals(1, Util.searchStyles(reader, STYLENAME).size());
assertNull(Util.searchStyle(reader, STYLENAME2));
// insert global style // insert global style
assertTrue(publisher.publishStyle(sldFile, STYLENAME2)); assertTrue(publisher.publishStyle(sldFile, STYLENAME));
assertFalse(reader.existsStyle(STYLENAME));
assertTrue(reader.existsStyle(STYLENAME2));
assertTrue(reader.existsStyle(STYLENAME));
assertTrue(reader.existsStyle(WORKSPACE, STYLENAME)); assertTrue(reader.existsStyle(WORKSPACE, STYLENAME));
assertFalse(reader.existsStyle(WORKSPACE, STYLENAME2));
assertEquals(2, Util.searchStyles(reader, STYLENAME).size());
assertEquals(1, reader.getStyles().size()); assertEquals(1, reader.getStyles().size());
assertEquals(1, reader.getStyles(WORKSPACE).size()); assertEquals(1, reader.getStyles(WORKSPACE).size());
RESTStyle style; List<RESTStyle> styles = Util.searchStyles(reader, STYLENAME);
style = Util.searchStyle(reader, STYLENAME);
assertEquals(STYLENAME, style.getName());
assertEquals(WORKSPACE, style.getWorkspace());
style = Util.searchStyle(reader, STYLENAME2); assertEquals(STYLENAME, styles.get(0).getName());
assertEquals(STYLENAME2, style.getName()); assertEquals(null, styles.get(0).getWorkspace()); // first one is the global one, if any
assertEquals(null, style.getWorkspace());
assertEquals(STYLENAME, styles.get(1).getName());
assertEquals(WORKSPACE, styles.get(1).getWorkspace());
} }
} }