avoid double request handling when suspended

This commit is contained in:
Greg Wilkins 2011-11-17 10:35:14 +11:00
parent e48570bd5e
commit 97b48a5b93
3 changed files with 52 additions and 9 deletions

View File

@ -111,14 +111,19 @@ public class AsyncHttpConnection extends AbstractHttpConnection implements Async
reset();
// TODO Is this required?
// TODO Is this still required?
if (!_generator.isPersistent() && !_endp.isOutputShutdown())
{
LOG.warn("Safety net oshut!!!");
LOG.warn("Safety net oshut!!! IF YOU SEE THIS, PLEASE RAISE BUGZILLA");
_endp.shutdownOutput();
}
}
else if (_request.getAsyncContinuation().isAsyncStarted())
{
// The request is suspended, so even though progress has been made, break the while loop
LOG.debug("suspended {}",this);
break;
}
}
}
}

View File

@ -31,16 +31,16 @@ import org.junit.After;
import org.junit.Before;
import org.junit.Test;
public class AsyncContextTest
public class LocalAsyncContextTest
{
protected Server _server = new Server();
protected SuspendHandler _handler = new SuspendHandler();
protected LocalConnector _connector;
protected Connector _connector;
@Before
public void init() throws Exception
{
_connector = new LocalConnector();
_connector = initConnector();
_server.setConnectors(new Connector[]{ _connector });
SessionHandler session = new SessionHandler();
@ -49,6 +49,11 @@ public class AsyncContextTest
_server.setHandler(session);
_server.start();
}
protected Connector initConnector()
{
return new LocalConnector();
}
@After
public void destroy() throws Exception
@ -129,14 +134,21 @@ public class AsyncContextTest
private synchronized String process(String content) throws Exception
{
String request = "GET / HTTP/1.1\r\n" + "Host: localhost\r\n";
String request = "GET / HTTP/1.1\r\n" +
"Host: localhost\r\n"+
"Connection: close\r\n";
if (content==null)
request+="\r\n";
else
request+="Content-Length: "+content.length()+"\r\n" + "\r\n" + content;
request+="Content-Length: "+content.length()+"\r\n" +"\r\n" + content;
return _connector.getResponses(request);
return getResponse(request);
}
protected String getResponse(String request) throws Exception
{
return ((LocalConnector)_connector).getResponses(request);
}
private static class SuspendHandler extends HandlerWrapper

View File

@ -0,0 +1,26 @@
package org.eclipse.jetty.server;
import java.net.Socket;
import org.eclipse.jetty.server.nio.SelectChannelConnector;
import org.eclipse.jetty.util.IO;
public class SelectChannelAsyncContextTest extends LocalAsyncContextTest
{
@Override
protected Connector initConnector()
{
return new SelectChannelConnector();
}
@Override
protected String getResponse(String request) throws Exception
{
SelectChannelConnector connector = (SelectChannelConnector)_connector;
Socket socket = new Socket((String)null,connector.getLocalPort());
socket.getOutputStream().write(request.getBytes("UTF-8"));
return IO.toString(socket.getInputStream());
}
}