mirror of
https://bitbucket.org/wisemapping/wisemapping-open-source.git
synced 2025-01-23 02:15:10 +01:00
Compare commits
No commits in common. "1059643b0f38540dbe1670b4c73e080f82384d52" and "56e4970861b7d1cea03d5389f405a3dc9e9f25a6" have entirely different histories.
1059643b0f
...
56e4970861
@ -57,6 +57,12 @@
|
|||||||
</exclusions>
|
</exclusions>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- <dependency>-->
|
||||||
|
<!-- <groupId>org.springframework.boot</groupId>-->
|
||||||
|
<!-- <artifactId>spring-boot-devtools</artifactId>-->
|
||||||
|
<!-- <optional>true</optional>-->
|
||||||
|
<!-- </dependency>-->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework</groupId>
|
<groupId>org.springframework</groupId>
|
||||||
<artifactId>spring-test</artifactId>
|
<artifactId>spring-test</artifactId>
|
||||||
@ -213,10 +219,6 @@
|
|||||||
</dependencies>
|
</dependencies>
|
||||||
<build>
|
<build>
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-surefire-plugin</artifactId>
|
|
||||||
</plugin>
|
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||||
|
@ -73,7 +73,7 @@ public class Label implements Serializable {
|
|||||||
return title;
|
return title;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setTitle(String title) {
|
public void setTitle(@NotNull String title) {
|
||||||
this.title = title;
|
this.title = title;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -85,12 +85,12 @@ public class Label implements Serializable {
|
|||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@NotNull
|
||||||
public String getColor() {
|
public String getColor() {
|
||||||
return color;
|
return color;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setColor(String color) {
|
public void setColor(@NotNull String color) {
|
||||||
this.color = color;
|
this.color = color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ public class RestLabel {
|
|||||||
this.label = label;
|
this.label = label;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setParent(final Label parent) {
|
public void setParent(@NotNull final Label parent) {
|
||||||
this.label.setParent(parent);
|
this.label.setParent(parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +56,7 @@ public class RestLabel {
|
|||||||
label.setTitle(title);
|
label.setTitle(title);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setColor(final String color) {
|
public void setColor(@NotNull final String color) {
|
||||||
label.setColor(color);
|
label.setColor(color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,21 +55,17 @@ public class LabelValidator implements Validator {
|
|||||||
ValidationUtils.rejectIfEmptyOrWhitespace(errors, "title", Messages.FIELD_REQUIRED);
|
ValidationUtils.rejectIfEmptyOrWhitespace(errors, "title", Messages.FIELD_REQUIRED);
|
||||||
ValidationUtils.rejectIfEmptyOrWhitespace(errors, "color", Messages.FIELD_REQUIRED);
|
ValidationUtils.rejectIfEmptyOrWhitespace(errors, "color", Messages.FIELD_REQUIRED);
|
||||||
final String title = label.getTitle();
|
final String title = label.getTitle();
|
||||||
|
|
||||||
ValidatorUtils.rejectIfExceeded(
|
ValidatorUtils.rejectIfExceeded(
|
||||||
errors,
|
errors,
|
||||||
"title",
|
"title",
|
||||||
"The description must have less than " + Constants.MAX_LABEL_NAME_LENGTH + " characters.",
|
"The description must have less than " + Constants.MAX_LABEL_NAME_LENGTH + " characters.",
|
||||||
title,
|
title,
|
||||||
Constants.MAX_LABEL_NAME_LENGTH);
|
Constants.MAX_LABEL_NAME_LENGTH);
|
||||||
|
|
||||||
final User user = com.wisemapping.security.Utils.getUser();
|
final User user = com.wisemapping.security.Utils.getUser();
|
||||||
if (user != null && title != null) {
|
assert user != null;
|
||||||
final Label foundLabel = service.getLabelByTitle(title, user);
|
final Label foundLabel = service.getLabelByTitle(title, user);
|
||||||
if (foundLabel != null) {
|
if (foundLabel != null) {
|
||||||
errors.rejectValue("title", Messages.LABEL_TITLE_ALREADY_EXISTS);
|
errors.rejectValue("title", Messages.LABEL_TITLE_ALREADY_EXISTS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,7 @@ spring.sql.init.mode=always
|
|||||||
spring.sql.init.platform=hsqldb
|
spring.sql.init.platform=hsqldb
|
||||||
|
|
||||||
# LOG
|
# LOG
|
||||||
logging.level.root=DEBUG
|
logging.level.root=INFO
|
||||||
logging.level.org.apache.tomcat=INFO
|
logging.level.org.apache.tomcat=INFO
|
||||||
|
|
||||||
##################################################################################
|
##################################################################################
|
||||||
|
@ -1,145 +0,0 @@
|
|||||||
package com.wisemapping.test.rest;
|
|
||||||
|
|
||||||
|
|
||||||
import com.wisemapping.config.common.CommonConfig;
|
|
||||||
import com.wisemapping.config.rest.RestAppConfig;
|
|
||||||
import com.wisemapping.rest.AdminController;
|
|
||||||
import com.wisemapping.rest.LabelController;
|
|
||||||
import com.wisemapping.rest.UserController;
|
|
||||||
import com.wisemapping.rest.model.RestLabel;
|
|
||||||
import com.wisemapping.rest.model.RestLabelList;
|
|
||||||
import com.wisemapping.rest.model.RestUser;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
|
||||||
import org.springframework.boot.test.web.client.TestRestTemplate;
|
|
||||||
import org.springframework.http.*;
|
|
||||||
import org.springframework.web.client.HttpClientErrorException;
|
|
||||||
import org.springframework.web.util.DefaultUriBuilderFactory;
|
|
||||||
|
|
||||||
import java.net.URI;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
import static com.wisemapping.test.rest.RestHelper.BASE_REST_URL;
|
|
||||||
import static com.wisemapping.test.rest.RestHelper.createHeaders;
|
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
|
||||||
|
|
||||||
|
|
||||||
@SpringBootTest(classes = {RestAppConfig.class, CommonConfig.class, LabelController.class, AdminController.class, UserController.class}, webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT)
|
|
||||||
public class RestLabelControllerTest {
|
|
||||||
private static final String COLOR = "#000000";
|
|
||||||
|
|
||||||
private RestUser user;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private TestRestTemplate restTemplate;
|
|
||||||
|
|
||||||
@BeforeEach
|
|
||||||
void createUser() {
|
|
||||||
|
|
||||||
// Remote debug ...
|
|
||||||
if (restTemplate == null) {
|
|
||||||
this.restTemplate = new TestRestTemplate();
|
|
||||||
this.restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory("http://localhost:8081/"));
|
|
||||||
}
|
|
||||||
RestAccountControllerTest restAccount = RestAccountControllerTest.create(restTemplate);
|
|
||||||
this.user = restAccount.createNewUser();
|
|
||||||
}
|
|
||||||
|
|
||||||
static RestLabelList getLabels(HttpHeaders requestHeaders, @NotNull TestRestTemplate template) {
|
|
||||||
final HttpEntity<RestLabelList> findLabelEntity = new HttpEntity<>(requestHeaders);
|
|
||||||
final ResponseEntity<RestLabelList> response = template.exchange(BASE_REST_URL + "/labels/", HttpMethod.GET, findLabelEntity, RestLabelList.class);
|
|
||||||
return response.getBody();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void createLabel() {
|
|
||||||
|
|
||||||
final HttpHeaders requestHeaders = createHeaders(MediaType.APPLICATION_JSON);
|
|
||||||
final TestRestTemplate restTemplate = this.restTemplate.withBasicAuth(user.getEmail(), user.getPassword());
|
|
||||||
|
|
||||||
// Create a new label
|
|
||||||
final String title1 = "Label 1 - ";
|
|
||||||
|
|
||||||
addNewLabel(requestHeaders, restTemplate, title1, COLOR);
|
|
||||||
|
|
||||||
// Create a new label
|
|
||||||
final String title2 = "Label 2 - ";
|
|
||||||
|
|
||||||
addNewLabel(requestHeaders, restTemplate, title2, COLOR);
|
|
||||||
|
|
||||||
// Check that the label has been created ...
|
|
||||||
final RestLabelList restLabelList = getLabels(requestHeaders, restTemplate);
|
|
||||||
|
|
||||||
// Validate that the two labels are there ...
|
|
||||||
final List<RestLabel> labels = restLabelList.getLabels();
|
|
||||||
|
|
||||||
long count = labels.stream().filter(l -> Objects.equals(l.getTitle(), title1) || Objects.equals(l.getTitle(), title2)).count();
|
|
||||||
assertEquals(2, count, "Labels could not be found");
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void createLabelWithoutRequiredField() {
|
|
||||||
final HttpHeaders requestHeaders = createHeaders(MediaType.APPLICATION_JSON);
|
|
||||||
final TestRestTemplate restTemplate = this.restTemplate.withBasicAuth(user.getEmail(), user.getPassword());
|
|
||||||
|
|
||||||
requestHeaders.set(HttpHeaders.ACCEPT_LANGUAGE, "en");
|
|
||||||
|
|
||||||
try {
|
|
||||||
addNewLabel(requestHeaders, restTemplate, null, COLOR);
|
|
||||||
fail("Wrong response");
|
|
||||||
} catch (IllegalStateException e) {
|
|
||||||
assertTrue(e.getMessage().contains("Required field cannot be left blank"), e.getMessage());
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
addNewLabel(requestHeaders, restTemplate, "title12345", null);
|
|
||||||
fail("Wrong response");
|
|
||||||
} catch (IllegalStateException e) {
|
|
||||||
assertTrue(e.getMessage().contains("Required field cannot be left blank"), e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void deleteLabel() {
|
|
||||||
final HttpHeaders requestHeaders = createHeaders(MediaType.APPLICATION_JSON);
|
|
||||||
final TestRestTemplate restTemplate = this.restTemplate.withBasicAuth(user.getEmail(), user.getPassword());
|
|
||||||
|
|
||||||
final String title = "title to delete";
|
|
||||||
final URI resourceUri = addNewLabel(requestHeaders, restTemplate, title, COLOR);
|
|
||||||
|
|
||||||
// Now remove it ...
|
|
||||||
restTemplate.delete(resourceUri.toString());
|
|
||||||
final RestLabelList restLabelList = getLabels(requestHeaders, restTemplate);
|
|
||||||
|
|
||||||
for (RestLabel restLabel : restLabelList.getLabels()) {
|
|
||||||
if (title.equals(restLabel.getTitle())) {
|
|
||||||
fail("Label could not be removed:" + resourceUri);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static URI addNewLabel(@NotNull HttpHeaders requestHeaders, @NotNull TestRestTemplate template, @Nullable String title, @Nullable String color) {
|
|
||||||
final RestLabel restLabel = new RestLabel();
|
|
||||||
if (title != null) {
|
|
||||||
restLabel.setTitle(title);
|
|
||||||
}
|
|
||||||
if (color != null) {
|
|
||||||
restLabel.setColor(color);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a new label ...
|
|
||||||
final HttpEntity<RestLabel> createUserEntity = new HttpEntity<>(restLabel, requestHeaders);
|
|
||||||
final ResponseEntity<String> result = template.exchange("/api/restfull/labels", HttpMethod.POST, createUserEntity, String.class);
|
|
||||||
if (!result.getStatusCode().is2xxSuccessful()) {
|
|
||||||
throw new IllegalStateException(result.toString());
|
|
||||||
}
|
|
||||||
;
|
|
||||||
return result.getHeaders().getLocation();
|
|
||||||
}
|
|
||||||
}
|
|
@ -0,0 +1,146 @@
|
|||||||
|
package com.wisemapping.test.rest;
|
||||||
|
|
||||||
|
|
||||||
|
import com.wisemapping.exceptions.WiseMappingException;
|
||||||
|
import com.wisemapping.rest.model.RestLabel;
|
||||||
|
import com.wisemapping.rest.model.RestLabelList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
import org.springframework.http.*;
|
||||||
|
import org.springframework.web.client.HttpClientErrorException;
|
||||||
|
import org.springframework.web.client.RestTemplate;
|
||||||
|
import org.testng.Assert;
|
||||||
|
import org.testng.SkipException;
|
||||||
|
import org.testng.annotations.BeforeClass;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.URI;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static com.wisemapping.test.rest.RestHelper.BASE_REST_URL;
|
||||||
|
import static org.testng.Assert.assertTrue;
|
||||||
|
import static org.testng.AssertJUnit.fail;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public class RestLabelITCase {
|
||||||
|
|
||||||
|
private String userEmail;
|
||||||
|
private static final String COLOR = "#000000";
|
||||||
|
|
||||||
|
@BeforeClass
|
||||||
|
void createUser() {
|
||||||
|
|
||||||
|
final RestAdminITCase restAdminITCase = new RestAdminITCase();
|
||||||
|
userEmail = restAdminITCase.createNewUser(MediaType.APPLICATION_JSON);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
|
public void createLabel(final @NotNull MediaType mediaType) throws IOException { // Configure media types ...
|
||||||
|
final HttpHeaders requestHeaders = RestHelper.createHeaders(mediaType);
|
||||||
|
final RestTemplate template = RestHelper.createTemplate(userEmail + ":" + "admin");
|
||||||
|
|
||||||
|
// Create a new label
|
||||||
|
final String title1 = "Label 1 - " + mediaType;
|
||||||
|
addNewLabel(requestHeaders, template, title1, COLOR);
|
||||||
|
|
||||||
|
// Create a new label
|
||||||
|
final String title2 = "Label 2 - " + mediaType;
|
||||||
|
addNewLabel(requestHeaders, template, title2, COLOR);
|
||||||
|
|
||||||
|
// Check that the label has been created ...
|
||||||
|
final RestLabelList restLabelList = getLabels(requestHeaders, template);
|
||||||
|
|
||||||
|
// Validate that the two labels are there ...
|
||||||
|
final List<RestLabel> labels = restLabelList.getLabels();
|
||||||
|
|
||||||
|
boolean found1 = false;
|
||||||
|
boolean found2 = false;
|
||||||
|
for (RestLabel label : labels) {
|
||||||
|
if (title1.equals(label.getTitle())) {
|
||||||
|
found1 = true;
|
||||||
|
}
|
||||||
|
if (title2.equals(label.getTitle())) {
|
||||||
|
found2 = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
assertTrue(found1 && found2, "Labels could not be found");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static RestLabelList getLabels(HttpHeaders requestHeaders, RestTemplate template) {
|
||||||
|
final HttpEntity findLabelEntity = new HttpEntity(requestHeaders);
|
||||||
|
final ResponseEntity<RestLabelList> response = template.exchange(BASE_REST_URL + "/labels/", HttpMethod.GET, findLabelEntity, RestLabelList.class);
|
||||||
|
return response.getBody();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
|
public void createLabelWithoutRequiredField(final @NotNull MediaType mediaType) throws IOException {
|
||||||
|
final HttpHeaders requestHeaders = RestHelper.createHeaders(mediaType);
|
||||||
|
requestHeaders.set(HttpHeaders.ACCEPT_LANGUAGE, "en");
|
||||||
|
final RestTemplate template = RestHelper.createTemplate(userEmail + ":" + "admin");
|
||||||
|
|
||||||
|
try {
|
||||||
|
addNewLabel(requestHeaders, template, null, COLOR);
|
||||||
|
fail("Wrong response");
|
||||||
|
} catch (HttpClientErrorException e) {
|
||||||
|
final String responseBodyAsString = e.getResponseBodyAsString();
|
||||||
|
assertTrue(responseBodyAsString.contains("Required field cannot be left blank"));
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
addNewLabel(requestHeaders, template, "title12345", null);
|
||||||
|
fail("Wrong response");
|
||||||
|
} catch (HttpClientErrorException e) {
|
||||||
|
final String responseBodyAsString = e.getResponseBodyAsString();
|
||||||
|
assert (responseBodyAsString.contains("Required field cannot be left blank"));
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
addNewLabel(requestHeaders, template, "title12345", COLOR);
|
||||||
|
fail("Wrong response");
|
||||||
|
} catch (HttpClientErrorException e) {
|
||||||
|
final String responseBodyAsString = e.getResponseBodyAsString();
|
||||||
|
assert (responseBodyAsString.contains("Required field cannot be left blank"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
|
public void validateLabelsUserIsolation() { // Configure media types ...
|
||||||
|
throw new SkipException("missing test: labels belong to users");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
|
public void deleteLabel(final @NotNull MediaType mediaType) throws IOException {
|
||||||
|
final HttpHeaders requestHeaders = RestHelper.createHeaders(mediaType);
|
||||||
|
final RestTemplate template = RestHelper.createTemplate(userEmail + ":" + "admin");
|
||||||
|
|
||||||
|
final String title = "title to delete";
|
||||||
|
final URI resourceUri = addNewLabel(requestHeaders, template, title, COLOR);
|
||||||
|
|
||||||
|
// Now remove it ...
|
||||||
|
template.delete(RestHelper.HOST_PORT + resourceUri.toString());
|
||||||
|
final RestLabelList restLabelList = getLabels(requestHeaders, template);
|
||||||
|
|
||||||
|
for (RestLabel restLabel : restLabelList.getLabels()) {
|
||||||
|
if (title.equals(restLabel.getTitle())) {
|
||||||
|
Assert.fail("Label could not be removed:" + resourceUri);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static URI addNewLabel(@NotNull HttpHeaders requestHeaders, @NotNull RestTemplate template, @Nullable String title, @Nullable String color) throws IOException {
|
||||||
|
final RestLabel restLabel = new RestLabel();
|
||||||
|
if (title != null) {
|
||||||
|
restLabel.setTitle(title);
|
||||||
|
}
|
||||||
|
if (color != null) {
|
||||||
|
restLabel.setColor(color);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create a new label ...
|
||||||
|
HttpEntity<RestLabel> createUserEntity = new HttpEntity<RestLabel>(restLabel, requestHeaders);
|
||||||
|
return template.postForLocation(BASE_REST_URL + "/labels", createUserEntity);
|
||||||
|
}
|
||||||
|
}
|
@ -16,6 +16,7 @@ import org.springframework.beans.factory.annotation.Autowired;
|
|||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.boot.test.web.client.TestRestTemplate;
|
import org.springframework.boot.test.web.client.TestRestTemplate;
|
||||||
import org.springframework.http.*;
|
import org.springframework.http.*;
|
||||||
|
import org.springframework.web.client.HttpClientErrorException;
|
||||||
import org.springframework.web.client.RestClientException;
|
import org.springframework.web.client.RestClientException;
|
||||||
import org.springframework.web.util.DefaultUriBuilderFactory;
|
import org.springframework.web.util.DefaultUriBuilderFactory;
|
||||||
|
|
||||||
@ -36,6 +37,8 @@ public class RestMindmapControllerTest {
|
|||||||
@Autowired
|
@Autowired
|
||||||
private TestRestTemplate restTemplate;
|
private TestRestTemplate restTemplate;
|
||||||
|
|
||||||
|
private RestAccountControllerTest restAccount;
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
void createUser() {
|
void createUser() {
|
||||||
|
|
||||||
@ -44,7 +47,7 @@ public class RestMindmapControllerTest {
|
|||||||
this.restTemplate = new TestRestTemplate();
|
this.restTemplate = new TestRestTemplate();
|
||||||
this.restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory("http://localhost:8081/"));
|
this.restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory("http://localhost:8081/"));
|
||||||
}
|
}
|
||||||
RestAccountControllerTest restAccount = RestAccountControllerTest.create(restTemplate);
|
this.restAccount = RestAccountControllerTest.create(restTemplate);
|
||||||
this.user = restAccount.createNewUser();
|
this.user = restAccount.createNewUser();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -398,10 +401,12 @@ public class RestMindmapControllerTest {
|
|||||||
final URI resourceUri = addNewMap(restTemplate, "deleteCollabsWithInvalidEmail");
|
final URI resourceUri = addNewMap(restTemplate, "deleteCollabsWithInvalidEmail");
|
||||||
|
|
||||||
// Remove with invalid email ...
|
// Remove with invalid email ...
|
||||||
final ResponseEntity<String> exchange = restTemplate.exchange(resourceUri + "/collabs?email=invalidEmail", HttpMethod.DELETE, null, String.class);
|
try {
|
||||||
assertTrue(exchange.getStatusCode().is4xxClientError());
|
restTemplate.delete(resourceUri + "/collabs?email=invalidEmail");
|
||||||
assertTrue(Objects.requireNonNull(exchange.getBody()).contains("Invalid email exception:"));
|
} catch (HttpClientErrorException e) {
|
||||||
|
assertEquals(e.getRawStatusCode(), 400);
|
||||||
|
assertTrue(e.getMessage().contains("Invalid email exception:"));
|
||||||
|
}
|
||||||
|
|
||||||
// Check that it has been removed ...
|
// Check that it has been removed ...
|
||||||
final ResponseEntity<RestCollaborationList> afterDeleteResponse = fetchCollabs(requestHeaders, restTemplate, resourceUri);
|
final ResponseEntity<RestCollaborationList> afterDeleteResponse = fetchCollabs(requestHeaders, restTemplate, resourceUri);
|
||||||
@ -453,96 +458,96 @@ public class RestMindmapControllerTest {
|
|||||||
return template.exchange(resourceUri + "/collabs", HttpMethod.GET, findCollabs, RestCollaborationList.class);
|
return template.exchange(resourceUri + "/collabs", HttpMethod.GET, findCollabs, RestCollaborationList.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void addCollabsInvalidOwner() {
|
|
||||||
|
|
||||||
final HttpHeaders requestHeaders = createHeaders(MediaType.APPLICATION_JSON);
|
|
||||||
final TestRestTemplate restTemplate = this.restTemplate.withBasicAuth(user.getEmail(), user.getPassword());
|
|
||||||
|
|
||||||
// Create a sample map ...fetchAndGetCollabs(requestHeaders, template, resourceUri);
|
|
||||||
final URI resourceUri = addNewMap(restTemplate, "Map for Collaboration");
|
|
||||||
|
|
||||||
// Add a new collaboration ...
|
|
||||||
requestHeaders.setContentType(MediaType.APPLICATION_JSON);
|
|
||||||
final RestCollaborationList collabs = new RestCollaborationList();
|
|
||||||
collabs.setMessage("Adding new permission");
|
|
||||||
|
|
||||||
// Validate that owner can not be added.
|
|
||||||
addCollabToList("newCollab@example", "owner", collabs);
|
|
||||||
|
|
||||||
final HttpEntity<RestCollaborationList> updateEntity = new HttpEntity<>(collabs, requestHeaders);
|
|
||||||
restTemplate.put(resourceUri + "/collabs/", updateEntity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void removeLabelFromMindmap() throws IOException, WiseMappingException { // Configure media types ...
|
|
||||||
final HttpHeaders requestHeaders = createHeaders(MediaType.APPLICATION_JSON);
|
|
||||||
final TestRestTemplate restTemplate = this.restTemplate.withBasicAuth(user.getEmail(), user.getPassword());
|
|
||||||
|
|
||||||
// Create a new label
|
|
||||||
final String titleLabel = "removeLabelFromMindmap";
|
|
||||||
final URI labelUri = RestLabelControllerTest.addNewLabel(requestHeaders, restTemplate, titleLabel, "red");
|
|
||||||
|
|
||||||
// Create a sample map ...
|
|
||||||
final String mapTitle = "removeLabelFromMindmap";
|
|
||||||
final URI mindmapUri = addNewMap(restTemplate, mapTitle);
|
|
||||||
final String mapId = mindmapUri.getPath().replace("/api/restfull/maps/", "");
|
|
||||||
|
|
||||||
// Assign label to map ...
|
|
||||||
String labelId = labelUri.getPath().replace("/api/restfull/labels/", "");
|
|
||||||
HttpEntity<String> labelEntity = new HttpEntity<>(labelId, requestHeaders);
|
|
||||||
restTemplate.postForLocation("/api/restfull/maps/" + mapId + "/labels", labelEntity);
|
|
||||||
|
|
||||||
// Remove label from map
|
|
||||||
restTemplate.delete("/api/restfull//maps/" + mapId + "/labels/" + labelId);
|
|
||||||
|
|
||||||
Optional<RestMindmapInfo> mindmapInfo = fetchMap(requestHeaders, restTemplate, mapId);
|
|
||||||
assertEquals(0, mindmapInfo.get().getLabels().size());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private Optional<RestMindmapInfo> fetchMap(HttpHeaders requestHeaders, TestRestTemplate template, @NotNull String mapId) {
|
|
||||||
// Check that the label has been removed ...
|
|
||||||
final List<RestMindmapInfo> mindmapsInfo = fetchMaps(requestHeaders, template).getMindmapsInfo();
|
|
||||||
return mindmapsInfo
|
|
||||||
.stream()
|
|
||||||
.filter(m -> m.getId() == Integer.parseInt(mapId))
|
|
||||||
.findAny();
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
|
// @Test(dataProviderClass = RestHelper.class, expectedExceptions = {HttpClientErrorException.class}, dataProvider = "ContentType-Provider-Function")
|
||||||
|
// public void addCollabsInvalidOwner(final @NotNull MediaType mediaType) {
|
||||||
|
//
|
||||||
|
// final HttpHeaders requestHeaders = createHeaders(mediaType);
|
||||||
|
// final RestTemplate template = createTemplate(userEmail);
|
||||||
|
//
|
||||||
|
// // Create a sample map ...fetchAndGetCollabs(requestHeaders, template, resourceUri);
|
||||||
|
// final URI resourceUri = addNewMap(template, "Map for Collaboration - " + mediaType);
|
||||||
|
//
|
||||||
|
// // Add a new collaboration ...
|
||||||
|
// requestHeaders.setContentType(MediaType.APPLICATION_JSON);
|
||||||
|
// final RestCollaborationList collabs = new RestCollaborationList();
|
||||||
|
// collabs.setMessage("Adding new permission");
|
||||||
|
//
|
||||||
|
// // Validate that owner can not be added.
|
||||||
|
// addCollabToList("newCollab@example", "owner", collabs);
|
||||||
|
//
|
||||||
|
// final HttpEntity<RestCollaborationList> updateEntity = new HttpEntity<>(collabs, requestHeaders);
|
||||||
|
// template.put(HOST_PORT + resourceUri + "/collabs/", updateEntity);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
|
// public void removeLabelFromMindmap(final @NotNull MediaType mediaType) throws IOException, WiseMappingException { // Configure media types ...
|
||||||
|
// final HttpHeaders requestHeaders = createHeaders(mediaType);
|
||||||
|
// final RestTemplate template = createTemplate(userEmail);
|
||||||
|
//
|
||||||
|
// // Create a new label
|
||||||
|
// final String titleLabel = "removeLabelFromMindmap";
|
||||||
|
// final URI labelUri = RestLabelITCase.addNewLabel(requestHeaders, template, titleLabel, COLOR);
|
||||||
|
//
|
||||||
|
// // Create a sample map ...
|
||||||
|
// final String mapTitle = "removeLabelFromMindmap";
|
||||||
|
// final URI mindmapUri = addNewMap(template, mapTitle);
|
||||||
|
// final String mapId = mindmapUri.getPath().replace("/api/restfull/maps/", "");
|
||||||
|
//
|
||||||
|
// // Assign label to map ...
|
||||||
|
// String labelId = labelUri.getPath().replace("/api/restfull/labels/", "");
|
||||||
|
// HttpEntity<String> labelEntity = new HttpEntity<>(labelId, requestHeaders);
|
||||||
|
// template.postForLocation(BASE_REST_URL + "/maps/" + mapId + "/labels", labelEntity);
|
||||||
|
//
|
||||||
|
// // Remove label from map
|
||||||
|
// template.delete(BASE_REST_URL + "/maps/" + mapId + "/labels/" + labelId);
|
||||||
|
//
|
||||||
|
// Optional<RestMindmapInfo> mindmapInfo = fetchMap(requestHeaders, template, mapId);
|
||||||
|
// assertTrue(mindmapInfo.get().getLabels().size() == 0);
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @NotNull
|
||||||
|
// private Optional<RestMindmapInfo> fetchMap(HttpHeaders requestHeaders, RestTemplate template, @NotNull String mapId) {
|
||||||
|
// // Check that the label has been removed ...
|
||||||
|
// final List<RestMindmapInfo> mindmapsInfo = fetchMaps(requestHeaders, template).getMindmapsInfo();
|
||||||
|
// Optional<RestMindmapInfo> mindmapInfo = mindmapsInfo
|
||||||
|
// .stream()
|
||||||
|
// .filter(m -> m.getId() == Integer.parseInt(mapId))
|
||||||
|
// .findAny();
|
||||||
|
// return mindmapInfo;
|
||||||
|
// }
|
||||||
|
//
|
||||||
// @Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
// @Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
// public void deleteMapAndCheckLabels(final @NotNull MediaType mediaType) { // Configure media types ...
|
// public void deleteMapAndCheckLabels(final @NotNull MediaType mediaType) { // Configure media types ...
|
||||||
// throw new SkipException("missing test: delete map should not affects others labels");
|
// throw new SkipException("missing test: delete map should not affects others labels");
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
@Test
|
// @Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
public void addLabelToMindmap() throws IOException, WiseMappingException { // Configure media types ...
|
// public void addLabelToMindmap(final @NotNull MediaType mediaType) throws IOException, WiseMappingException { // Configure media types ...
|
||||||
final HttpHeaders requestHeaders = createHeaders(MediaType.APPLICATION_JSON);
|
// final HttpHeaders requestHeaders = createHeaders(mediaType);
|
||||||
final TestRestTemplate restTemplate = this.restTemplate.withBasicAuth(user.getEmail(), user.getPassword());
|
// final RestTemplate template = createTemplate(userEmail);
|
||||||
|
//
|
||||||
// Create a new label
|
// // Create a new label
|
||||||
final String titleLabel = "Label 1 - ";
|
// final String titleLabel = "Label 1 - " + mediaType;
|
||||||
final URI labelUri = RestLabelControllerTest.addNewLabel(requestHeaders, restTemplate, titleLabel, "COLOR");
|
// final URI labelUri = RestLabelITCase.addNewLabel(requestHeaders, template, titleLabel, COLOR);
|
||||||
|
//
|
||||||
// Create a sample map ...
|
// // Create a sample map ...
|
||||||
final String mapTitle = "Maps 1 - ";
|
// final String mapTitle = "Maps 1 - " + mediaType;
|
||||||
final URI mindmapUri = addNewMap(restTemplate, mapTitle);
|
// final URI mindmapUri = addNewMap(template, mapTitle);
|
||||||
final String mapId = mindmapUri.getPath().replace("/api/restfull/maps/", "");
|
// final String mapId = mindmapUri.getPath().replace("/api/restfull/maps/", "");
|
||||||
|
//
|
||||||
// Assign label to map ...
|
// // Assign label to map ...
|
||||||
String labelId = labelUri.getPath().replace("/api/restfull/labels/", "");
|
// String labelId = labelUri.getPath().replace("/api/restfull/labels/", "");
|
||||||
HttpEntity<String> labelEntity = new HttpEntity<>(labelId, requestHeaders);
|
// HttpEntity<String> labelEntity = new HttpEntity<>(labelId, requestHeaders);
|
||||||
restTemplate.postForLocation("/api/restfull/maps/" + mapId + "/labels", labelEntity);
|
// template.postForLocation(BASE_REST_URL + "/maps/" + mapId + "/labels", labelEntity);
|
||||||
|
//
|
||||||
// Check that the label has been assigned ...
|
// // Check that the label has been assigned ...
|
||||||
Optional<RestMindmapInfo> mindmapInfo = fetchMap(requestHeaders, restTemplate, mapId);
|
// Optional<RestMindmapInfo> mindmapInfo = fetchMap(requestHeaders, template, mapId);
|
||||||
|
//
|
||||||
assertTrue(mindmapInfo.get().getLabels().size() == 1);
|
// assertTrue(mindmapInfo.get().getLabels().size() == 1);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
//
|
|
||||||
// @Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
// @Test(dataProviderClass = RestHelper.class, dataProvider = "ContentType-Provider-Function")
|
||||||
// public void updateCollabs(final @NotNull MediaType mediaType) {
|
// public void updateCollabs(final @NotNull MediaType mediaType) {
|
||||||
//
|
//
|
||||||
|
Loading…
x
Reference in New Issue
Block a user