460905 - Make sure TimeoutCompleteListener is cancelled if the request cannot be sent.

This commit is contained in:
Simone Bordet 2015-02-26 12:25:42 +01:00
parent d5a6ad2345
commit 008b03ac78
2 changed files with 17 additions and 8 deletions

View File

@ -683,6 +683,7 @@ public class HttpRequest implements Request
// can't even start sending the request. // can't even start sending the request.
if (timeoutListener != null) if (timeoutListener != null)
timeoutListener.cancel(); timeoutListener.cancel();
throw x;
} }
} }

View File

@ -434,7 +434,10 @@ public class HttpClientTimeoutTest extends AbstractHttpClientServerTest
start(new EmptyServerHandler()); start(new EmptyServerHandler());
long timeout = 1000; long timeout = 1000;
Request request = client.newRequest("bad_scheme://localhost:" + connector.getLocalPort()); Request request = client.newRequest("badscheme://localhost:" + connector.getLocalPort());
try
{
request.timeout(timeout, TimeUnit.MILLISECONDS) request.timeout(timeout, TimeUnit.MILLISECONDS)
.send(new Response.CompleteListener() .send(new Response.CompleteListener()
{ {
@ -443,6 +446,11 @@ public class HttpClientTimeoutTest extends AbstractHttpClientServerTest
{ {
} }
}); });
Assert.fail();
}
catch (Exception expected)
{
}
Thread.sleep(2 * timeout); Thread.sleep(2 * timeout);