From 731df774a8babce7d232d699f7aa9092f53e9bfb Mon Sep 17 00:00:00 2001 From: Paulo Gustavo Veiga Date: Thu, 15 Mar 2012 01:47:42 -0300 Subject: [PATCH] Add REST support for changing map title and description. --- .../wisemapping/rest/MindmapController.java | 31 +++++++ .../test/rest/RestAdminITCase.java | 1 + .../test/rest/RestMindmapTCase.java | 88 +++++++++++++------ 3 files changed, 95 insertions(+), 25 deletions(-) diff --git a/wise-webapp/src/main/java/com/wisemapping/rest/MindmapController.java b/wise-webapp/src/main/java/com/wisemapping/rest/MindmapController.java index c5e8d13e..4711e38e 100644 --- a/wise-webapp/src/main/java/com/wisemapping/rest/MindmapController.java +++ b/wise-webapp/src/main/java/com/wisemapping/rest/MindmapController.java @@ -85,6 +85,37 @@ public class MindmapController extends BaseController { updateMindmap(minor, mindMap, user); } + @RequestMapping(method = RequestMethod.PUT, value = "/maps/{id}/title", consumes = {"text/plain"}, produces = {"application/json", "text/html", "application/xml"}) + @ResponseStatus(value = HttpStatus.NO_CONTENT) + public void changeMapTitle(@RequestBody String title, @PathVariable int id) throws WiseMappingException { + + final MindMap mindMap = mindmapService.getMindmapById(id); + final User user = Utils.getUser(); + + // Is there a map with the same name ? + if (mindmapService.getMindmapByTitle(title, user) != null) { + throw new IllegalArgumentException("Map already exists with this title"); + } + + // Update map ... + final MindMap mindmap = mindmapService.getMindmapById(id); + mindmap.setTitle(title); + updateMindmap(true, mindMap, user); + } + + @RequestMapping(method = RequestMethod.PUT, value = "/maps/{id}/description", consumes = {"text/plain"}, produces = {"application/json", "text/html", "application/xml"}) + @ResponseStatus(value = HttpStatus.NO_CONTENT) + public void changeMapDescription(@RequestBody String description, @PathVariable int id) throws WiseMappingException { + + final MindMap mindMap = mindmapService.getMindmapById(id); + final User user = Utils.getUser(); + + // Update map ... + final MindMap mindmap = mindmapService.getMindmapById(id); + mindmap.setDescription(description); + updateMindmap(true, mindMap, user); + } + @RequestMapping(method = RequestMethod.DELETE, value = "/maps/{id}") @ResponseStatus(value = HttpStatus.NO_CONTENT) diff --git a/wise-webapp/src/test/java/com/wisemapping/test/rest/RestAdminITCase.java b/wise-webapp/src/test/java/com/wisemapping/test/rest/RestAdminITCase.java index 10c2e047..deb5d8a0 100644 --- a/wise-webapp/src/test/java/com/wisemapping/test/rest/RestAdminITCase.java +++ b/wise-webapp/src/test/java/com/wisemapping/test/rest/RestAdminITCase.java @@ -144,6 +144,7 @@ public class RestAdminITCase { private HttpHeaders createHeaders(@NotNull MediaType mediaType) { List acceptableMediaTypes = new ArrayList(); acceptableMediaTypes.add(mediaType); + final HttpHeaders requestHeaders = new HttpHeaders(); requestHeaders.setAccept(acceptableMediaTypes); requestHeaders.setContentType(mediaType); diff --git a/wise-webapp/src/test/java/com/wisemapping/test/rest/RestMindmapTCase.java b/wise-webapp/src/test/java/com/wisemapping/test/rest/RestMindmapTCase.java index b7084b13..60a3eea9 100644 --- a/wise-webapp/src/test/java/com/wisemapping/test/rest/RestMindmapTCase.java +++ b/wise-webapp/src/test/java/com/wisemapping/test/rest/RestMindmapTCase.java @@ -41,18 +41,18 @@ public class RestMindmapTCase { @Test(dataProvider = "ContentType-Provider-Function") public void listMaps(final @NotNull MediaType mediaType) { // Configure media types ... final HttpHeaders requestHeaders = createHeaders(mediaType); - final RestTemplate templateRest = createTemplate(); + final RestTemplate template = createTemplate(); // Create a sample map ... final String title1 = "List Maps 1 - " + mediaType.toString(); - addNewMap(requestHeaders, templateRest, title1); + addNewMap(requestHeaders, template, title1); final String title2 = "List Maps 2 - " + mediaType.toString(); - addNewMap(requestHeaders, templateRest, title2); + addNewMap(requestHeaders, template, title2); // Check that the map has been created ... final HttpEntity findMapEntity = new HttpEntity(requestHeaders); - final ResponseEntity response = templateRest.exchange(BASE_REST_URL + "/maps", HttpMethod.GET, findMapEntity, RestMindmapList.class); + final ResponseEntity response = template.exchange(BASE_REST_URL + "/maps", HttpMethod.GET, findMapEntity, RestMindmapList.class); // Validate that the two maps are there ... final RestMindmapList body = response.getBody(); @@ -75,41 +75,79 @@ public class RestMindmapTCase { @Test(dataProvider = "ContentType-Provider-Function") public void deleteMap(final @NotNull MediaType mediaType) { // Configure media types ... final HttpHeaders requestHeaders = createHeaders(mediaType); - final RestTemplate templateRest = createTemplate(); + final RestTemplate template = createTemplate(); // Create a sample map ... final String title1 = "Map to delete - " + mediaType.toString(); - final URI resourceLocation = addNewMap(requestHeaders, templateRest, title1); + final URI resourceUri = addNewMap(requestHeaders, template, title1); // Now remove it ... - templateRest.delete(HOST_PORT + resourceLocation.toString()); + template.delete(HOST_PORT + resourceUri.toString()); // Check that has been removed ... try { - findMap(requestHeaders, templateRest, resourceLocation); - fail("Map could not be removed:" + resourceLocation); + findMap(requestHeaders, template, resourceUri); + fail("Map could not be removed:" + resourceUri); } catch (Exception e) { } } - private URI addNewMap(HttpHeaders requestHeaders, RestTemplate templateRest, String title) { + @Test(dataProvider = "ContentType-Provider-Function") + public void changeMapTitle(final @NotNull MediaType mediaType) { // Configure media types ... + final HttpHeaders requestHeaders = createHeaders(mediaType); + final RestTemplate template = createTemplate(); + + // Create a sample map ... + final URI resourceUri = addNewMap(requestHeaders, template, "Map to change title - " + mediaType.toString()); + + // Change map title ... + requestHeaders.setContentType(MediaType.TEXT_PLAIN); + final String newTitle = "New map to change title - " + mediaType.toString(); + final HttpEntity updateEntity = new HttpEntity(newTitle, requestHeaders); + template.put(HOST_PORT + resourceUri + "/title", updateEntity); + + // Load map again .. + final RestMindmap map = findMap(requestHeaders, template, resourceUri); + assertEquals(newTitle, map.getTitle()); + } + + @Test(dataProvider = "ContentType-Provider-Function") + public void changeMapDescription(final @NotNull MediaType mediaType) { // Configure media types ... + final HttpHeaders requestHeaders = createHeaders(mediaType); + final RestTemplate template = createTemplate(); + + // Create a sample map ... + final URI resourceUri = addNewMap(requestHeaders, template, "Map to change title - " + mediaType.toString()); + + // Change map title ... + requestHeaders.setContentType(MediaType.TEXT_PLAIN); + final String newDescription = "New map to change title - " + mediaType.toString(); + final HttpEntity updateEntity = new HttpEntity(newDescription, requestHeaders); + template.put(HOST_PORT + resourceUri + "/description", updateEntity); + + // Load map again .. + final RestMindmap map = findMap(requestHeaders, template, resourceUri); + assertEquals(newDescription, map.getDescription()); + } + + private URI addNewMap(HttpHeaders requestHeaders, RestTemplate template, String title) { final RestMindmapInfo restMindmap = new RestMindmapInfo(); restMindmap.setTitle(title); restMindmap.setDescription("My Map Desc"); // Create a new map ... HttpEntity createUserEntity = new HttpEntity(restMindmap, requestHeaders); - return templateRest.postForLocation(BASE_REST_URL + "/maps", createUserEntity); + return template.postForLocation(BASE_REST_URL + "/maps", createUserEntity); } @Test(dataProvider = "ContentType-Provider-Function") public void discardChange(final @NotNull MediaType mediaType) { // Configure media types ... final HttpHeaders requestHeaders = createHeaders(mediaType); - final RestTemplate templateRest = createTemplate(); + final RestTemplate template = createTemplate(); // Create a sample map ... final String title = "Add map to discard " + mediaType.toString(); - final URI resourceLocation = addNewMap(requestHeaders, templateRest, title); + final URI resourceUri = addNewMap(requestHeaders, template, title); // Update with "minor" flag ... @@ -121,38 +159,38 @@ public class RestMindmapTCase { @Test(dataProvider = "ContentType-Provider-Function") public void updateMapXml(final @NotNull MediaType mediaType) throws IOException { // Configure media types ... final HttpHeaders requestHeaders = createHeaders(mediaType); - final RestTemplate templateRest = createTemplate(); + final RestTemplate template = createTemplate(); // Create a sample map ... final String title = "Update XML sample " + mediaType.toString(); - final URI resourceLocation = addNewMap(requestHeaders, templateRest, title); + final URI resourceUri = addNewMap(requestHeaders, template, title); // Update map xml content ... - final String resourceUrl = HOST_PORT + resourceLocation.toString(); + final String resourceUrl = HOST_PORT + resourceUri.toString(); requestHeaders.setContentType(MediaType.APPLICATION_XML); final String newXmlContent = "this is not valid"; HttpEntity updateEntity = new HttpEntity(newXmlContent, requestHeaders); - templateRest.put(resourceUrl + "/xml", updateEntity); + template.put(resourceUrl + "/xml", updateEntity); // Check that the map has been updated ... - final RestMindmap response = findMap(requestHeaders, templateRest, resourceLocation); + final RestMindmap response = findMap(requestHeaders, template, resourceUri); assertEquals(response.getXml(), newXmlContent); } - private RestMindmap findMap(HttpHeaders requestHeaders, RestTemplate templateRest, URI resourceLocation) { + private RestMindmap findMap(HttpHeaders requestHeaders, RestTemplate template, URI resourceUri) { final HttpEntity findMapEntity = new HttpEntity(requestHeaders); - final ResponseEntity response = templateRest.exchange(HOST_PORT + resourceLocation.toString(), HttpMethod.GET, findMapEntity, RestMindmap.class); + final ResponseEntity response = template.exchange(HOST_PORT + resourceUri.toString(), HttpMethod.GET, findMapEntity, RestMindmap.class); return response.getBody(); } @Test(dataProvider = "ContentType-Provider-Function") public void updateMap(final @NotNull MediaType mediaType) throws IOException { // Configure media types ... final HttpHeaders requestHeaders = createHeaders(mediaType); - final RestTemplate templateRest = createTemplate(); + final RestTemplate template = createTemplate(); // Create a sample map ... final String title = "Update sample " + mediaType.toString(); - final URI resourceLocation = addNewMap(requestHeaders, templateRest, title); + final URI resourceUri = addNewMap(requestHeaders, template, title); // Build map to update ... final RestMindmap mapToUpdate = new RestMindmap(); @@ -160,14 +198,14 @@ public class RestMindmapTCase { mapToUpdate.setProperties("{zoom:x}"); // Update map ... - final String resourceUrl = HOST_PORT + resourceLocation.toString(); + final String resourceUrl = HOST_PORT + resourceUri.toString(); requestHeaders.setContentType(MediaType.APPLICATION_XML); final HttpEntity updateEntity = new HttpEntity(mapToUpdate, requestHeaders); - templateRest.put(resourceUrl, updateEntity); + template.put(resourceUrl, updateEntity); // Check that the map has been updated ... HttpEntity findUserEntity = new HttpEntity(requestHeaders); - final ResponseEntity response = templateRest.exchange(HOST_PORT + resourceLocation.toString(), HttpMethod.GET, findUserEntity, RestMindmap.class); + final ResponseEntity response = template.exchange(HOST_PORT + resourceUri.toString(), HttpMethod.GET, findUserEntity, RestMindmap.class); assertEquals(response.getBody().getXml(), mapToUpdate.getXml()); assertEquals(response.getBody().getProperties(), mapToUpdate.getProperties()); }