Skip to content

Commit

Permalink
Merge pull request eugenp#252 from zinch84/rest_template_tutorial
Browse files Browse the repository at this point in the history
[RestTemplate] Use constant for an application port value
  • Loading branch information
Eugen committed Sep 18, 2015
2 parents 2c393c0 + b0c30e7 commit 1722004
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 19 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
package org.baeldung;

public interface Consts {
int APPLICATION_PORT = 8080;
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package org.baeldung.client;

import static org.apache.commons.codec.binary.Base64.encodeBase64;
import static org.baeldung.Consts.APPLICATION_PORT;
import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.not;
import static org.hamcrest.MatcherAssert.assertThat;
Expand Down Expand Up @@ -43,9 +44,9 @@

public class RestTemplateLiveTest {

RestTemplate restTemplate;
private RestTemplate restTemplate;
private List<HttpMessageConverter<?>> messageConverters;
private static final String fooResourceUrl = "http://localhost:8080/spring-security-rest-full/foos";
private static final String fooResourceUrl = "http://localhost:" + APPLICATION_PORT + "/spring-security-rest-full/foos";

@Before
public void beforeTest() {
Expand All @@ -60,13 +61,13 @@ public void beforeTest() {
}

@Test
public void givenValidEndpoint_whenSendGetForRequestEntity_thenStatusOk() throws IOException {
public void givenResourceUrl_whenSendGetForRequestEntity_thenStatusOk() throws IOException {
ResponseEntity<String> response = restTemplate.getForEntity(fooResourceUrl + "/1", String.class);
assertThat(response.getStatusCode(), is(HttpStatus.OK));
}

@Test
public void givenRepoEndpoint_whenSendGetForRestEntity_thenReceiveCorrectJson() throws IOException {
public void givenResourceUrl_whenSendGetForRestEntity_thenReceiveCorrectJson() throws IOException {
ResponseEntity<String> response = restTemplate.getForEntity(fooResourceUrl + "/1", String.class);

ObjectMapper mapper = new ObjectMapper();
Expand All @@ -80,7 +81,7 @@ public void givenRepoEndpoint_whenSendGetForRestEntity_thenReceiveCorrectJson()
}

@Test
public void givenRepoEndpoint_whenSendGetForObject_thenReturnsRepoObject() {
public void givenResourceUrl_whenSendGetForObject_thenReturnsRepoObject() {
restTemplate.setMessageConverters(messageConverters);
Foo foo = restTemplate.getForObject(fooResourceUrl + "/1", Foo.class);
assertThat(foo.getName(), is("bar"));
Expand All @@ -106,21 +107,21 @@ public void givenFooService_whenPostFor2Objects_thenNewObjectIsCreatedEachTime()
}

@Test
public void givenResource_whenCallHeadForHeaders_thenReceiveAllHeadersForThatResource() {
public void givenFooService_whenCallHeadForHeaders_thenReceiveAllHeadersForThatResource() {
HttpHeaders httpHeaders = restTemplate.headForHeaders(fooResourceUrl);
assertTrue(httpHeaders.getContentType().includes(MediaType.APPLICATION_JSON));
assertTrue(httpHeaders.get("bar").contains("baz"));
}

@Test
public void givenResource_whenCallOptionsForAllow_thenReceiveValueOfAllowHeader() {
public void givenFooService_whenCallOptionsForAllow_thenReceiveValueOfAllowHeader() {
Set<HttpMethod> optionsForAllow = restTemplate.optionsForAllow(fooResourceUrl);
HttpMethod[] supportedMethods = {HttpMethod.GET, HttpMethod.POST, HttpMethod.PUT, HttpMethod.DELETE};
assertTrue(optionsForAllow.containsAll(Arrays.asList(supportedMethods)));
}

@Test
public void givenRestService_whenPostResource_thenResourceIsCreated() {
public void givenFooService_whenPostResource_thenResourceIsCreated() {
RestTemplate template = new RestTemplate();

HttpHeaders headers = prepareBasicAuthHeaders();
Expand All @@ -134,7 +135,7 @@ public void givenRestService_whenPostResource_thenResourceIsCreated() {
}

@Test
public void givenResource_whenPutExistingEntity_thenItIsUpdated() {
public void givenFooService_whenPutExistingEntity_thenItIsUpdated() {
RestTemplate template = new RestTemplate();
HttpHeaders headers = prepareBasicAuthHeaders();
HttpEntity<Foo> request = new HttpEntity<>(new Foo("bar"), headers);
Expand All @@ -156,7 +157,7 @@ public void givenResource_whenPutExistingEntity_thenItIsUpdated() {
}

@Test
public void givenRestService_whenCallDelete_thenEntityIsRemoved() {
public void givenFooService_whenCallDelete_thenEntityIsRemoved() {
Foo foo = new Foo("remove me");
ResponseEntity<Foo> response = restTemplate.postForEntity(fooResourceUrl, foo, Foo.class);
assertThat(response.getStatusCode(), is(HttpStatus.CREATED));
Expand Down Expand Up @@ -193,7 +194,7 @@ private ClientHttpRequestFactory getClientHttpRequestFactory() {
.setSocketTimeout(timeout * 1000).build();

BasicCredentialsProvider credentialsProvider = new BasicCredentialsProvider();
credentialsProvider.setCredentials(new AuthScope("localhost", 8080, AuthScope.ANY_REALM),
credentialsProvider.setCredentials(new AuthScope("localhost", APPLICATION_PORT, AuthScope.ANY_REALM),
new UsernamePasswordCredentials("user1", "user1Pass"));

CloseableHttpClient client = HttpClientBuilder.create()
Expand All @@ -216,10 +217,10 @@ private String getBase64EncodedLogPass() {
return new String(authHeaderBytes, Charsets.US_ASCII);
}

private RequestCallback requestCallback(Foo updatedInstace) {
private RequestCallback requestCallback(Foo updatedInstance) {
return clientHttpRequest -> {
ObjectMapper mapper = new ObjectMapper();
mapper.writeValue(clientHttpRequest.getBody(), updatedInstace);
mapper.writeValue(clientHttpRequest.getBody(), updatedInstance);
clientHttpRequest.getHeaders().add(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE);
clientHttpRequest.getHeaders().add(HttpHeaders.AUTHORIZATION, "Basic " + getBase64EncodedLogPass());
};
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
package org.baeldung.common.web;

import java.io.Serializable;

import org.baeldung.test.IMarshaller;
import org.springframework.beans.factory.annotation.Autowired;

import com.google.common.base.Preconditions;
import com.google.common.net.HttpHeaders;
import com.jayway.restassured.RestAssured;
import com.jayway.restassured.response.Response;
import com.jayway.restassured.specification.RequestSpecification;
import org.baeldung.test.IMarshaller;
import org.springframework.beans.factory.annotation.Autowired;

import java.io.Serializable;

import static org.baeldung.Consts.APPLICATION_PORT;

public abstract class AbstractLiveTest<T extends Serializable> {

Expand Down Expand Up @@ -55,7 +56,7 @@ final Response createAsResponse(final T resource) {
//

protected String getURL() {
return "http://localhost:8080/spring-security-rest-full/foos";
return "http://localhost:" + APPLICATION_PORT + "/spring-security-rest-full/foos";
}

protected final RequestSpecification givenAuth() {
Expand Down

0 comments on commit 1722004

Please sign in to comment.