/* * JBoss, Home of Professional Open Source * Copyright 2012, Red Hat, Inc., and individual contributors * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.apache.org/licenses/LICENSE-2.0 * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jboss.cdi.tck.tests.context.request.async; import java.io.IOException; import java.util.Arrays; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import javax.inject.Inject; import javax.servlet.AsyncContext; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.jboss.cdi.tck.util.SimpleLogger; @WebServlet(name = "AsyncServlet", urlPatterns = { "/AsyncServlet" }, asyncSupported = true) @SuppressWarnings("serial") public class AsyncServlet extends HttpServlet { public static final String TEST_TIMEOUT = "timeout"; public static final String TEST_COMPLETE = "complete"; public static final String TEST_ERROR = "error"; public static final String TEST_LOOP = "loop"; private static final String[] VALID_TESTS = new String[] { TEST_TIMEOUT, TEST_COMPLETE, TEST_ERROR, TEST_LOOP }; private static final SimpleLogger logger = new SimpleLogger(AsyncServlet.class); private static final long TIMEOUT = 200l; private static boolean inLoop = false; private ExecutorService executorService; @Inject StatusBean statusBean; @Override public void init() throws ServletException { // Note that executor thread does not use the same CL executorService = Executors.newSingleThreadExecutor(); } @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { String test = req.getParameter("test"); if (!Arrays.asList(VALID_TESTS).contains(test)) { resp.setStatus(404); return; } statusBean.reset(); final AsyncContext actx = req.startAsync(); actx.addListener(actx.createListener(SimpleAsyncListener.class)); resp.setContentType("text/plain"); if (TEST_TIMEOUT.equals(test)) { actx.setTimeout(TIMEOUT); } else if (TEST_COMPLETE.equals(test)) { executorService.execute(new AsyncRequestProcessor(actx, 50l, false, null)); } else if (TEST_ERROR.equals(test)) { executorService.execute(new AsyncRequestProcessor(actx, 50l, true, "/FailingServlet")); } else if (TEST_LOOP.equals(test)) { if (inLoop) { executorService.execute(new AsyncRequestProcessor(actx, 50l, false, null)); } else { executorService.execute(new AsyncRequestProcessor(actx, 50l, true, null)); inLoop = true; } } logger.log("Service finished: {0}", test); } }