[cvs] / jsr166 / src / test / tck / FutureTaskTest.java Repository:
ViewVC logotype

Diff of /jsr166/src/test/tck/FutureTaskTest.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.21, Sat Oct 9 19:30:35 2010 UTC revision 1.22, Sun Nov 28 20:20:00 2010 UTC
# Line 9  Line 9 
9  import junit.framework.*;  import junit.framework.*;
10  import java.util.concurrent.*;  import java.util.concurrent.*;
11  import static java.util.concurrent.TimeUnit.MILLISECONDS;  import static java.util.concurrent.TimeUnit.MILLISECONDS;
12    import static java.util.concurrent.TimeUnit.SECONDS;
13  import java.util.*;  import java.util.*;
14    
15  public class FutureTaskTest extends JSR166TestCase {  public class FutureTaskTest extends JSR166TestCase {
# Line 20  Line 21 
21          return new TestSuite(FutureTaskTest.class);          return new TestSuite(FutureTaskTest.class);
22      }      }
23    
24        void checkNotDone(Future<?> f) {
25            assertFalse(f.isDone());
26            assertFalse(f.isCancelled());
27        }
28    
29        <T> void checkCompletedNormally(Future<T> f, T expected) {
30            assertTrue(f.isDone());
31            assertFalse(f.isCancelled());
32    
33            try {
34                assertSame(expected, f.get());
35            } catch (Throwable fail) { threadUnexpectedException(fail); }
36            try {
37                assertSame(expected, f.get(5L, SECONDS));
38            } catch (Throwable fail) { threadUnexpectedException(fail); }
39    
40            assertFalse(f.cancel(false));
41            assertFalse(f.cancel(true));
42        }
43    
44        void checkCancelled(Future<?> f) {
45            assertTrue(f.isDone());
46            assertTrue(f.isCancelled());
47    
48            try {
49                f.get();
50                shouldThrow();
51            } catch (CancellationException success) {
52            } catch (Throwable fail) { threadUnexpectedException(fail); }
53    
54            try {
55                f.get(5L, SECONDS);
56                shouldThrow();
57            } catch (CancellationException success) {
58            } catch (Throwable fail) { threadUnexpectedException(fail); }
59    
60            assertFalse(f.cancel(false));
61            assertFalse(f.cancel(true));
62        }
63    
64        void checkCompletedAbnormally(Future<?> f, Throwable t) {
65            assertTrue(f.isDone());
66            assertFalse(f.isCancelled());
67    
68            try {
69                f.get();
70                shouldThrow();
71            } catch (ExecutionException success) {
72                assertSame(t, success.getCause());
73            } catch (Throwable fail) { threadUnexpectedException(fail); }
74    
75            try {
76                f.get(5L, SECONDS);
77                shouldThrow();
78            } catch (ExecutionException success) {
79                assertSame(t, success.getCause());
80            } catch (Throwable fail) { threadUnexpectedException(fail); }
81    
82            assertFalse(f.cancel(false));
83            assertFalse(f.cancel(true));
84        }
85    
86      /**      /**
87       * Subclass to expose protected methods       * Subclass to expose protected methods
88       */       */
# Line 57  Line 120 
120          FutureTask task = new FutureTask(new NoOpCallable());          FutureTask task = new FutureTask(new NoOpCallable());
121          task.run();          task.run();
122          assertTrue(task.isDone());          assertTrue(task.isDone());
123          assertFalse(task.isCancelled());          checkCompletedNormally(task, Boolean.TRUE);
124      }      }
125    
126      /**      /**
# Line 66  Line 129 
129      public void testRunAndReset() {      public void testRunAndReset() {
130          PublicFutureTask task = new PublicFutureTask(new NoOpCallable());          PublicFutureTask task = new PublicFutureTask(new NoOpCallable());
131          assertTrue(task.runAndReset());          assertTrue(task.runAndReset());
132          assertFalse(task.isDone());          checkNotDone(task);
133      }      }
134    
135      /**      /**
# Line 76  Line 139 
139          PublicFutureTask task = new PublicFutureTask(new NoOpCallable());          PublicFutureTask task = new PublicFutureTask(new NoOpCallable());
140          assertTrue(task.cancel(false));          assertTrue(task.cancel(false));
141          assertFalse(task.runAndReset());          assertFalse(task.runAndReset());
142          assertTrue(task.isDone());          checkCancelled(task);
         assertTrue(task.isCancelled());  
143      }      }
144    
145    
   
146      /**      /**
147       * setting value causes get to return it       * setting value causes get to return it
148       */       */
# Line 89  Line 150 
150          PublicFutureTask task = new PublicFutureTask(new NoOpCallable());          PublicFutureTask task = new PublicFutureTask(new NoOpCallable());
151          task.set(one);          task.set(one);
152          assertSame(task.get(), one);          assertSame(task.get(), one);
153            checkCompletedNormally(task, one);
154      }      }
155    
156      /**      /**
# Line 103  Line 165 
165              shouldThrow();              shouldThrow();
166          } catch (ExecutionException success) {          } catch (ExecutionException success) {
167              assertSame(success.getCause(), nse);              assertSame(success.getCause(), nse);
168                checkCompletedAbnormally(task, nse);
169          }          }
170      }      }
171    
# Line 113  Line 176 
176          FutureTask task = new FutureTask(new NoOpCallable());          FutureTask task = new FutureTask(new NoOpCallable());
177          assertTrue(task.cancel(false));          assertTrue(task.cancel(false));
178          task.run();          task.run();
179          assertTrue(task.isDone());          checkCancelled(task);
         assertTrue(task.isCancelled());  
180      }      }
181    
182      /**      /**
# Line 124  Line 186 
186          FutureTask task = new FutureTask(new NoOpCallable());          FutureTask task = new FutureTask(new NoOpCallable());
187          assertTrue(task.cancel(true));          assertTrue(task.cancel(true));
188          task.run();          task.run();
189          assertTrue(task.isDone());          checkCancelled(task);
         assertTrue(task.isCancelled());  
190      }      }
191    
192      /**      /**
# Line 135  Line 196 
196          FutureTask task = new FutureTask(new NoOpCallable());          FutureTask task = new FutureTask(new NoOpCallable());
197          task.run();          task.run();
198          assertFalse(task.cancel(false));          assertFalse(task.cancel(false));
199          assertTrue(task.isDone());          checkCompletedNormally(task, Boolean.TRUE);
         assertFalse(task.isCancelled());  
200      }      }
201    
202      /**      /**
203       * cancel(true) interrupts a running task       * cancel(true) interrupts a running task
204       */       */
205      public void testCancelInterrupt() throws InterruptedException {      public void testCancelInterrupt() throws InterruptedException {
206            final CountDownLatch threadStarted = new CountDownLatch(1);
207          final FutureTask task =          final FutureTask task =
208              new FutureTask(new CheckedInterruptedCallable<Object>() {              new FutureTask(new CheckedCallable<Object>() {
209                  public Object realCall() throws InterruptedException {                  public Object realCall() {
210                      Thread.sleep(SMALL_DELAY_MS);                      threadStarted.countDown();
211                        long t0 = System.nanoTime();
212                        for (;;) {
213                            if (Thread.interrupted())
214                      return Boolean.TRUE;                      return Boolean.TRUE;
215                            if (millisElapsedSince(t0) > MEDIUM_DELAY_MS)
216                                fail("interrupt not delivered");
217                            Thread.yield();
218                        }
219                  }});                  }});
220    
221          Thread t = new Thread(task);          Thread t = newStartedThread(task);
222          t.start();          threadStarted.await();
         Thread.sleep(SHORT_DELAY_MS);  
223          assertTrue(task.cancel(true));          assertTrue(task.cancel(true));
224          t.join();          checkCancelled(task);
225          assertTrue(task.isDone());          awaitTermination(t, MEDIUM_DELAY_MS);
226          assertTrue(task.isCancelled());          checkCancelled(task);
227      }      }
228    
   
229      /**      /**
230       * cancel(false) does not interrupt a running task       * cancel(false) does not interrupt a running task
231       */       */
232      public void testCancelNoInterrupt() throws InterruptedException {      public void testCancelNoInterrupt() throws InterruptedException {
233          final FutureTask task =          final CountDownLatch threadStarted = new CountDownLatch(1);
234              new FutureTask(new CheckedCallable<Object>() {          final CountDownLatch cancelled = new CountDownLatch(1);
235                  public Object realCall() throws InterruptedException {          final FutureTask<Boolean> task =
236                      Thread.sleep(MEDIUM_DELAY_MS);              new FutureTask<Boolean>(new CheckedCallable<Boolean>() {
237                    public Boolean realCall() throws InterruptedException {
238                        threadStarted.countDown();
239                        cancelled.await(MEDIUM_DELAY_MS, MILLISECONDS);
240                        assertFalse(Thread.interrupted());
241                      return Boolean.TRUE;                      return Boolean.TRUE;
242                  }});                  }});
243    
244          Thread t = new Thread(task);          Thread t = newStartedThread(task);
245          t.start();          threadStarted.await();
         Thread.sleep(SHORT_DELAY_MS);  
246          assertTrue(task.cancel(false));          assertTrue(task.cancel(false));
247          t.join();          checkCancelled(task);
248          assertTrue(task.isDone());          cancelled.countDown();
249          assertTrue(task.isCancelled());          awaitTermination(t, MEDIUM_DELAY_MS);
250            checkCancelled(task);
251      }      }
252    
253      /**      /**
254       * set in one thread causes get in another thread to retrieve value       * set in one thread causes get in another thread to retrieve value
255       */       */
256      public void testGet1() throws InterruptedException {      public void testGet1() throws InterruptedException {
257          final FutureTask ft =          final FutureTask task =
258              new FutureTask(new CheckedCallable<Object>() {              new FutureTask(new CheckedCallable<Object>() {
259                  public Object realCall() throws InterruptedException {                  public Object realCall() throws InterruptedException {
260                      return Boolean.TRUE;                      return Boolean.TRUE;
261                  }});                  }});
262          Thread t = new Thread(new CheckedRunnable() {          checkNotDone(task);
263    
264            Thread t = newStartedThread(new CheckedRunnable() {
265              public void realRun() throws Exception {              public void realRun() throws Exception {
266                  assertSame(Boolean.TRUE, ft.get());                  assertSame(Boolean.TRUE, task.get());
267              }});              }});
268    
269          assertFalse(ft.isDone());          task.run();
270          assertFalse(ft.isCancelled());          checkCompletedNormally(task, Boolean.TRUE);
271          t.start();          awaitTermination(t, MEDIUM_DELAY_MS);
         Thread.sleep(SHORT_DELAY_MS);  
         ft.run();  
         t.join();  
         assertTrue(ft.isDone());  
         assertFalse(ft.isCancelled());  
272      }      }
273    
274      /**      /**
275       * set in one thread causes timed get in another thread to retrieve value       * set in one thread causes timed get in another thread to retrieve value
276       */       */
277      public void testTimedGet1() throws InterruptedException {      public void testTimedGet1() throws InterruptedException {
278          final FutureTask ft =          final FutureTask task =
279              new FutureTask(new CheckedCallable<Object>() {              new FutureTask(new CheckedCallable<Object>() {
280                  public Object realCall() throws InterruptedException {                  public Object realCall() throws InterruptedException {
281                      return Boolean.TRUE;                      return Boolean.TRUE;
282                  }});                  }});
283          Thread t = new Thread(new CheckedRunnable() {          checkNotDone(task);
284    
285            Thread t = newStartedThread(new CheckedRunnable() {
286              public void realRun() throws Exception {              public void realRun() throws Exception {
287                  assertSame(Boolean.TRUE, ft.get(SMALL_DELAY_MS, MILLISECONDS));                  assertSame(Boolean.TRUE, task.get(SMALL_DELAY_MS, MILLISECONDS));
288              }});              }});
289    
290          assertFalse(ft.isDone());          task.run();
291          assertFalse(ft.isCancelled());          checkCompletedNormally(task, Boolean.TRUE);
292          t.start();          awaitTermination(t, MEDIUM_DELAY_MS);
         Thread.sleep(SHORT_DELAY_MS);  
         ft.run();  
         t.join();  
         assertTrue(ft.isDone());  
         assertFalse(ft.isCancelled());  
293      }      }
294    
295      /**      /**
# Line 233  Line 297 
297       * CancellationException       * CancellationException
298       */       */
299      public void testTimedGet_Cancellation() throws InterruptedException {      public void testTimedGet_Cancellation() throws InterruptedException {
300          final FutureTask ft =          final CountDownLatch threadStarted = new CountDownLatch(2);
301            final FutureTask task =
302              new FutureTask(new CheckedInterruptedCallable<Object>() {              new FutureTask(new CheckedInterruptedCallable<Object>() {
303                  public Object realCall() throws InterruptedException {                  public Object realCall() throws InterruptedException {
304                      Thread.sleep(SMALL_DELAY_MS);                      threadStarted.countDown();
305                        Thread.sleep(LONG_DELAY_MS);
306                      return Boolean.TRUE;                      return Boolean.TRUE;
307                  }});                  }});
308    
309          Thread t1 = new ThreadShouldThrow(CancellationException.class) {          Thread t1 = new ThreadShouldThrow(CancellationException.class) {
310              public void realRun() throws Exception {              public void realRun() throws Exception {
311                  ft.get(MEDIUM_DELAY_MS, MILLISECONDS);                  threadStarted.countDown();
312                    task.get(MEDIUM_DELAY_MS, MILLISECONDS);
313              }};              }};
314          Thread t2 = new Thread(ft);          Thread t2 = new Thread(task);
315          t1.start();          t1.start();
316          t2.start();          t2.start();
317          Thread.sleep(SHORT_DELAY_MS);          threadStarted.await();
318          ft.cancel(true);          task.cancel(true);
319          t1.join();          awaitTermination(t1, MEDIUM_DELAY_MS);
320          t2.join();          awaitTermination(t2, MEDIUM_DELAY_MS);
321            checkCancelled(task);
322      }      }
323    
324      /**      /**
# Line 258  Line 326 
326       * CancellationException       * CancellationException
327       */       */
328      public void testGet_Cancellation() throws InterruptedException {      public void testGet_Cancellation() throws InterruptedException {
329          final FutureTask ft =          final CountDownLatch threadStarted = new CountDownLatch(2);
330            final FutureTask task =
331              new FutureTask(new CheckedInterruptedCallable<Object>() {              new FutureTask(new CheckedInterruptedCallable<Object>() {
332                  public Object realCall() throws InterruptedException {                  public Object realCall() throws InterruptedException {
333                      Thread.sleep(SMALL_DELAY_MS);                      threadStarted.countDown();
334                        Thread.sleep(LONG_DELAY_MS);
335                      return Boolean.TRUE;                      return Boolean.TRUE;
336                  }});                  }});
337    
338          Thread t1 = new ThreadShouldThrow(CancellationException.class) {          Thread t1 = new ThreadShouldThrow(CancellationException.class) {
339              public void realRun() throws Exception {              public void realRun() throws Exception {
340                  ft.get();                  threadStarted.countDown();
341                    task.get();
342              }};              }};
343            Thread t2 = new Thread(task);
         Thread t2 = new Thread(ft);  
344          t1.start();          t1.start();
345          t2.start();          t2.start();
346          Thread.sleep(SHORT_DELAY_MS);          threadStarted.await();
347          ft.cancel(true);          task.cancel(true);
348          t1.join();          awaitTermination(t1, MEDIUM_DELAY_MS);
349          t2.join();          awaitTermination(t2, MEDIUM_DELAY_MS);
350            checkCancelled(task);
351      }      }
352    
353    
# Line 283  Line 355 
355       * A runtime exception in task causes get to throw ExecutionException       * A runtime exception in task causes get to throw ExecutionException
356       */       */
357      public void testGet_ExecutionException() throws InterruptedException {      public void testGet_ExecutionException() throws InterruptedException {
358          final FutureTask ft = new FutureTask(new Callable() {          final FutureTask task = new FutureTask(new Callable() {
359              public Object call() {              public Object call() {
360                  return 5/0;                  return 5/0;
361              }});              }});
362    
363          ft.run();          task.run();
364          try {          try {
365              ft.get();              task.get();
366              shouldThrow();              shouldThrow();
367          } catch (ExecutionException success) {          } catch (ExecutionException success) {
368              assertTrue(success.getCause() instanceof ArithmeticException);              assertTrue(success.getCause() instanceof ArithmeticException);
369                checkCompletedAbnormally(task, success.getCause());
370          }          }
371      }      }
372    
# Line 301  Line 374 
374       * A runtime exception in task causes timed get to throw ExecutionException       * A runtime exception in task causes timed get to throw ExecutionException
375       */       */
376      public void testTimedGet_ExecutionException2() throws Exception {      public void testTimedGet_ExecutionException2() throws Exception {
377          final FutureTask ft = new FutureTask(new Callable() {          final FutureTask task = new FutureTask(new Callable() {
378              public Object call() {              public Object call() {
379                  return 5/0;                  return 5/0;
380              }});              }});
381    
382          ft.run();          task.run();
383          try {          try {
384              ft.get(SHORT_DELAY_MS, MILLISECONDS);              task.get(SHORT_DELAY_MS, MILLISECONDS);
385              shouldThrow();              shouldThrow();
386          } catch (ExecutionException success) {          } catch (ExecutionException success) {
387              assertTrue(success.getCause() instanceof ArithmeticException);              assertTrue(success.getCause() instanceof ArithmeticException);
388                checkCompletedAbnormally(task, success.getCause());
389          }          }
390      }      }
391    
# Line 320  Line 394 
394       * Interrupting a waiting get causes it to throw InterruptedException       * Interrupting a waiting get causes it to throw InterruptedException
395       */       */
396      public void testGet_InterruptedException() throws InterruptedException {      public void testGet_InterruptedException() throws InterruptedException {
397          final FutureTask ft = new FutureTask(new NoOpCallable());          final CountDownLatch threadStarted = new CountDownLatch(1);
398          Thread t = new Thread(new CheckedInterruptedRunnable() {          final FutureTask task = new FutureTask(new NoOpCallable());
399            Thread t = newStartedThread(new CheckedInterruptedRunnable() {
400              public void realRun() throws Exception {              public void realRun() throws Exception {
401                  ft.get();                  threadStarted.countDown();
402                    task.get();
403              }});              }});
404    
405          t.start();          threadStarted.await();
         Thread.sleep(SHORT_DELAY_MS);  
406          t.interrupt();          t.interrupt();
407          t.join();          awaitTermination(t, MEDIUM_DELAY_MS);
408            checkNotDone(task);
409      }      }
410    
411      /**      /**
412       * Interrupting a waiting timed get causes it to throw InterruptedException       * Interrupting a waiting timed get causes it to throw InterruptedException
413       */       */
414      public void testTimedGet_InterruptedException2() throws InterruptedException {      public void testTimedGet_InterruptedException2() throws InterruptedException {
415          final FutureTask ft = new FutureTask(new NoOpCallable());          final CountDownLatch threadStarted = new CountDownLatch(1);
416          Thread t = new Thread(new CheckedInterruptedRunnable() {          final FutureTask task = new FutureTask(new NoOpCallable());
417            Thread t = newStartedThread(new CheckedInterruptedRunnable() {
418              public void realRun() throws Exception {              public void realRun() throws Exception {
419                  ft.get(LONG_DELAY_MS,MILLISECONDS);                  threadStarted.countDown();
420                    task.get(LONG_DELAY_MS, MILLISECONDS);
421              }});              }});
422    
423          t.start();          threadStarted.await();
         Thread.sleep(SHORT_DELAY_MS);  
424          t.interrupt();          t.interrupt();
425          t.join();          awaitTermination(t, MEDIUM_DELAY_MS);
426            checkNotDone(task);
427      }      }
428    
429      /**      /**
# Line 353  Line 431 
431       */       */
432      public void testGet_TimeoutException() throws Exception {      public void testGet_TimeoutException() throws Exception {
433          try {          try {
434              FutureTask ft = new FutureTask(new NoOpCallable());              FutureTask task = new FutureTask(new NoOpCallable());
435              ft.get(1,MILLISECONDS);              task.get(1, MILLISECONDS);
436              shouldThrow();              shouldThrow();
437          } catch (TimeoutException success) {}          } catch (TimeoutException success) {}
438      }      }

Legend:
Removed from v.1.21  
changed lines
  Added in v.1.22

Doug Lea
ViewVC Help
Powered by ViewVC 1.0.8