package org.jboss.resteasy.test.asynch;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.resteasy.client.jaxrs.ResteasyClient;
import org.jboss.resteasy.client.jaxrs.ResteasyClientBuilder;
import org.jboss.resteasy.test.asynch.resource.AsyncPostProcessingMsgBodyWriterInterceptor;
import org.jboss.resteasy.test.asynch.resource.AsyncPostProcessingInterceptor;
import org.jboss.resteasy.test.asynch.resource.AsyncPostProcessingResource;
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.asset.StringAsset;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.jboss.logging.Logger;
import javax.ws.rs.core.Response;
/**
* @tpSubChapter Asynchronous RESTEasy
* @tpChapter Integration tests
* @tpTestCaseDetails Regression test for RESTEASY-767
* @tpSince RESTEasy 3.0.16
*/
@RunWith(Arquillian.class)
public class AsyncPostProcessingTest {
private static Logger logger = Logger.getLogger(AsyncPostProcessingTest.class);
static ResteasyClient client;
@Deployment
public static Archive<?> createTestArchive() {
WebArchive war = TestUtil.prepareArchive(AsyncPostProcessingTest.class.getSimpleName());
war.addClasses(TestUtil.class, PortProviderUtil.class);
war.addAsWebInfResource(AsyncPostProcessingTest.class.getPackage(), "AsyncPostProcessingTestWeb.xml", "web.xml");
return TestUtil.finishContainerPrepare(war, null, AsyncPostProcessingResource.class,
AsyncPostProcessingMsgBodyWriterInterceptor.class, AsyncPostProcessingInterceptor.class);
}
private String generateURL(String path) {
return PortProviderUtil.generateURL(path, AsyncPostProcessingTest.class.getSimpleName());
}
@Before
public void init() {
client = new ResteasyClientBuilder().build();
}
@After
public void after() throws Exception {
client.close();
}
/**
* @tpTestDetails Test synchronized request.
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testSync() throws Exception {
reset();
Response response = client.target(generateURL("/sync")).request().get();
logger.info("Status: " + response.getStatus());
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
logger.info("TestMessageBodyWriterInterceptor.called: " + AsyncPostProcessingMsgBodyWriterInterceptor.called);
logger.info("TestPostProcessInterceptor.called: " + AsyncPostProcessingInterceptor.called);
response.bufferEntity();
logger.info("returned entity: " + response.readEntity(String.class));
Assert.assertTrue("AsyncPostProcessingMsgBodyWriterInterceptor interceptor was not called",
AsyncPostProcessingMsgBodyWriterInterceptor.called);
Assert.assertTrue("AsyncPostProcessingInterceptor interceptor was not called", AsyncPostProcessingInterceptor.called);
Assert.assertEquals("Entity has wrong content", "sync", response.readEntity(String.class));
}
/**
* @tpTestDetails Test async request with delay.
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testAsyncWithDelay() throws Exception {
reset();
Response response = client.target(generateURL("/async/delay")).request().get();
logger.info("Status: " + response.getStatus());
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
logger.info("TestMessageBodyWriterInterceptor.called: " + AsyncPostProcessingMsgBodyWriterInterceptor.called);
logger.info("TestPostProcessInterceptor.called: " + AsyncPostProcessingInterceptor.called);
response.bufferEntity();
logger.info("returned entity: " + response.readEntity(String.class));
Assert.assertTrue("AsyncPostProcessingMsgBodyWriterInterceptor interceptor was not called",
AsyncPostProcessingMsgBodyWriterInterceptor.called);
Assert.assertTrue("AsyncPostProcessingInterceptor interceptor was not called", AsyncPostProcessingInterceptor.called);
Assert.assertEquals("Entity has wrong content", "async/delay", response.readEntity(String.class));
}
/**
* @tpTestDetails Test async request without delay.
* @tpSince RESTEasy 3.0.16
*/
@Test
public void testAsyncWithNoDelay() throws Exception {
reset();
Response response = client.target(generateURL("/async/nodelay")).request().get();
logger.info("Status: " + response.getStatus());
Assert.assertEquals(HttpResponseCodes.SC_OK, response.getStatus());
logger.info("TestMessageBodyWriterInterceptor.called: " + AsyncPostProcessingMsgBodyWriterInterceptor.called);
logger.info("TestPostProcessInterceptor.called: " + AsyncPostProcessingInterceptor.called);
response.bufferEntity();
logger.info("returned entity: " + response.readEntity(String.class));
Assert.assertTrue("AsyncPostProcessingMsgBodyWriterInterceptor interceptor was not called",
AsyncPostProcessingMsgBodyWriterInterceptor.called);
Assert.assertTrue("AsyncPostProcessingInterceptor interceptor was not called", AsyncPostProcessingInterceptor.called);
Assert.assertEquals("Entity has wrong content", "async/nodelay", response.readEntity(String.class));
}
private void reset() {
AsyncPostProcessingMsgBodyWriterInterceptor.called = false;
AsyncPostProcessingInterceptor.called = false;
}
}