Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimone Bordet2015-12-11 11:25:54 +0000
committerSimone Bordet2015-12-11 11:25:54 +0000
commitc3889873f66c946f8848291d887d20d6f125a02b (patch)
treea609153aa074ae0d1bf241abd61c94d9a98f5fed /tests/test-http-client-transport
parente7d8980952bddd172b1580462032e8c6221f3841 (diff)
downloadorg.eclipse.jetty.project-c3889873f66c946f8848291d887d20d6f125a02b.tar.gz
org.eclipse.jetty.project-c3889873f66c946f8848291d887d20d6f125a02b.tar.xz
org.eclipse.jetty.project-c3889873f66c946f8848291d887d20d6f125a02b.zip
484167 - GOAWAY frames aren't handling disconnects appropriately on Client.
Fixed by overriding onClose() to listen for GOAWAY frames, and acting appropriately.
Diffstat (limited to 'tests/test-http-client-transport')
-rw-r--r--tests/test-http-client-transport/src/test/java/org/eclipse/jetty/http/client/HttpClientIdleTimeoutTest.java26
1 files changed, 26 insertions, 0 deletions
diff --git a/tests/test-http-client-transport/src/test/java/org/eclipse/jetty/http/client/HttpClientIdleTimeoutTest.java b/tests/test-http-client-transport/src/test/java/org/eclipse/jetty/http/client/HttpClientIdleTimeoutTest.java
index e168a0f3ef..c38bceb296 100644
--- a/tests/test-http-client-transport/src/test/java/org/eclipse/jetty/http/client/HttpClientIdleTimeoutTest.java
+++ b/tests/test-http-client-transport/src/test/java/org/eclipse/jetty/http/client/HttpClientIdleTimeoutTest.java
@@ -27,6 +27,8 @@ import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
+import org.eclipse.jetty.client.api.ContentResponse;
+import org.eclipse.jetty.http.HttpStatus;
import org.eclipse.jetty.server.Request;
import org.eclipse.jetty.server.handler.AbstractHandler;
import org.junit.Assert;
@@ -93,4 +95,28 @@ public class HttpClientIdleTimeoutTest extends AbstractTest
Assert.assertTrue(latch.await(2 * idleTimeout, TimeUnit.MILLISECONDS));
}
+
+ @Test
+ public void testServerIdleTimeout() throws Exception
+ {
+ start(new AbstractHandler()
+ {
+ @Override
+ public void handle(String target, Request baseRequest, HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException
+ {
+ baseRequest.setHandled(true);
+ }
+ });
+ connector.setIdleTimeout(idleTimeout);
+
+ ContentResponse response1 = client.newRequest(newURI()).send();
+ Assert.assertEquals(HttpStatus.OK_200, response1.getStatus());
+
+ // Let the server idle timeout.
+ Thread.sleep(2 * idleTimeout);
+
+ // Make sure we can make another request successfully.
+ ContentResponse response2 = client.newRequest(newURI()).send();
+ Assert.assertEquals(HttpStatus.OK_200, response2.getStatus());
+ }
}

Back to the top