package org.jboss.resteasy.test.providers.custom;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.container.test.api.RunAsClient;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.resteasy.test.providers.custom.resource.SetRequestUriRequestFilter;
import org.jboss.resteasy.test.providers.custom.resource.SetRequestUriResource;
import org.jboss.resteasy.util.HttpResponseCodes;
import org.jboss.resteasy.utils.PortProviderUtil;
import org.jboss.resteasy.utils.TestUtil;
import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.Assert;
import org.junit.runner.RunWith;
import javax.ws.rs.client.Client;
import javax.ws.rs.client.ClientBuilder;
import javax.ws.rs.core.Response;
/**
* @tpSubChapter Resteasy-client
* @tpChapter Integration tests
* @tpSince RESTEasy 3.0.16
*/
@RunWith(Arquillian.class)
@RunAsClient
public class SetRequestUriTest {
static Client client;
@BeforeClass
public static void setup() throws Exception {
client = ClientBuilder.newClient();
}
@Deployment
public static Archive<?> deploy() {
WebArchive war = TestUtil.prepareArchive(SetRequestUriTest.class.getSimpleName());
return TestUtil.finishContainerPrepare(war, null, SetRequestUriResource.class, SetRequestUriRequestFilter.class);
}
private String generateURL(String path) {
return PortProviderUtil.generateURL(path, SetRequestUriTest.class.getSimpleName());
}
@AfterClass
public static void close() throws Exception {
client.close();
}
/**
* @tpTestDetails Client sends GET request with https protocol uri. The resource has injected UriInfo and returns
* response containing absolute path of the uri from the request.
* @tpPassCrit The response code status is changed to 200 (SUCCESS) and the absolute uri matches the original request
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testSchemaChange() {
String uri = generateURL("/base/resource/change");
String httpsUri = uri.replace("http://", "https://");
Response response = client.target(uri).request().header("X-Forwarded-Proto", "https").get();
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
Assert.assertEquals("The original https uri doesn't match the entity in the response", httpsUri,
response.readEntity(String.class));
}
/**
* @tpTestDetails Client sends GET request with https protocol uri. The resource has injected UriInfo and returns
* response containing absolute path of the uri from the request.
* @tpPassCrit The response code status is changed to 200 (SUCCESS) and the absolute uri matches the original request
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testUriOverride() {
Response response = client.target(generateURL("/base/resource/setrequesturi1")).request().get();
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
Assert.assertEquals("OK", response.readEntity(String.class));
}
/**
* @tpTestDetails Client sends GET request with non existing uri path. The request is catched by PreMatching
* RequestFilter which applies to all requests not matter if the resource exists on the server. The RequestFilter
* processes the request aborts processing of the request and sends response back to the client.
* @tpPassCrit The response code status is 200 (SUCCESS) and the absolute uri is changed by RequestFilter
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testUriOverride2() {
Response response = client.target(generateURL("/base/resource/setrequesturi2")).request().get();
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
Assert.assertEquals("The original uri doesn't match the entity changed by RequestFilter",
"http://xx.yy:888/base/resource/sub", response.readEntity(String.class));
}
}