|
|
@ -16,10 +16,14 @@
|
|
|
|
|
|
|
|
|
|
|
|
package sample;
|
|
|
|
package sample;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import java.net.URI;
|
|
|
|
|
|
|
|
|
|
|
|
import org.junit.Test;
|
|
|
|
import org.junit.Test;
|
|
|
|
|
|
|
|
|
|
|
|
import org.springframework.boot.test.web.client.TestRestTemplate;
|
|
|
|
import org.springframework.boot.test.web.client.TestRestTemplate;
|
|
|
|
import org.springframework.http.HttpStatus;
|
|
|
|
import org.springframework.http.HttpStatus;
|
|
|
|
|
|
|
|
import org.springframework.http.MediaType;
|
|
|
|
|
|
|
|
import org.springframework.http.RequestEntity;
|
|
|
|
import org.springframework.http.ResponseEntity;
|
|
|
|
import org.springframework.http.ResponseEntity;
|
|
|
|
|
|
|
|
|
|
|
|
import static org.assertj.core.api.Assertions.assertThat;
|
|
|
|
import static org.assertj.core.api.Assertions.assertThat;
|
|
|
@ -29,13 +33,14 @@ import static org.assertj.core.api.Assertions.assertThat;
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public class SampleTomcatDeployApplicationIT {
|
|
|
|
public class SampleTomcatDeployApplicationIT {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private final TestRestTemplate rest = new TestRestTemplate();
|
|
|
|
|
|
|
|
|
|
|
|
private int port = Integer.valueOf(System.getProperty("port"));
|
|
|
|
private int port = Integer.valueOf(System.getProperty("port"));
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testHome() throws Exception {
|
|
|
|
public void testHome() throws Exception {
|
|
|
|
String url = "http://localhost:" + this.port + "/bootapp/";
|
|
|
|
String url = "http://localhost:" + this.port + "/bootapp/";
|
|
|
|
ResponseEntity<String> entity = new TestRestTemplate().getForEntity(url,
|
|
|
|
ResponseEntity<String> entity = this.rest.getForEntity(url, String.class);
|
|
|
|
String.class);
|
|
|
|
|
|
|
|
assertThat(entity.getStatusCode()).isEqualTo(HttpStatus.OK);
|
|
|
|
assertThat(entity.getStatusCode()).isEqualTo(HttpStatus.OK);
|
|
|
|
assertThat(entity.getBody()).isEqualTo("Hello World");
|
|
|
|
assertThat(entity.getBody()).isEqualTo("Hello World");
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -50,4 +55,71 @@ public class SampleTomcatDeployApplicationIT {
|
|
|
|
assertThat(entity.getBody()).isEqualTo("{\"status\":\"UP\"}");
|
|
|
|
assertThat(entity.getBody()).isEqualTo("{\"status\":\"UP\"}");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void errorFromExceptionForRequestAcceptingAnythingProducesAJsonResponse()
|
|
|
|
|
|
|
|
throws Exception {
|
|
|
|
|
|
|
|
assertThatErrorFromExceptionProducesExpectedResponse(MediaType.ALL,
|
|
|
|
|
|
|
|
MediaType.APPLICATION_JSON);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void errorFromExceptionForRequestAcceptingJsonProducesAJsonResponse()
|
|
|
|
|
|
|
|
throws Exception {
|
|
|
|
|
|
|
|
assertThatErrorFromExceptionProducesExpectedResponse(MediaType.APPLICATION_JSON,
|
|
|
|
|
|
|
|
MediaType.APPLICATION_JSON);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void errorFromExceptionForRequestAcceptingHtmlProducesAnHtmlResponse()
|
|
|
|
|
|
|
|
throws Exception {
|
|
|
|
|
|
|
|
assertThatErrorFromExceptionProducesExpectedResponse(MediaType.TEXT_HTML,
|
|
|
|
|
|
|
|
MediaType.TEXT_HTML);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void sendErrorForRequestAcceptingAnythingProducesAJsonResponse()
|
|
|
|
|
|
|
|
throws Exception {
|
|
|
|
|
|
|
|
assertThatSendErrorProducesExpectedResponse(MediaType.ALL,
|
|
|
|
|
|
|
|
MediaType.APPLICATION_JSON);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void sendErrorForRequestAcceptingJsonProducesAJsonResponse() throws Exception {
|
|
|
|
|
|
|
|
assertThatSendErrorProducesExpectedResponse(MediaType.APPLICATION_JSON,
|
|
|
|
|
|
|
|
MediaType.APPLICATION_JSON);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void sendErrorForRequestAcceptingHtmlProducesAnHtmlResponse()
|
|
|
|
|
|
|
|
throws Exception {
|
|
|
|
|
|
|
|
assertThatSendErrorProducesExpectedResponse(MediaType.TEXT_HTML,
|
|
|
|
|
|
|
|
MediaType.TEXT_HTML);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void assertThatSendErrorProducesExpectedResponse(MediaType accept,
|
|
|
|
|
|
|
|
MediaType contentType) {
|
|
|
|
|
|
|
|
RequestEntity<Void> request = RequestEntity
|
|
|
|
|
|
|
|
.get(URI.create("http://localhost:" + this.port + "/bootapp/send-error"))
|
|
|
|
|
|
|
|
.accept(accept).build();
|
|
|
|
|
|
|
|
ResponseEntity<String> response = this.rest.exchange(request, String.class);
|
|
|
|
|
|
|
|
assertThat(response.getStatusCode()).isEqualTo(HttpStatus.INTERNAL_SERVER_ERROR);
|
|
|
|
|
|
|
|
assertThat(contentType.isCompatibleWith(response.getHeaders().getContentType()))
|
|
|
|
|
|
|
|
.as("%s is compatible with %s", contentType,
|
|
|
|
|
|
|
|
response.getHeaders().getContentType())
|
|
|
|
|
|
|
|
.isTrue();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void assertThatErrorFromExceptionProducesExpectedResponse(MediaType accept,
|
|
|
|
|
|
|
|
MediaType contentType) {
|
|
|
|
|
|
|
|
RequestEntity<Void> request = RequestEntity
|
|
|
|
|
|
|
|
.get(URI.create("http://localhost:" + this.port + "/bootapp/exception"))
|
|
|
|
|
|
|
|
.accept(accept).build();
|
|
|
|
|
|
|
|
ResponseEntity<String> response = this.rest.exchange(request, String.class);
|
|
|
|
|
|
|
|
assertThat(response.getStatusCode()).isEqualTo(HttpStatus.INTERNAL_SERVER_ERROR);
|
|
|
|
|
|
|
|
assertThat(contentType.isCompatibleWith(response.getHeaders().getContentType()))
|
|
|
|
|
|
|
|
.as("%s is compatible with %s", contentType,
|
|
|
|
|
|
|
|
response.getHeaders().getContentType())
|
|
|
|
|
|
|
|
.isTrue();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|