From 694593579b492c33a67b3747a9d8815eac88da7a Mon Sep 17 00:00:00 2001 From: Simon Brandhof Date: Fri, 12 Sep 2014 18:09:22 +0200 Subject: SONAR-4898 improve stability of WatcherThreadTest on slow machines --- .../test/java/org/sonar/process/monitor/WatcherThreadTest.java | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'server/sonar-process-monitor') diff --git a/server/sonar-process-monitor/src/test/java/org/sonar/process/monitor/WatcherThreadTest.java b/server/sonar-process-monitor/src/test/java/org/sonar/process/monitor/WatcherThreadTest.java index 86f3a47e6ff..251dcdb21ea 100644 --- a/server/sonar-process-monitor/src/test/java/org/sonar/process/monitor/WatcherThreadTest.java +++ b/server/sonar-process-monitor/src/test/java/org/sonar/process/monitor/WatcherThreadTest.java @@ -24,6 +24,8 @@ import org.mockito.Mockito; import org.mockito.invocation.InvocationOnMock; import org.mockito.stubbing.Answer; +import java.util.concurrent.atomic.AtomicBoolean; + import static org.mockito.Mockito.mock; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; @@ -33,9 +35,11 @@ public class WatcherThreadTest { @Test(timeout = 10000L) public void kill_process_if_watcher_is_interrupted() throws Exception { ProcessRef ref = mock(ProcessRef.class, Mockito.RETURNS_DEEP_STUBS); + final AtomicBoolean waiting = new AtomicBoolean(false); when(ref.getProcess().waitFor()).thenAnswer(new Answer() { @Override public Object answer(InvocationOnMock invocationOnMock) throws Throwable { + waiting.set(true); Thread.sleep(Long.MAX_VALUE); return 0; } @@ -44,9 +48,11 @@ public class WatcherThreadTest { WatcherThread watcher = new WatcherThread(ref, monitor); watcher.start(); - Thread.sleep(50L); - watcher.interrupt(); + while (!waiting.get()) { + Thread.sleep(50L); + } + watcher.interrupt(); verify(ref).hardKill(); } } -- cgit v1.2.3