package org.jboss.resteasy.test.exception;
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.exception.resource.ExceptionMapperAbstractExceptionMapper;
import org.jboss.resteasy.test.exception.resource.ExceptionMapperMyCustomException;
import org.jboss.resteasy.test.exception.resource.ExceptionMapperMyCustomExceptionMapper;
import org.jboss.resteasy.test.exception.resource.ExceptionMapperMyCustomSubException;
import org.jboss.resteasy.test.exception.resource.ExceptionMapperResource;
import org.jboss.resteasy.test.exception.resource.ExceptionMapperWebAppExceptionMapper;
import org.jboss.resteasy.test.exception.resource.NotFoundExceptionMapper;
import org.jboss.resteasy.util.HttpResponseCodes;
import org.jboss.resteasy.util.Types;
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.Test;
import org.junit.Assert;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.runner.RunWith;
import javax.ws.rs.client.Client;
import javax.ws.rs.client.ClientBuilder;
import javax.ws.rs.core.Response;
import javax.ws.rs.ext.ExceptionMapper;
import java.lang.reflect.Type;
/**
* @tpSubChapter Resteasy-client
* @tpChapter Integration tests
* @tpSince RESTEasy 3.0.16
*/
@RunWith(Arquillian.class)
@RunAsClient
public class ExceptionMapperTest {
static Client client;
@Deployment
public static Archive<?> deploy() {
WebArchive war = TestUtil.prepareArchive(ExceptionMapperTest.class.getSimpleName());
war.addClasses(ExceptionMapperAbstractExceptionMapper.class);
return TestUtil.finishContainerPrepare(war, null, ExceptionMapperResource.class, ExceptionMapperWebAppExceptionMapper.class,
ExceptionMapperMyCustomExceptionMapper.class, ExceptionMapperMyCustomException.class,
ExceptionMapperMyCustomSubException.class, NotFoundExceptionMapper.class);
}
private String generateURL(String path) {
return PortProviderUtil.generateURL(path, ExceptionMapperTest.class.getSimpleName());
}
@BeforeClass
public static void setup() {
client = ClientBuilder.newClient();
}
@AfterClass
public static void close() {
client.close();
}
/**
* @tpTestDetails Client sends GET request to the server, which causes application custom exception being thrown, this
* exception is caught by application provided ExceptionMapper. The application provides two providers for mapping
* exceptions. General RuntimeException mapping and MyCustomException mapping which extends the RuntimeException.
* @tpPassCrit The more specific MyCustomException mapping will be used.
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testCustomExceptionsUsed() {
Type exceptionType = Types.getActualTypeArgumentsOfAnInterface(ExceptionMapperMyCustomExceptionMapper.class, ExceptionMapper.class)[0];
Assert.assertEquals(ExceptionMapperMyCustomException.class, exceptionType);
Response response = client.target(generateURL("/resource/custom")).request().get();
Assert.assertNotEquals("General RuntimeException mapper was used instead of more specific one"
, HttpResponseCodes.SC_NOT_ACCEPTABLE, response.getStatus());
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
Assert.assertEquals("custom", response.readEntity(String.class));
}
/**
* @tpTestDetails Client sends GET request to the server, which causes WebapplicationException being thrown, this
* exception is caught by application provided ExceptionMapper
* @tpPassCrit Application provided ExceptionMapper serves the exception and creates response with ACCEPTED status
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testWAEResponseUsed() {
Response response = client.target(generateURL("/resource/responseok")).request().get();
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
Assert.assertEquals("hello", response.readEntity(String.class));
}
/**
* @tpTestDetails Client sends GET request to the server, which causes the subclass of an exception
* which has an ExceptionMapper to be thrown. This subclass exception is caught by application provided ExceptionMapper
* @tpPassCrit Application provided ExceptionMapper serves the exception and creates response with ACCEPTED status
* @tpSince RESTEasy 3.0.20
*/
@Test
public void testCustomSubExceptionsUsed() {
Response response = client.target(generateURL("/resource/sub")).request().get();
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
Assert.assertEquals("custom", response.readEntity(String.class));
}
/**
* @tpTestDetails Client sends GET request to a nonexistent resource, which causes a NotFoundException to be thrown.
* The NotFoundException is caught by the application provided NotFoundExceptionMapper, which sends a 410 status.
* @tpSince RESTEasy 3.0.20
*/
@Test
public void testNotFoundExceptionMapping() {
Response response = client.target(generateURL("/bogus")).request().get();
Assert.assertEquals(410, response.getStatus());
response.close();
}
}