From 0948260ada06520436513558a6e347bd0052a83c Mon Sep 17 00:00:00 2001 From: Simon Willnauer Date: Wed, 16 Apr 2014 22:59:31 +0200 Subject: [PATCH] [TEST] make testTimeoutSendExceptionWithDelayedResponse more reliable on slow systems --- .../transport/AbstractSimpleTransportTests.java | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/test/java/org/elasticsearch/transport/AbstractSimpleTransportTests.java b/src/test/java/org/elasticsearch/transport/AbstractSimpleTransportTests.java index 5126dbd4445..153c33e1a91 100644 --- a/src/test/java/org/elasticsearch/transport/AbstractSimpleTransportTests.java +++ b/src/test/java/org/elasticsearch/transport/AbstractSimpleTransportTests.java @@ -441,7 +441,6 @@ public abstract class AbstractSimpleTransportTests extends ElasticsearchTestCase } @Test - @TestLogging("_root:TRACE") public void testTimeoutSendExceptionWithDelayedResponse() throws Exception { serviceA.registerHandler("sayHelloTimeoutDelayedResponse", new BaseTransportRequestHandler() { @Override @@ -470,7 +469,7 @@ public abstract class AbstractSimpleTransportTests extends ElasticsearchTestCase } } }); - + final CountDownLatch latch = new CountDownLatch(1); TransportFuture res = serviceB.submitRequest(nodeA, "sayHelloTimeoutDelayedResponse", new StringMessageRequest("300ms"), options().withTimeout(100), new BaseTransportResponseHandler() { @Override @@ -485,11 +484,13 @@ public abstract class AbstractSimpleTransportTests extends ElasticsearchTestCase @Override public void handleResponse(StringMessageResponse response) { + latch.countDown(); assertThat("got response instead of exception", false, equalTo(true)); } @Override public void handleException(TransportException exp) { + latch.countDown(); assertThat(exp, instanceOf(ReceiveTimeoutTransportException.class)); } }); @@ -500,15 +501,13 @@ public abstract class AbstractSimpleTransportTests extends ElasticsearchTestCase } catch (Exception e) { assertThat(e, instanceOf(ReceiveTimeoutTransportException.class)); } - - // sleep for 400 millis to make sure we get back the response - Thread.sleep(400); + latch.await(); for (int i = 0; i < 10; i++) { final int counter = i; // now, try and send another request, this times, with a short timeout res = serviceB.submitRequest(nodeA, "sayHelloTimeoutDelayedResponse", - new StringMessageRequest(counter + "ms"), options().withTimeout(100), new BaseTransportResponseHandler() { + new StringMessageRequest(counter + "ms"), options().withTimeout(300), new BaseTransportResponseHandler() { @Override public StringMessageResponse newInstance() { return new StringMessageResponse();