diff options
author | Simone Bordet | 2015-12-11 11:25:54 +0000 |
---|---|---|
committer | Simone Bordet | 2015-12-11 11:25:54 +0000 |
commit | c3889873f66c946f8848291d887d20d6f125a02b (patch) | |
tree | a609153aa074ae0d1bf241abd61c94d9a98f5fed /tests/test-http-client-transport | |
parent | e7d8980952bddd172b1580462032e8c6221f3841 (diff) | |
download | org.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.java | 26 |
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()); + } } |