Status: New
Owner: ----
New issue 650 by [email protected]: Guice can't create async servlet
http://code.google.com/p/google-guice/issues/detail?id=650
I've connect Guice to my project, write web.xml and everything gone right
until I wan't to realize async servlet. I using Tomcat 7.0.20 and Guice
3.0. Servlets spec version is 3.0.
Test Comet servlet:
@Singleton
@WebServlet(name = "comet", urlPatterns = {"/comet"}, asyncSupported = true)
public class CometServlet extends HttpServlet {
private class TestThread implements Runnable {
private AsyncContext context;
public TestThread(AsyncContext ctx) {
context = ctx;
}
@Override
public void run() {
try {
Thread.sleep(5000);
context.getResponse().getWriter().write("TEST!");
} catch (InterruptedException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
AsyncContext ctx = req.startAsync(req, resp);
new Thread(new TestThread(ctx)).start();
}
}
Servlet created, it placed at "/comet" path, but async not working and
error was printed:
HTTP Status 500
java.lang.IllegalStateException: Not supported.
org.apache.catalina.connector.Request.startAsync(Request.java:1638)
org.apache.catalina.connector.RequestFacade.startAsync(RequestFacade.java:1031)
javax.servlet.ServletRequestWrapper.startAsync(ServletRequestWrapper.java:379)
javax.servlet.ServletRequestWrapper.startAsync(ServletRequestWrapper.java:379)
ru.unimobi.cinema.server.server.servlets.CometServlet.service(CometServlet.java:46)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
com.google.inject.servlet.ServletDefinition.doService(ServletDefinition.java:216)
com.google.inject.servlet.ServletDefinition.service(ServletDefinition.java:141)
com.google.inject.servlet.ManagedServletPipeline.service(ManagedServletPipeline.java:93)
com.google.inject.servlet.FilterChainInvocation.doFilter(FilterChainInvocation.java:63)
com.google.inject.servlet.FilterDefinition.doFilter(FilterDefinition.java:134)
com.google.inject.servlet.FilterChainInvocation.doFilter(FilterChainInvocation.java:59)
com.google.inject.servlet.ManagedFilterPipeline.dispatch(ManagedFilterPipeline.java:122)
com.google.inject.servlet.GuiceFilter.doFilter(GuiceFilter.java:110)
I think this is bug, because I write web.xml directly without Guice and it
working as expected.
--
You received this message because you are subscribed to the Google Groups
"google-guice-dev" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to
[email protected].
For more options, visit this group at
http://groups.google.com/group/google-guice-dev?hl=en.