From 9acc8c72ee1e506a37a688378565581da031e298 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Xavier=20L=C3=A9aut=C3=A9?= Date: Wed, 7 Jan 2015 15:07:14 -0800 Subject: [PATCH 1/2] new faster container builds in Travis-CI --- .travis.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.travis.yml b/.travis.yml index 2fd5140efca..f888220552e 100644 --- a/.travis.yml +++ b/.travis.yml @@ -3,3 +3,5 @@ language: java jdk: - oraclejdk7 - oraclejdk8 + +sudo: false From d5f4182de4535a3999bfbfc703530bf4731cea97 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Xavier=20L=C3=A9aut=C3=A9?= Date: Wed, 7 Jan 2015 22:55:53 -0800 Subject: [PATCH 2/2] global test timeouts + fix test race condition --- .../ChainedExecutionQueryRunnerTest.java | 47 ++++++++++--------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/processing/src/test/java/io/druid/query/ChainedExecutionQueryRunnerTest.java b/processing/src/test/java/io/druid/query/ChainedExecutionQueryRunnerTest.java index 9ba455eaed8..58d9331f3e2 100644 --- a/processing/src/test/java/io/druid/query/ChainedExecutionQueryRunnerTest.java +++ b/processing/src/test/java/io/druid/query/ChainedExecutionQueryRunnerTest.java @@ -42,11 +42,10 @@ import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; -import java.util.concurrent.TimeUnit; public class ChainedExecutionQueryRunnerTest { - @Test + @Test(timeout = 60000) public void testQueryCancellation() throws Exception { ExecutorService exec = PrioritizedExecutorService.create( @@ -124,8 +123,8 @@ public class ChainedExecutionQueryRunnerTest ); // wait for query to register and start - Assert.assertTrue(queryIsRegistered.await(1, TimeUnit.SECONDS)); - Assert.assertTrue(queriesStarted.await(1, TimeUnit.SECONDS)); + queryIsRegistered.await(); + queriesStarted.await(); // cancel the query Assert.assertTrue(capturedFuture.hasCaptured()); @@ -139,14 +138,16 @@ public class ChainedExecutionQueryRunnerTest Assert.assertTrue(e.getCause() instanceof QueryInterruptedException); cause = (QueryInterruptedException)e.getCause(); } - Assert.assertTrue(queriesInterrupted.await(500, TimeUnit.MILLISECONDS)); + queriesInterrupted.await(); Assert.assertNotNull(cause); Assert.assertTrue(future.isCancelled()); Assert.assertTrue(runner1.hasStarted); Assert.assertTrue(runner2.hasStarted); Assert.assertTrue(runner1.interrupted); Assert.assertTrue(runner2.interrupted); - Assert.assertTrue(!runner3.hasStarted || runner3.interrupted); + synchronized (runner3) { + Assert.assertTrue(!runner3.hasStarted || runner3.interrupted); + } Assert.assertFalse(runner1.hasCompleted); Assert.assertFalse(runner2.hasCompleted); Assert.assertFalse(runner3.hasCompleted); @@ -154,7 +155,7 @@ public class ChainedExecutionQueryRunnerTest EasyMock.verify(watcher); } - @Test + @Test(timeout = 60000) public void testQueryTimeout() throws Exception { ExecutorService exec = PrioritizedExecutorService.create( @@ -233,8 +234,8 @@ public class ChainedExecutionQueryRunnerTest ); // wait for query to register and start - Assert.assertTrue(queryIsRegistered.await(1, TimeUnit.SECONDS)); - Assert.assertTrue(queriesStarted.await(1, TimeUnit.SECONDS)); + queryIsRegistered.await(); + queriesStarted.await(); Assert.assertTrue(capturedFuture.hasCaptured()); ListenableFuture future = capturedFuture.getValue(); @@ -248,14 +249,16 @@ public class ChainedExecutionQueryRunnerTest Assert.assertEquals("Query timeout", e.getCause().getMessage()); cause = (QueryInterruptedException)e.getCause(); } - Assert.assertTrue(queriesInterrupted.await(500, TimeUnit.MILLISECONDS)); + queriesInterrupted.await(); Assert.assertNotNull(cause); Assert.assertTrue(future.isCancelled()); Assert.assertTrue(runner1.hasStarted); Assert.assertTrue(runner2.hasStarted); Assert.assertTrue(runner1.interrupted); Assert.assertTrue(runner2.interrupted); - Assert.assertTrue(!runner3.hasStarted || runner3.interrupted); + synchronized (runner3) { + Assert.assertTrue(!runner3.hasStarted || runner3.interrupted); + } Assert.assertFalse(runner1.hasCompleted); Assert.assertFalse(runner2.hasCompleted); Assert.assertFalse(runner3.hasCompleted); @@ -268,9 +271,9 @@ public class ChainedExecutionQueryRunnerTest private final CountDownLatch start; private final CountDownLatch stop; - private boolean hasStarted = false; - private boolean hasCompleted = false; - private boolean interrupted = false; + private volatile boolean hasStarted = false; + private volatile boolean hasCompleted = false; + private volatile boolean interrupted = false; public DyingQueryRunner(CountDownLatch start, CountDownLatch stop) { @@ -281,17 +284,19 @@ public class ChainedExecutionQueryRunnerTest @Override public Sequence run(Query query, Map responseContext) { - hasStarted = true; - start.countDown(); - if (Thread.interrupted()) { - interrupted = true; - stop.countDown(); - throw new QueryInterruptedException("I got killed"); + synchronized (this) { // ensure hasStarted and interrupted are updated simultaneously + hasStarted = true; + start.countDown(); + if (Thread.interrupted()) { + interrupted = true; + stop.countDown(); + throw new QueryInterruptedException("I got killed"); + } } // do a lot of work try { - Thread.sleep(500); + Thread.sleep(5000); } catch (InterruptedException e) { interrupted = true;