package org.jboss.resteasy.test.providers.custom; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; 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.ResponseContainerResource; import org.jboss.resteasy.test.providers.custom.resource.ResponseContainerResponseFilter; import org.jboss.resteasy.test.providers.custom.resource.ResponseContainerSecondResponseFilter; import org.jboss.resteasy.test.providers.custom.resource.ResponseContainerTemplateFilter; 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.Test; import org.junit.BeforeClass; import org.junit.AfterClass; 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.client.Entity; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; /** * @tpSubChapter Resteasy-client * @tpChapter Integration tests * @tpSince RESTEasy 3.0.16 */ @RunWith(Arquillian.class) @RunAsClient public class ResponseContainerFilterTest { protected static final Logger logger = LogManager.getLogger(ResponseContainerFilterTest.class.getName()); static Client client; @BeforeClass public static void setup() throws Exception { client = ClientBuilder.newClient(); } @Deployment public static Archive<?> deploy() { WebArchive war = TestUtil.prepareArchive(ResponseContainerFilterTest.class.getSimpleName()); war.addClasses(ResponseContainerTemplateFilter.class); return TestUtil.finishContainerPrepare(war, null, ResponseContainerResource.class, ResponseContainerResponseFilter.class, ResponseContainerSecondResponseFilter.class); } private String generateURL(String path) { return PortProviderUtil.generateURL(path, ResponseContainerFilterTest.class.getSimpleName()); } @AfterClass public static void close() throws Exception { client.close(); } /** * @tpTestDetails Client sends POST request with it's custom header "OPERATION" specified in it. Server has registered * two ContainerResponseFilters, which have common ancestor and different priority. The filter ResponseFilter * with higher priority should be used here first, because the order of execution for Response filters is descending. * @tpPassCrit The ResponseFilter is used first for processing the response * @tpSince RESTEasy 3.0.16 */ @Test public void testHasEntity() { Response response = client.target(generateURL("/resource/hasentity")).request("*/*") .header("OPERATION", "hasentity").post(Entity.entity("entity", MediaType.WILDCARD_TYPE)); Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus()); Assert.assertEquals("The ResponseFilters were used in different order than expected" , MediaType.TEXT_PLAIN_TYPE , response.getMediaType()); logger.info(response.readEntity(String.class)); response.close(); } }