package org.jboss.resteasy.test.cdi.interceptors; 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.cdi.interceptors.resource.TimerInterceptorResource; import org.jboss.resteasy.test.cdi.interceptors.resource.TimerInterceptorResourceIntf; import org.jboss.resteasy.test.cdi.util.UtilityProducer; import org.jboss.resteasy.utils.PortProviderUtil; import org.jboss.resteasy.utils.TestUtil; import org.jboss.shrinkwrap.api.Archive; import org.jboss.shrinkwrap.api.asset.EmptyAsset; import org.jboss.shrinkwrap.api.spec.WebArchive; import org.junit.Test; import org.junit.runner.RunWith; import javax.ws.rs.client.Client; import javax.ws.rs.client.ClientBuilder; import javax.ws.rs.client.WebTarget; import javax.ws.rs.core.Response; import static org.junit.Assert.assertEquals; /** * @tpSubChapter CDI * @tpChapter Integration tests * @tpTestCaseDetails Test for interceptors with timer service. * @tpSince RESTEasy 3.0.16 */ @RunWith(Arquillian.class) @RunAsClient public class TimerInterceptorTest { protected static final Logger log = LogManager.getLogger(TimerInterceptorTest.class.getName()); @Deployment public static Archive<?> createTestArchive() { WebArchive war = TestUtil.prepareArchive(TimerInterceptorTest.class.getSimpleName()) .addClasses(UtilityProducer.class, PortProviderUtil.class) .addClasses(TimerInterceptorResourceIntf.class, TimerInterceptorResource.class) .addAsWebInfResource(EmptyAsset.INSTANCE, "beans.xml"); return war; } private String generateURL(String path) { return PortProviderUtil.generateURL(path, TimerInterceptorTest.class.getSimpleName()); } /** * @tpTestDetails Timer is sheduled and than is called. * @tpSince RESTEasy 3.0.16 */ @Test public void testTimerInterceptor() throws Exception { Client client = ClientBuilder.newClient(); // Schedule timer. WebTarget base = client.target(generateURL("/timer/schedule")); Response response = base.request().get(); log.info("Status: " + response.getStatus()); assertEquals(200, response.getStatus()); response.close(); // Verify timer expired and timer interceptor was executed. base = client.target(generateURL("/timer/test")); response = base.request().get(); log.info("Status: " + response.getStatus()); assertEquals(200, response.getStatus()); response.close(); client.close(); } }