diff --git a/jetty-rewrite/src/test/java/org/eclipse/jetty/rewrite/handler/AbstractRuleTestCase.java b/jetty-rewrite/src/test/java/org/eclipse/jetty/rewrite/handler/AbstractRuleTestCase.java index 7907fb04abf..955391dbe52 100644 --- a/jetty-rewrite/src/test/java/org/eclipse/jetty/rewrite/handler/AbstractRuleTestCase.java +++ b/jetty-rewrite/src/test/java/org/eclipse/jetty/rewrite/handler/AbstractRuleTestCase.java @@ -13,6 +13,7 @@ package org.eclipse.jetty.rewrite.handler; import org.eclipse.jetty.io.bio.StringEndPoint; +import org.eclipse.jetty.server.BlockingHttpConnection; import org.eclipse.jetty.server.Connector; import org.eclipse.jetty.server.HttpConnection; import org.eclipse.jetty.server.LocalConnector; @@ -61,7 +62,7 @@ public abstract class AbstractRuleTestCase protected void reset() { - _connection = new HttpConnection(_connector, _endpoint, _server); + _connection = new BlockingHttpConnection(_connector, _endpoint, _server); _request = new Request(_connection); _response = new Response(_connection); _request.setRequestURI("/test/"); diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java index 34654605298..aa0e5c29870 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java @@ -88,7 +88,7 @@ import org.eclipse.jetty.util.thread.Timeout; *

* */ -public class HttpConnection extends AbstractConnection +public abstract class HttpConnection extends AbstractConnection { private static final int UNKNOWN = -2; private static final ThreadLocal __currentConnection = new ThreadLocal(); @@ -528,10 +528,7 @@ public class HttpConnection extends AbstractConnection } /* ------------------------------------------------------------ */ - public Connection handle() throws IOException - { - return this; - } + public abstract Connection handle() throws IOException; /* ------------------------------------------------------------ */ public void commitResponse(boolean last) throws IOException diff --git a/jetty-server/src/test/java/org/eclipse/jetty/server/ResponseTest.java b/jetty-server/src/test/java/org/eclipse/jetty/server/ResponseTest.java index 9b80a044125..d9f57f06426 100644 --- a/jetty-server/src/test/java/org/eclipse/jetty/server/ResponseTest.java +++ b/jetty-server/src/test/java/org/eclipse/jetty/server/ResponseTest.java @@ -33,10 +33,14 @@ import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSessionContext; +import org.eclipse.jetty.http.Generator; import org.eclipse.jetty.http.HttpHeaders; import org.eclipse.jetty.http.HttpURI; +import org.eclipse.jetty.http.Parser; import org.eclipse.jetty.io.ByteArrayBuffer; import org.eclipse.jetty.io.ByteArrayEndPoint; +import org.eclipse.jetty.io.Connection; +import org.eclipse.jetty.io.EndPoint; import org.eclipse.jetty.server.bio.SocketConnector; import org.eclipse.jetty.server.handler.AbstractHandler; import org.eclipse.jetty.server.handler.ContextHandler; @@ -55,7 +59,7 @@ public class ResponseTest { private Server server; private LocalConnector connector; - + @Before public void init() throws Exception { @@ -76,7 +80,7 @@ public class ResponseTest @Test public void testContentType() throws Exception { - HttpConnection connection = new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); + HttpConnection connection = new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); Response response = connection.getResponse(); assertEquals(null,response.getContentType()); @@ -121,7 +125,7 @@ public class ResponseTest public void testLocale() throws Exception { - HttpConnection connection = new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); + HttpConnection connection = new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); Request request = connection.getRequest(); Response response = connection.getResponse(); ContextHandler context = new ContextHandler(); @@ -145,7 +149,7 @@ public class ResponseTest @Test public void testContentTypeCharacterEncoding() throws Exception { - HttpConnection connection = new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); + HttpConnection connection = new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); Request request = connection.getRequest(); Response response = connection.getResponse(); @@ -178,7 +182,7 @@ public class ResponseTest @Test public void testCharacterEncodingContentType() throws Exception { - Response response = new Response(new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); + Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); response.setCharacterEncoding("utf-8"); response.setContentType("foo/bar"); @@ -207,7 +211,7 @@ public class ResponseTest @Test public void testContentTypeWithCharacterEncoding() throws Exception { - Response response = new Response(new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); + Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); response.setCharacterEncoding("utf16"); response.setContentType("foo/bar; charset=utf-8"); @@ -236,7 +240,7 @@ public class ResponseTest @Test public void testContentTypeWithOther() throws Exception { - Response response = new Response(new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); + Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); response.setContentType("foo/bar; other=xyz"); assertEquals("foo/bar; other=xyz",response.getContentType()); @@ -259,7 +263,7 @@ public class ResponseTest @Test public void testContentTypeWithCharacterEncodingAndOther() throws Exception { - Response response = new Response(new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); + Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); response.setCharacterEncoding("utf16"); response.setContentType("foo/bar; charset=utf-8 other=xyz"); @@ -319,7 +323,7 @@ public class ResponseTest public void testEncodeRedirect() throws Exception { - HttpConnection connection=new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); + HttpConnection connection=new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()); Response response = new Response(connection); Request request = connection.getRequest(); request.setServerName("myhost"); @@ -369,7 +373,7 @@ public class ResponseTest throws Exception { ByteArrayEndPoint out=new ByteArrayEndPoint(new byte[]{},4096); - HttpConnection connection=new HttpConnection(connector,out, connector.getServer()); + HttpConnection connection=new TestHttpConnection(connector,out, connector.getServer()); Response response = new Response(connection); Request request = connection.getRequest(); request.setServerName("myhost"); @@ -398,7 +402,7 @@ public class ResponseTest @Test public void testSetBufferSize () throws Exception { - Response response = new Response(new HttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); + Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer())); response.setBufferSize(20*1024); response.getWriter().print("hello"); try @@ -464,7 +468,7 @@ public class ResponseTest ByteArrayEndPoint endPoint = new ByteArrayEndPoint(); endPoint.setOut(new ByteArrayBuffer(1024)); endPoint.setGrowOutput(true); - HttpConnection connection=new HttpConnection(connector, endPoint, connector.getServer()); + HttpConnection connection=new TestHttpConnection(connector, endPoint, connector.getServer()); connection.getGenerator().reset(false); HttpConnection.setCurrentConnection(connection); Response response = connection.getResponse(); @@ -565,4 +569,25 @@ public class ResponseTest return null; } } + + static class TestHttpConnection extends HttpConnection + { + + public TestHttpConnection(Connector connector, EndPoint endpoint, Server server) + { + super(connector,endpoint,server); + } + + public TestHttpConnection(Connector connector, EndPoint endpoint, Server server, Parser parser, Generator generator, Request request) + { + super(connector,endpoint,server,parser,generator,request); + } + + @Override + public Connection handle() throws IOException + { + return this; + } + + } }