ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/ForkJoinTask8Test.java
(Generate patch)

Comparing jsr166/src/test/tck/ForkJoinTask8Test.java (file contents):
Revision 1.11 by jsr166, Sat Feb 7 19:24:47 2015 UTC vs.
Revision 1.33 by jsr166, Fri Feb 22 19:27:47 2019 UTC

# Line 5 | Line 5
5   */
6  
7   import static java.util.concurrent.TimeUnit.MILLISECONDS;
8 import static java.util.concurrent.TimeUnit.SECONDS;
8  
9 < import java.util.HashSet;
9 > import java.util.Arrays;
10 > import java.util.concurrent.CountDownLatch;
11   import java.util.concurrent.ExecutionException;
12   import java.util.concurrent.ForkJoinPool;
13   import java.util.concurrent.ForkJoinTask;
14 + import java.util.concurrent.ForkJoinWorkerThread;
15   import java.util.concurrent.RecursiveAction;
16   import java.util.concurrent.TimeoutException;
17  
# Line 34 | Line 35 | public class ForkJoinTask8Test extends J
35      static final short EXCEPTION_STATE = 1;
36  
37      public static void main(String[] args) {
38 <        junit.textui.TestRunner.run(suite());
38 >        main(suite(), args);
39      }
40  
41      public static Test suite() {
# Line 59 | Line 60 | public class ForkJoinTask8Test extends J
60                                  null, true);
61      }
62  
63 +    // Compute fib naively and efficiently
64 +    final int[] fib;
65 +    {
66 +        int[] fib = new int[10];
67 +        fib[0] = 0;
68 +        fib[1] = 1;
69 +        for (int i = 2; i < fib.length; i++)
70 +            fib[i] = fib[i - 1] + fib[i - 2];
71 +        this.fib = fib;
72 +    }
73 +
74      private void testInvokeOnPool(ForkJoinPool pool, RecursiveAction a) {
75 <        try {
75 >        try (PoolCleaner cleaner = cleaner(pool)) {
76              assertFalse(a.isDone());
77              assertFalse(a.isCompletedNormally());
78              assertFalse(a.isCompletedAbnormally());
# Line 76 | Line 88 | public class ForkJoinTask8Test extends J
88              assertFalse(a.isCancelled());
89              assertNull(a.getException());
90              assertNull(a.getRawResult());
79        } finally {
80            joinPool(pool);
91          }
92      }
93  
# Line 89 | Line 99 | public class ForkJoinTask8Test extends J
99          assertNull(a.getException());
100          assertNull(a.getRawResult());
101          if (a instanceof BinaryAsyncAction)
102 <            assertTrue(((BinaryAsyncAction)a).getForkJoinTaskTag() == INITIAL_STATE);
102 >            assertEquals(INITIAL_STATE,
103 >                         ((BinaryAsyncAction)a).getForkJoinTaskTag());
104  
105          try {
106 <            a.get(0L, SECONDS);
106 >            a.get(randomExpiredTimeout(), randomTimeUnit());
107              shouldThrow();
108          } catch (TimeoutException success) {
109          } catch (Throwable fail) { threadUnexpectedException(fail); }
# Line 102 | Line 113 | public class ForkJoinTask8Test extends J
113          checkCompletedNormally(a, null);
114      }
115  
116 <    <T> void checkCompletedNormally(ForkJoinTask<T> a, T expected) {
116 >    <T> void checkCompletedNormally(ForkJoinTask<T> a, T expectedValue) {
117          assertTrue(a.isDone());
118          assertFalse(a.isCancelled());
119          assertTrue(a.isCompletedNormally());
120          assertFalse(a.isCompletedAbnormally());
121          assertNull(a.getException());
122 <        assertSame(expected, a.getRawResult());
122 >        assertSame(expectedValue, a.getRawResult());
123          if (a instanceof BinaryAsyncAction)
124 <            assertTrue(((BinaryAsyncAction)a).getForkJoinTaskTag() == COMPLETE_STATE);
124 >            assertEquals(COMPLETE_STATE,
125 >                         ((BinaryAsyncAction)a).getForkJoinTaskTag());
126  
127          {
128              Thread.currentThread().interrupt();
129 <            long t0 = System.nanoTime();
130 <            assertSame(expected, a.join());
131 <            assertTrue(millisElapsedSince(t0) < SMALL_DELAY_MS);
129 >            long startTime = System.nanoTime();
130 >            assertSame(expectedValue, a.join());
131 >            assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS);
132              Thread.interrupted();
133          }
134  
135          {
136              Thread.currentThread().interrupt();
137 <            long t0 = System.nanoTime();
137 >            long startTime = System.nanoTime();
138              a.quietlyJoin();        // should be no-op
139 <            assertTrue(millisElapsedSince(t0) < SMALL_DELAY_MS);
139 >            assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS);
140              Thread.interrupted();
141          }
142  
143          assertFalse(a.cancel(false));
144          assertFalse(a.cancel(true));
145 +
146 +        T v1 = null, v2 = null;
147          try {
148 <            assertSame(expected, a.get());
149 <        } catch (Throwable fail) { threadUnexpectedException(fail); }
136 <        try {
137 <            assertSame(expected, a.get(5L, SECONDS));
148 >            v1 = a.get();
149 >            v2 = a.get(randomTimeout(), randomTimeUnit());
150          } catch (Throwable fail) { threadUnexpectedException(fail); }
151 +        assertSame(expectedValue, v1);
152 +        assertSame(expectedValue, v2);
153      }
154  
155      void checkCompletedAbnormally(ForkJoinTask a, Throwable t) {
# Line 160 | Line 174 | public class ForkJoinTask8Test extends J
174          Thread.interrupted();
175  
176          {
177 <            long t0 = System.nanoTime();
177 >            long startTime = System.nanoTime();
178              a.quietlyJoin();        // should be no-op
179 <            assertTrue(millisElapsedSince(t0) < SMALL_DELAY_MS);
179 >            assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS);
180          }
181  
182          try {
# Line 173 | Line 187 | public class ForkJoinTask8Test extends J
187          } catch (Throwable fail) { threadUnexpectedException(fail); }
188  
189          try {
190 <            a.get(5L, SECONDS);
190 >            a.get(randomTimeout(), randomTimeUnit());
191              shouldThrow();
192          } catch (ExecutionException success) {
193              assertSame(t.getClass(), success.getCause().getClass());
# Line 186 | Line 200 | public class ForkJoinTask8Test extends J
200  
201      abstract static class BinaryAsyncAction extends ForkJoinTask<Void> {
202  
203 <        private BinaryAsyncAction parent;
203 >        private volatile BinaryAsyncAction parent;
204  
205 <        private BinaryAsyncAction sibling;
205 >        private volatile BinaryAsyncAction sibling;
206  
207          protected BinaryAsyncAction() {
208              setForkJoinTaskTag(INITIAL_STATE);
# Line 231 | Line 245 | public class ForkJoinTask8Test extends J
245              super.completeExceptionally(ex);
246          }
247  
248 +        public boolean cancel(boolean mayInterruptIfRunning) {
249 +            if (super.cancel(mayInterruptIfRunning)) {
250 +                completeExceptionally(new FJException());
251 +                return true;
252 +            }
253 +            return false;
254 +        }
255 +
256          public final void complete() {
257              BinaryAsyncAction a = this;
258              for (;;) {
# Line 253 | Line 275 | public class ForkJoinTask8Test extends J
275          }
276  
277          public final void completeExceptionally(Throwable ex) {
278 <            BinaryAsyncAction a = this;
257 <            while (!a.isCompletedAbnormally()) {
278 >            for (BinaryAsyncAction a = this;;) {
279                  a.completeThisExceptionally(ex);
280                  BinaryAsyncAction s = a.sibling;
281 <                if (s != null)
282 <                    s.cancel(false);
283 <                if (!a.onException() || (a = a.parent) == null)
281 >                if (s != null && !s.isDone())
282 >                    s.completeExceptionally(ex);
283 >                if ((a = a.parent) == null)
284                      break;
285              }
286          }
# Line 279 | Line 300 | public class ForkJoinTask8Test extends J
300  
301      }
302  
303 <    static final class AsyncFib extends BinaryAsyncAction {
303 >    final class AsyncFib extends BinaryAsyncAction {
304          int number;
305 <        public AsyncFib(int n) {
306 <            this.number = n;
305 >        int expectedResult;
306 >        public AsyncFib(int number) {
307 >            this.number = number;
308 >            this.expectedResult = fib[number];
309          }
310  
311          public final boolean exec() {
312              try {
313                  AsyncFib f = this;
314                  int n = f.number;
315 <                if (n > 1) {
316 <                    while (n > 1) {
317 <                        AsyncFib p = f;
318 <                        AsyncFib r = new AsyncFib(n - 2);
319 <                        f = new AsyncFib(--n);
320 <                        p.linkSubtasks(r, f);
298 <                        r.fork();
299 <                    }
300 <                    f.number = n;
315 >                while (n > 1) {
316 >                    AsyncFib p = f;
317 >                    AsyncFib r = new AsyncFib(n - 2);
318 >                    f = new AsyncFib(--n);
319 >                    p.linkSubtasks(r, f);
320 >                    r.fork();
321                  }
322                  f.complete();
323              }
324              catch (Throwable ex) {
325                  compareAndSetForkJoinTaskTag(INITIAL_STATE, EXCEPTION_STATE);
326              }
327 +            if (getForkJoinTaskTag() == EXCEPTION_STATE)
328 +                throw new FJException();
329              return false;
330          }
331  
# Line 311 | Line 333 | public class ForkJoinTask8Test extends J
333              number = ((AsyncFib)x).number + ((AsyncFib)y).number;
334              super.onComplete(x, y);
335          }
336 +
337 +        public void checkCompletedNormally() {
338 +            assertEquals(expectedResult, number);
339 +            ForkJoinTask8Test.this.checkCompletedNormally(this);
340 +        }
341      }
342  
343      static final class FailingAsyncFib extends BinaryAsyncAction {
# Line 320 | Line 347 | public class ForkJoinTask8Test extends J
347          }
348  
349          public final boolean exec() {
350 <            FailingAsyncFib f = this;
351 <            int n = f.number;
352 <            if (n > 1) {
350 >            try {
351 >                FailingAsyncFib f = this;
352 >                int n = f.number;
353                  while (n > 1) {
354                      FailingAsyncFib p = f;
355                      FailingAsyncFib r = new FailingAsyncFib(n - 2);
# Line 330 | Line 357 | public class ForkJoinTask8Test extends J
357                      p.linkSubtasks(r, f);
358                      r.fork();
359                  }
360 <                f.number = n;
360 >                f.complete();
361 >            }
362 >            catch (Throwable ex) {
363 >                compareAndSetForkJoinTaskTag(INITIAL_STATE, EXCEPTION_STATE);
364              }
365 <            f.complete();
365 >            if (getForkJoinTaskTag() == EXCEPTION_STATE)
366 >                throw new FJException();
367              return false;
368          }
369  
# Line 347 | Line 378 | public class ForkJoinTask8Test extends J
378       * completed tasks; getRawResult returns null.
379       */
380      public void testInvoke() {
381 +        testInvoke(mainPool());
382 +    }
383 +    public void testInvoke_Singleton() {
384 +        testInvoke(singletonPool());
385 +    }
386 +    public void testInvoke(ForkJoinPool pool) {
387          RecursiveAction a = new CheckedRecursiveAction() {
388              protected void realCompute() {
389                  AsyncFib f = new AsyncFib(8);
390                  assertNull(f.invoke());
391 <                assertEquals(21, f.number);
355 <                checkCompletedNormally(f);
391 >                f.checkCompletedNormally();
392              }};
393 <        testInvokeOnPool(mainPool(), a);
393 >        testInvokeOnPool(pool, a);
394      }
395  
396      /**
# Line 363 | Line 399 | public class ForkJoinTask8Test extends J
399       * completed tasks
400       */
401      public void testQuietlyInvoke() {
402 +        testQuietlyInvoke(mainPool());
403 +    }
404 +    public void testQuietlyInvoke_Singleton() {
405 +        testQuietlyInvoke(singletonPool());
406 +    }
407 +    public void testQuietlyInvoke(ForkJoinPool pool) {
408          RecursiveAction a = new CheckedRecursiveAction() {
409              protected void realCompute() {
410                  AsyncFib f = new AsyncFib(8);
411                  f.quietlyInvoke();
412 <                assertEquals(21, f.number);
371 <                checkCompletedNormally(f);
412 >                f.checkCompletedNormally();
413              }};
414 <        testInvokeOnPool(mainPool(), a);
414 >        testInvokeOnPool(pool, a);
415      }
416  
417      /**
418       * join of a forked task returns when task completes
419       */
420      public void testForkJoin() {
421 +        testForkJoin(mainPool());
422 +    }
423 +    public void testForkJoin_Singleton() {
424 +        testForkJoin(singletonPool());
425 +    }
426 +    public void testForkJoin(ForkJoinPool pool) {
427          RecursiveAction a = new CheckedRecursiveAction() {
428              protected void realCompute() {
429                  AsyncFib f = new AsyncFib(8);
430                  assertSame(f, f.fork());
431                  assertNull(f.join());
432 <                assertEquals(21, f.number);
386 <                checkCompletedNormally(f);
432 >                f.checkCompletedNormally();
433              }};
434 <        testInvokeOnPool(mainPool(), a);
434 >        testInvokeOnPool(pool, a);
435      }
436  
437      /**
438       * get of a forked task returns when task completes
439       */
440      public void testForkGet() {
441 +        testForkGet(mainPool());
442 +    }
443 +    public void testForkGet_Singleton() {
444 +        testForkGet(singletonPool());
445 +    }
446 +    public void testForkGet(ForkJoinPool pool) {
447          RecursiveAction a = new CheckedRecursiveAction() {
448              protected void realCompute() throws Exception {
449                  AsyncFib f = new AsyncFib(8);
450                  assertSame(f, f.fork());
451                  assertNull(f.get());
452 <                assertEquals(21, f.number);
401 <                checkCompletedNormally(f);
452 >                f.checkCompletedNormally();
453              }};
454 <        testInvokeOnPool(mainPool(), a);
454 >        testInvokeOnPool(pool, a);
455      }
456  
457      /**
458       * timed get of a forked task returns when task completes
459       */
460      public void testForkTimedGet() {
461 +        testForkTimedGet(mainPool());
462 +    }
463 +    public void testForkTimedGet_Singleton() {
464 +        testForkTimedGet(singletonPool());
465 +    }
466 +    public void testForkTimedGet(ForkJoinPool pool) {
467          RecursiveAction a = new CheckedRecursiveAction() {
468              protected void realCompute() throws Exception {
469                  AsyncFib f = new AsyncFib(8);
470                  assertSame(f, f.fork());
471                  assertNull(f.get(LONG_DELAY_MS, MILLISECONDS));
472 <                assertEquals(21, f.number);
416 <                checkCompletedNormally(f);
472 >                f.checkCompletedNormally();
473              }};
474 <        testInvokeOnPool(mainPool(), a);
474 >        testInvokeOnPool(pool, a);
475      }
476  
477      /**
478 <     * timed get with null time unit throws NPE
478 >     * timed get with null time unit throws NullPointerException
479       */
480 <    public void testForkTimedGetNPE() {
480 >    public void testForkTimedGetNullTimeUnit() {
481 >        testForkTimedGetNullTimeUnit(mainPool());
482 >    }
483 >    public void testForkTimedGetNullTimeUnit_Singleton() {
484 >        testForkTimedGet(singletonPool());
485 >    }
486 >    public void testForkTimedGetNullTimeUnit(ForkJoinPool pool) {
487          RecursiveAction a = new CheckedRecursiveAction() {
488              protected void realCompute() throws Exception {
489                  AsyncFib f = new AsyncFib(8);
490                  assertSame(f, f.fork());
491                  try {
492 <                    f.get(5L, null);
492 >                    f.get(randomTimeout(), null);
493                      shouldThrow();
494                  } catch (NullPointerException success) {}
495              }};
496 <        testInvokeOnPool(mainPool(), a);
496 >        testInvokeOnPool(pool, a);
497      }
498  
499      /**
500       * quietlyJoin of a forked task returns when task completes
501       */
502      public void testForkQuietlyJoin() {
503 +        testForkQuietlyJoin(mainPool());
504 +    }
505 +    public void testForkQuietlyJoin_Singleton() {
506 +        testForkQuietlyJoin(singletonPool());
507 +    }
508 +    public void testForkQuietlyJoin(ForkJoinPool pool) {
509          RecursiveAction a = new CheckedRecursiveAction() {
510              protected void realCompute() {
511                  AsyncFib f = new AsyncFib(8);
512                  assertSame(f, f.fork());
513                  f.quietlyJoin();
514 <                assertEquals(21, f.number);
447 <                checkCompletedNormally(f);
514 >                f.checkCompletedNormally();
515              }};
516 <        testInvokeOnPool(mainPool(), a);
516 >        testInvokeOnPool(pool, a);
517      }
518  
519      /**
# Line 454 | Line 521 | public class ForkJoinTask8Test extends J
521       * getQueuedTaskCount returns 0 when quiescent
522       */
523      public void testForkHelpQuiesce() {
524 +        testForkHelpQuiesce(mainPool());
525 +    }
526 +    public void testForkHelpQuiesce_Singleton() {
527 +        testForkHelpQuiesce(singletonPool());
528 +    }
529 +    public void testForkHelpQuiesce(ForkJoinPool pool) {
530          RecursiveAction a = new CheckedRecursiveAction() {
531              protected void realCompute() {
532                  AsyncFib f = new AsyncFib(8);
533                  assertSame(f, f.fork());
534                  helpQuiesce();
462                assertEquals(21, f.number);
535                  assertEquals(0, getQueuedTaskCount());
536 <                checkCompletedNormally(f);
536 >                f.checkCompletedNormally();
537              }};
538 <        testInvokeOnPool(mainPool(), a);
538 >        testInvokeOnPool(pool, a);
539      }
540  
541      /**
542       * invoke task throws exception when task completes abnormally
543       */
544      public void testAbnormalInvoke() {
545 +        testAbnormalInvoke(mainPool());
546 +    }
547 +    public void testAbnormalInvoke_Singleton() {
548 +        testAbnormalInvoke(singletonPool());
549 +    }
550 +    public void testAbnormalInvoke(ForkJoinPool pool) {
551          RecursiveAction a = new CheckedRecursiveAction() {
552              protected void realCompute() {
553                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 480 | Line 558 | public class ForkJoinTask8Test extends J
558                      checkCompletedAbnormally(f, success);
559                  }
560              }};
561 <        testInvokeOnPool(mainPool(), a);
561 >        testInvokeOnPool(pool, a);
562      }
563  
564      /**
565       * quietlyInvoke task returns when task completes abnormally
566       */
567      public void testAbnormalQuietlyInvoke() {
568 +        testAbnormalQuietlyInvoke(mainPool());
569 +    }
570 +    public void testAbnormalQuietlyInvoke_Singleton() {
571 +        testAbnormalQuietlyInvoke(singletonPool());
572 +    }
573 +    public void testAbnormalQuietlyInvoke(ForkJoinPool pool) {
574          RecursiveAction a = new CheckedRecursiveAction() {
575              protected void realCompute() {
576                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 494 | Line 578 | public class ForkJoinTask8Test extends J
578                  assertTrue(f.getException() instanceof FJException);
579                  checkCompletedAbnormally(f, f.getException());
580              }};
581 <        testInvokeOnPool(mainPool(), a);
581 >        testInvokeOnPool(pool, a);
582      }
583  
584      /**
585       * join of a forked task throws exception when task completes abnormally
586       */
587      public void testAbnormalForkJoin() {
588 +        testAbnormalForkJoin(mainPool());
589 +    }
590 +    public void testAbnormalForkJoin_Singleton() {
591 +        testAbnormalForkJoin(singletonPool());
592 +    }
593 +    public void testAbnormalForkJoin(ForkJoinPool pool) {
594          RecursiveAction a = new CheckedRecursiveAction() {
595              protected void realCompute() {
596                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 512 | Line 602 | public class ForkJoinTask8Test extends J
602                      checkCompletedAbnormally(f, success);
603                  }
604              }};
605 <        testInvokeOnPool(mainPool(), a);
605 >        testInvokeOnPool(pool, a);
606      }
607  
608      /**
609       * get of a forked task throws exception when task completes abnormally
610       */
611      public void testAbnormalForkGet() {
612 +        testAbnormalForkGet(mainPool());
613 +    }
614 +    public void testAbnormalForkGet_Singleton() {
615 +        testAbnormalForkJoin(singletonPool());
616 +    }
617 +    public void testAbnormalForkGet(ForkJoinPool pool) {
618          RecursiveAction a = new CheckedRecursiveAction() {
619              protected void realCompute() throws Exception {
620                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 532 | Line 628 | public class ForkJoinTask8Test extends J
628                      checkCompletedAbnormally(f, cause);
629                  }
630              }};
631 <        testInvokeOnPool(mainPool(), a);
631 >        testInvokeOnPool(pool, a);
632      }
633  
634      /**
635       * timed get of a forked task throws exception when task completes abnormally
636       */
637      public void testAbnormalForkTimedGet() {
638 +        testAbnormalForkTimedGet(mainPool());
639 +    }
640 +    public void testAbnormalForkTimedGet_Singleton() {
641 +        testAbnormalForkTimedGet(singletonPool());
642 +    }
643 +    public void testAbnormalForkTimedGet(ForkJoinPool pool) {
644          RecursiveAction a = new CheckedRecursiveAction() {
645              protected void realCompute() throws Exception {
646                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 552 | Line 654 | public class ForkJoinTask8Test extends J
654                      checkCompletedAbnormally(f, cause);
655                  }
656              }};
657 <        testInvokeOnPool(mainPool(), a);
657 >        testInvokeOnPool(pool, a);
658      }
659  
660      /**
661       * quietlyJoin of a forked task returns when task completes abnormally
662       */
663      public void testAbnormalForkQuietlyJoin() {
664 +        testAbnormalForkQuietlyJoin(mainPool());
665 +    }
666 +    public void testAbnormalForkQuietlyJoin_Singleton() {
667 +        testAbnormalForkQuietlyJoin(singletonPool());
668 +    }
669 +    public void testAbnormalForkQuietlyJoin(ForkJoinPool pool) {
670          RecursiveAction a = new CheckedRecursiveAction() {
671              protected void realCompute() {
672                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 567 | Line 675 | public class ForkJoinTask8Test extends J
675                  assertTrue(f.getException() instanceof FJException);
676                  checkCompletedAbnormally(f, f.getException());
677              }};
678 <        testInvokeOnPool(mainPool(), a);
678 >        testInvokeOnPool(pool, a);
679      }
680  
681      /**
682       * getPool of executing task returns its pool
683       */
684      public void testGetPool() {
685 <        final ForkJoinPool mainPool = mainPool();
685 >        testGetPool(mainPool());
686 >    }
687 >    public void testGetPool_Singleton() {
688 >        testGetPool(singletonPool());
689 >    }
690 >    public void testGetPool(ForkJoinPool pool) {
691          RecursiveAction a = new CheckedRecursiveAction() {
692              protected void realCompute() {
693 <                assertSame(mainPool, getPool());
693 >                assertSame(pool, getPool());
694              }};
695 <        testInvokeOnPool(mainPool, a);
695 >        testInvokeOnPool(pool, a);
696      }
697  
698      /**
# Line 597 | Line 710 | public class ForkJoinTask8Test extends J
710       * inForkJoinPool of executing task returns true
711       */
712      public void testInForkJoinPool() {
713 +        testInForkJoinPool(mainPool());
714 +    }
715 +    public void testInForkJoinPool_Singleton() {
716 +        testInForkJoinPool(singletonPool());
717 +    }
718 +    public void testInForkJoinPool(ForkJoinPool pool) {
719          RecursiveAction a = new CheckedRecursiveAction() {
720              protected void realCompute() {
721                  assertTrue(inForkJoinPool());
722              }};
723 <        testInvokeOnPool(mainPool(), a);
723 >        testInvokeOnPool(pool, a);
724      }
725  
726      /**
# Line 631 | Line 750 | public class ForkJoinTask8Test extends J
750       * invoke task throws exception after invoking completeExceptionally
751       */
752      public void testCompleteExceptionally() {
753 +        testCompleteExceptionally(mainPool());
754 +    }
755 +    public void testCompleteExceptionally_Singleton() {
756 +        testCompleteExceptionally(singletonPool());
757 +    }
758 +    public void testCompleteExceptionally(ForkJoinPool pool) {
759          RecursiveAction a = new CheckedRecursiveAction() {
760              protected void realCompute() {
761                  AsyncFib f = new AsyncFib(8);
# Line 642 | Line 767 | public class ForkJoinTask8Test extends J
767                      checkCompletedAbnormally(f, success);
768                  }
769              }};
770 <        testInvokeOnPool(mainPool(), a);
770 >        testInvokeOnPool(pool, a);
771      }
772  
773      /**
774 <     * invokeAll(t1, t2) invokes all task arguments
774 >     * invokeAll(tasks) with 1 argument invokes task
775       */
776 <    public void testInvokeAll2() {
776 >    public void testInvokeAll1() {
777 >        testInvokeAll1(mainPool());
778 >    }
779 >    public void testInvokeAll1_Singleton() {
780 >        testInvokeAll1(singletonPool());
781 >    }
782 >    public void testInvokeAll1(ForkJoinPool pool) {
783          RecursiveAction a = new CheckedRecursiveAction() {
784              protected void realCompute() {
785                  AsyncFib f = new AsyncFib(8);
786 <                AsyncFib g = new AsyncFib(9);
787 <                invokeAll(f, g);
657 <                assertEquals(21, f.number);
658 <                assertEquals(34, g.number);
659 <                checkCompletedNormally(f);
660 <                checkCompletedNormally(g);
786 >                invokeAll(f);
787 >                f.checkCompletedNormally();
788              }};
789 <        testInvokeOnPool(mainPool(), a);
789 >        testInvokeOnPool(pool, a);
790      }
791  
792      /**
793 <     * invokeAll(tasks) with 1 argument invokes task
793 >     * invokeAll(t1, t2) invokes all task arguments
794       */
795 <    public void testInvokeAll1() {
795 >    public void testInvokeAll2() {
796 >        testInvokeAll2(mainPool());
797 >    }
798 >    public void testInvokeAll2_Singleton() {
799 >        testInvokeAll2(singletonPool());
800 >    }
801 >    public void testInvokeAll2(ForkJoinPool pool) {
802          RecursiveAction a = new CheckedRecursiveAction() {
803              protected void realCompute() {
804 <                AsyncFib f = new AsyncFib(8);
805 <                invokeAll(f);
806 <                checkCompletedNormally(f);
807 <                assertEquals(21, f.number);
804 >                AsyncFib[] tasks = {
805 >                    new AsyncFib(8),
806 >                    new AsyncFib(9),
807 >                };
808 >                invokeAll(tasks[0], tasks[1]);
809 >                for (AsyncFib task : tasks) assertTrue(task.isDone());
810 >                for (AsyncFib task : tasks) task.checkCompletedNormally();
811              }};
812 <        testInvokeOnPool(mainPool(), a);
812 >        testInvokeOnPool(pool, a);
813      }
814  
815      /**
816       * invokeAll(tasks) with > 2 argument invokes tasks
817       */
818      public void testInvokeAll3() {
819 +        testInvokeAll3(mainPool());
820 +    }
821 +    public void testInvokeAll3_Singleton() {
822 +        testInvokeAll3(singletonPool());
823 +    }
824 +    public void testInvokeAll3(ForkJoinPool pool) {
825          RecursiveAction a = new CheckedRecursiveAction() {
826              protected void realCompute() {
827 <                AsyncFib f = new AsyncFib(8);
828 <                AsyncFib g = new AsyncFib(9);
829 <                AsyncFib h = new AsyncFib(7);
830 <                invokeAll(f, g, h);
831 <                assertEquals(21, f.number);
832 <                assertEquals(34, g.number);
833 <                assertEquals(13, h.number);
834 <                checkCompletedNormally(f);
693 <                checkCompletedNormally(g);
694 <                checkCompletedNormally(h);
827 >                AsyncFib[] tasks = {
828 >                    new AsyncFib(8),
829 >                    new AsyncFib(9),
830 >                    new AsyncFib(7),
831 >                };
832 >                invokeAll(tasks[0], tasks[1], tasks[2]);
833 >                for (AsyncFib task : tasks) assertTrue(task.isDone());
834 >                for (AsyncFib task : tasks) task.checkCompletedNormally();
835              }};
836 <        testInvokeOnPool(mainPool(), a);
836 >        testInvokeOnPool(pool, a);
837      }
838  
839      /**
840       * invokeAll(collection) invokes all tasks in the collection
841       */
842      public void testInvokeAllCollection() {
843 +        testInvokeAllCollection(mainPool());
844 +    }
845 +    public void testInvokeAllCollection_Singleton() {
846 +        testInvokeAllCollection(singletonPool());
847 +    }
848 +    public void testInvokeAllCollection(ForkJoinPool pool) {
849          RecursiveAction a = new CheckedRecursiveAction() {
850              protected void realCompute() {
851 <                AsyncFib f = new AsyncFib(8);
852 <                AsyncFib g = new AsyncFib(9);
853 <                AsyncFib h = new AsyncFib(7);
854 <                HashSet set = new HashSet();
855 <                set.add(f);
856 <                set.add(g);
857 <                set.add(h);
858 <                invokeAll(set);
713 <                assertEquals(21, f.number);
714 <                assertEquals(34, g.number);
715 <                assertEquals(13, h.number);
716 <                checkCompletedNormally(f);
717 <                checkCompletedNormally(g);
718 <                checkCompletedNormally(h);
851 >                AsyncFib[] tasks = {
852 >                    new AsyncFib(8),
853 >                    new AsyncFib(9),
854 >                    new AsyncFib(7),
855 >                };
856 >                invokeAll(Arrays.asList(tasks));
857 >                for (AsyncFib task : tasks) assertTrue(task.isDone());
858 >                for (AsyncFib task : tasks) task.checkCompletedNormally();
859              }};
860 <        testInvokeOnPool(mainPool(), a);
860 >        testInvokeOnPool(pool, a);
861      }
862  
863      /**
864       * invokeAll(tasks) with any null task throws NullPointerException
865       */
866      public void testInvokeAllNullTask() {
867 +        testInvokeAllNullTask(mainPool());
868 +    }
869 +    public void testInvokeAllNullTask_Singleton() {
870 +        testInvokeAllNullTask(singletonPool());
871 +    }
872 +    public void testInvokeAllNullTask(ForkJoinPool pool) {
873          RecursiveAction a = new CheckedRecursiveAction() {
874              protected void realCompute() {
729                AsyncFib f = new AsyncFib(8);
730                AsyncFib g = new AsyncFib(9);
875                  AsyncFib nul = null;
876 <                Runnable[] throwingActions = {
876 >                assertThrows(
877 >                    NullPointerException.class,
878                      () -> invokeAll(nul),
879                      () -> invokeAll(nul, nul),
880 <                    () -> invokeAll(f, g, nul),
881 <                    () -> invokeAll(f, nul, g),
882 <                    () -> invokeAll(nul, f, g),
738 <                };
739 <                assertThrows(NullPointerException.class, throwingActions);
880 >                    () -> invokeAll(new AsyncFib(8), new AsyncFib(9), nul),
881 >                    () -> invokeAll(new AsyncFib(8), nul, new AsyncFib(9)),
882 >                    () -> invokeAll(nul, new AsyncFib(8), new AsyncFib(9)));
883              }};
884 <        testInvokeOnPool(mainPool(), a);
884 >        testInvokeOnPool(pool, a);
885      }
886  
887      /**
888 <     * invokeAll(t1, t2) throw exception if any task does
888 >     * invokeAll(tasks) with 1 argument throws exception if task does
889       */
890 <    public void testAbnormalInvokeAll2() {
890 >    public void testAbnormalInvokeAll1() {
891 >        testAbnormalInvokeAll1(mainPool());
892 >    }
893 >    public void testAbnormalInvokeAll1_Singleton() {
894 >        testAbnormalInvokeAll1(singletonPool());
895 >    }
896 >    public void testAbnormalInvokeAll1(ForkJoinPool pool) {
897          RecursiveAction a = new CheckedRecursiveAction() {
898              protected void realCompute() {
750                AsyncFib f = new AsyncFib(8);
899                  FailingAsyncFib g = new FailingAsyncFib(9);
900                  try {
901 <                    invokeAll(f, g);
901 >                    invokeAll(g);
902                      shouldThrow();
903                  } catch (FJException success) {
904                      checkCompletedAbnormally(g, success);
905                  }
906              }};
907 <        testInvokeOnPool(mainPool(), a);
907 >        testInvokeOnPool(pool, a);
908      }
909  
910      /**
911 <     * invokeAll(tasks) with 1 argument throws exception if task does
911 >     * invokeAll(t1, t2) throw exception if any task does
912       */
913 <    public void testAbnormalInvokeAll1() {
913 >    public void testAbnormalInvokeAll2() {
914 >        testAbnormalInvokeAll2(mainPool());
915 >    }
916 >    public void testAbnormalInvokeAll2_Singleton() {
917 >        testAbnormalInvokeAll2(singletonPool());
918 >    }
919 >    public void testAbnormalInvokeAll2(ForkJoinPool pool) {
920          RecursiveAction a = new CheckedRecursiveAction() {
921              protected void realCompute() {
922 +                AsyncFib f = new AsyncFib(8);
923                  FailingAsyncFib g = new FailingAsyncFib(9);
924 +                ForkJoinTask[] tasks = { f, g };
925 +                shuffle(tasks);
926                  try {
927 <                    invokeAll(g);
927 >                    invokeAll(tasks[0], tasks[1]);
928                      shouldThrow();
929                  } catch (FJException success) {
930                      checkCompletedAbnormally(g, success);
931                  }
932              }};
933 <        testInvokeOnPool(mainPool(), a);
933 >        testInvokeOnPool(pool, a);
934      }
935  
936      /**
937       * invokeAll(tasks) with > 2 argument throws exception if any task does
938       */
939      public void testAbnormalInvokeAll3() {
940 +        testAbnormalInvokeAll3(mainPool());
941 +    }
942 +    public void testAbnormalInvokeAll3_Singleton() {
943 +        testAbnormalInvokeAll3(singletonPool());
944 +    }
945 +    public void testAbnormalInvokeAll3(ForkJoinPool pool) {
946          RecursiveAction a = new CheckedRecursiveAction() {
947              protected void realCompute() {
948                  AsyncFib f = new AsyncFib(8);
949                  FailingAsyncFib g = new FailingAsyncFib(9);
950                  AsyncFib h = new AsyncFib(7);
951 +                ForkJoinTask[] tasks = { f, g, h };
952 +                shuffle(tasks);
953                  try {
954 <                    invokeAll(f, g, h);
954 >                    invokeAll(tasks[0], tasks[1], tasks[2]);
955                      shouldThrow();
956                  } catch (FJException success) {
957                      checkCompletedAbnormally(g, success);
958                  }
959              }};
960 <        testInvokeOnPool(mainPool(), a);
960 >        testInvokeOnPool(pool, a);
961      }
962  
963      /**
964       * invokeAll(collection) throws exception if any task does
965       */
966      public void testAbnormalInvokeAllCollection() {
967 +        testAbnormalInvokeAllCollection(mainPool());
968 +    }
969 +    public void testAbnormalInvokeAllCollection_Singleton() {
970 +        testAbnormalInvokeAllCollection(singletonPool());
971 +    }
972 +    public void testAbnormalInvokeAllCollection(ForkJoinPool pool) {
973          RecursiveAction a = new CheckedRecursiveAction() {
974              protected void realCompute() {
975                  FailingAsyncFib f = new FailingAsyncFib(8);
976                  AsyncFib g = new AsyncFib(9);
977                  AsyncFib h = new AsyncFib(7);
978 <                HashSet set = new HashSet();
979 <                set.add(f);
809 <                set.add(g);
810 <                set.add(h);
978 >                ForkJoinTask[] tasks = { f, g, h };
979 >                shuffle(tasks);
980                  try {
981 <                    invokeAll(set);
981 >                    invokeAll(Arrays.asList(tasks));
982                      shouldThrow();
983                  } catch (FJException success) {
984                      checkCompletedAbnormally(f, success);
985                  }
986              }};
987 <        testInvokeOnPool(mainPool(), a);
987 >        testInvokeOnPool(pool, a);
988      }
989  
990      /**
# Line 832 | Line 1001 | public class ForkJoinTask8Test extends J
1001                  assertTrue(f.tryUnfork());
1002                  helpQuiesce();
1003                  checkNotDone(f);
1004 <                checkCompletedNormally(g);
1004 >                g.checkCompletedNormally();
1005              }};
1006          testInvokeOnPool(singletonPool(), a);
1007      }
# Line 853 | Line 1022 | public class ForkJoinTask8Test extends J
1022                  assertTrue(getSurplusQueuedTaskCount() > 0);
1023                  helpQuiesce();
1024                  assertEquals(0, getSurplusQueuedTaskCount());
1025 <                checkCompletedNormally(f);
1026 <                checkCompletedNormally(g);
1027 <                checkCompletedNormally(h);
1025 >                f.checkCompletedNormally();
1026 >                g.checkCompletedNormally();
1027 >                h.checkCompletedNormally();
1028              }};
1029          testInvokeOnPool(singletonPool(), a);
1030      }
# Line 872 | Line 1041 | public class ForkJoinTask8Test extends J
1041                  assertSame(f, f.fork());
1042                  assertSame(f, peekNextLocalTask());
1043                  assertNull(f.join());
1044 <                checkCompletedNormally(f);
1044 >                f.checkCompletedNormally();
1045                  helpQuiesce();
1046 <                checkCompletedNormally(g);
1046 >                g.checkCompletedNormally();
1047              }};
1048          testInvokeOnPool(singletonPool(), a);
1049      }
# Line 893 | Line 1062 | public class ForkJoinTask8Test extends J
1062                  assertSame(f, pollNextLocalTask());
1063                  helpQuiesce();
1064                  checkNotDone(f);
1065 <                assertEquals(34, g.number);
897 <                checkCompletedNormally(g);
1065 >                g.checkCompletedNormally();
1066              }};
1067          testInvokeOnPool(singletonPool(), a);
1068      }
# Line 912 | Line 1080 | public class ForkJoinTask8Test extends J
1080                  assertSame(f, pollTask());
1081                  helpQuiesce();
1082                  checkNotDone(f);
1083 <                checkCompletedNormally(g);
1083 >                g.checkCompletedNormally();
1084              }};
1085          testInvokeOnPool(singletonPool(), a);
1086      }
# Line 930 | Line 1098 | public class ForkJoinTask8Test extends J
1098                  assertSame(g, peekNextLocalTask());
1099                  assertNull(f.join());
1100                  helpQuiesce();
1101 <                checkCompletedNormally(f);
1102 <                assertEquals(34, g.number);
935 <                checkCompletedNormally(g);
1101 >                f.checkCompletedNormally();
1102 >                g.checkCompletedNormally();
1103              }};
1104          testInvokeOnPool(asyncSingletonPool(), a);
1105      }
# Line 950 | Line 1117 | public class ForkJoinTask8Test extends J
1117                  assertSame(f, f.fork());
1118                  assertSame(g, pollNextLocalTask());
1119                  helpQuiesce();
1120 <                assertEquals(21, f.number);
954 <                checkCompletedNormally(f);
1120 >                f.checkCompletedNormally();
1121                  checkNotDone(g);
1122              }};
1123          testInvokeOnPool(asyncSingletonPool(), a);
# Line 970 | Line 1136 | public class ForkJoinTask8Test extends J
1136                  assertSame(f, f.fork());
1137                  assertSame(g, pollTask());
1138                  helpQuiesce();
1139 <                assertEquals(21, f.number);
974 <                checkCompletedNormally(f);
1139 >                f.checkCompletedNormally();
1140                  checkNotDone(g);
1141              }};
1142          testInvokeOnPool(asyncSingletonPool(), a);
1143      }
1144  
980    // versions for singleton pools
981
982    /**
983     * invoke returns when task completes normally.
984     * isCompletedAbnormally and isCancelled return false for normally
985     * completed tasks; getRawResult returns null.
986     */
987    public void testInvokeSingleton() {
988        RecursiveAction a = new CheckedRecursiveAction() {
989            protected void realCompute() {
990                AsyncFib f = new AsyncFib(8);
991                assertNull(f.invoke());
992                assertEquals(21, f.number);
993                checkCompletedNormally(f);
994            }};
995        testInvokeOnPool(singletonPool(), a);
996    }
997
998    /**
999     * quietlyInvoke task returns when task completes normally.
1000     * isCompletedAbnormally and isCancelled return false for normally
1001     * completed tasks
1002     */
1003    public void testQuietlyInvokeSingleton() {
1004        RecursiveAction a = new CheckedRecursiveAction() {
1005            protected void realCompute() {
1006                AsyncFib f = new AsyncFib(8);
1007                f.quietlyInvoke();
1008                assertEquals(21, f.number);
1009                checkCompletedNormally(f);
1010            }};
1011        testInvokeOnPool(singletonPool(), a);
1012    }
1013
1014    /**
1015     * join of a forked task returns when task completes
1016     */
1017    public void testForkJoinSingleton() {
1018        RecursiveAction a = new CheckedRecursiveAction() {
1019            protected void realCompute() {
1020                AsyncFib f = new AsyncFib(8);
1021                assertSame(f, f.fork());
1022                assertNull(f.join());
1023                assertEquals(21, f.number);
1024                checkCompletedNormally(f);
1025            }};
1026        testInvokeOnPool(singletonPool(), a);
1027    }
1028
1029    /**
1030     * get of a forked task returns when task completes
1031     */
1032    public void testForkGetSingleton() {
1033        RecursiveAction a = new CheckedRecursiveAction() {
1034            protected void realCompute() throws Exception {
1035                AsyncFib f = new AsyncFib(8);
1036                assertSame(f, f.fork());
1037                assertNull(f.get());
1038                assertEquals(21, f.number);
1039                checkCompletedNormally(f);
1040            }};
1041        testInvokeOnPool(singletonPool(), a);
1042    }
1043
1044    /**
1045     * timed get of a forked task returns when task completes
1046     */
1047    public void testForkTimedGetSingleton() {
1048        RecursiveAction a = new CheckedRecursiveAction() {
1049            protected void realCompute() throws Exception {
1050                AsyncFib f = new AsyncFib(8);
1051                assertSame(f, f.fork());
1052                assertNull(f.get(LONG_DELAY_MS, MILLISECONDS));
1053                assertEquals(21, f.number);
1054                checkCompletedNormally(f);
1055            }};
1056        testInvokeOnPool(singletonPool(), a);
1057    }
1058
1059    /**
1060     * timed get with null time unit throws NPE
1061     */
1062    public void testForkTimedGetNPESingleton() {
1063        RecursiveAction a = new CheckedRecursiveAction() {
1064            protected void realCompute() throws Exception {
1065                AsyncFib f = new AsyncFib(8);
1066                assertSame(f, f.fork());
1067                try {
1068                    f.get(5L, null);
1069                    shouldThrow();
1070                } catch (NullPointerException success) {}
1071            }};
1072        testInvokeOnPool(singletonPool(), a);
1073    }
1074
1075    /**
1076     * quietlyJoin of a forked task returns when task completes
1077     */
1078    public void testForkQuietlyJoinSingleton() {
1079        RecursiveAction a = new CheckedRecursiveAction() {
1080            protected void realCompute() {
1081                AsyncFib f = new AsyncFib(8);
1082                assertSame(f, f.fork());
1083                f.quietlyJoin();
1084                assertEquals(21, f.number);
1085                checkCompletedNormally(f);
1086            }};
1087        testInvokeOnPool(singletonPool(), a);
1088    }
1089
1090    /**
1091     * helpQuiesce returns when tasks are complete.
1092     * getQueuedTaskCount returns 0 when quiescent
1093     */
1094    public void testForkHelpQuiesceSingleton() {
1095        RecursiveAction a = new CheckedRecursiveAction() {
1096            protected void realCompute() {
1097                AsyncFib f = new AsyncFib(8);
1098                assertSame(f, f.fork());
1099                helpQuiesce();
1100                assertEquals(0, getQueuedTaskCount());
1101                assertEquals(21, f.number);
1102                checkCompletedNormally(f);
1103            }};
1104        testInvokeOnPool(singletonPool(), a);
1105    }
1106
1107    /**
1108     * invoke task throws exception when task completes abnormally
1109     */
1110    public void testAbnormalInvokeSingleton() {
1111        RecursiveAction a = new CheckedRecursiveAction() {
1112            protected void realCompute() {
1113                FailingAsyncFib f = new FailingAsyncFib(8);
1114                try {
1115                    f.invoke();
1116                    shouldThrow();
1117                } catch (FJException success) {
1118                    checkCompletedAbnormally(f, success);
1119                }
1120            }};
1121        testInvokeOnPool(singletonPool(), a);
1122    }
1123
1124    /**
1125     * quietlyInvoke task returns when task completes abnormally
1126     */
1127    public void testAbnormalQuietlyInvokeSingleton() {
1128        RecursiveAction a = new CheckedRecursiveAction() {
1129            protected void realCompute() {
1130                FailingAsyncFib f = new FailingAsyncFib(8);
1131                f.quietlyInvoke();
1132                assertTrue(f.getException() instanceof FJException);
1133                checkCompletedAbnormally(f, f.getException());
1134            }};
1135        testInvokeOnPool(singletonPool(), a);
1136    }
1137
1138    /**
1139     * join of a forked task throws exception when task completes abnormally
1140     */
1141    public void testAbnormalForkJoinSingleton() {
1142        RecursiveAction a = new CheckedRecursiveAction() {
1143            protected void realCompute() {
1144                FailingAsyncFib f = new FailingAsyncFib(8);
1145                assertSame(f, f.fork());
1146                try {
1147                    f.join();
1148                    shouldThrow();
1149                } catch (FJException success) {
1150                    checkCompletedAbnormally(f, success);
1151                }
1152            }};
1153        testInvokeOnPool(singletonPool(), a);
1154    }
1155
1156    /**
1157     * get of a forked task throws exception when task completes abnormally
1158     */
1159    public void testAbnormalForkGetSingleton() {
1160        RecursiveAction a = new CheckedRecursiveAction() {
1161            protected void realCompute() throws Exception {
1162                FailingAsyncFib f = new FailingAsyncFib(8);
1163                assertSame(f, f.fork());
1164                try {
1165                    f.get();
1166                    shouldThrow();
1167                } catch (ExecutionException success) {
1168                    Throwable cause = success.getCause();
1169                    assertTrue(cause instanceof FJException);
1170                    checkCompletedAbnormally(f, cause);
1171                }
1172            }};
1173        testInvokeOnPool(singletonPool(), a);
1174    }
1175
1176    /**
1177     * timed get of a forked task throws exception when task completes abnormally
1178     */
1179    public void testAbnormalForkTimedGetSingleton() {
1180        RecursiveAction a = new CheckedRecursiveAction() {
1181            protected void realCompute() throws Exception {
1182                FailingAsyncFib f = new FailingAsyncFib(8);
1183                assertSame(f, f.fork());
1184                try {
1185                    f.get(LONG_DELAY_MS, MILLISECONDS);
1186                    shouldThrow();
1187                } catch (ExecutionException success) {
1188                    Throwable cause = success.getCause();
1189                    assertTrue(cause instanceof FJException);
1190                    checkCompletedAbnormally(f, cause);
1191                }
1192            }};
1193        testInvokeOnPool(singletonPool(), a);
1194    }
1195
1196    /**
1197     * quietlyJoin of a forked task returns when task completes abnormally
1198     */
1199    public void testAbnormalForkQuietlyJoinSingleton() {
1200        RecursiveAction a = new CheckedRecursiveAction() {
1201            protected void realCompute() {
1202                FailingAsyncFib f = new FailingAsyncFib(8);
1203                assertSame(f, f.fork());
1204                f.quietlyJoin();
1205                assertTrue(f.getException() instanceof FJException);
1206                checkCompletedAbnormally(f, f.getException());
1207            }};
1208        testInvokeOnPool(singletonPool(), a);
1209    }
1210
1211    /**
1212     * invoke task throws exception after invoking completeExceptionally
1213     */
1214    public void testCompleteExceptionallySingleton() {
1215        RecursiveAction a = new CheckedRecursiveAction() {
1216            protected void realCompute() {
1217                AsyncFib f = new AsyncFib(8);
1218                f.completeExceptionally(new FJException());
1219                try {
1220                    f.invoke();
1221                    shouldThrow();
1222                } catch (FJException success) {
1223                    checkCompletedAbnormally(f, success);
1224                }
1225            }};
1226        testInvokeOnPool(singletonPool(), a);
1227    }
1228
1229    /**
1230     * invokeAll(t1, t2) invokes all task arguments
1231     */
1232    public void testInvokeAll2Singleton() {
1233        RecursiveAction a = new CheckedRecursiveAction() {
1234            protected void realCompute() {
1235                AsyncFib f = new AsyncFib(8);
1236                AsyncFib g = new AsyncFib(9);
1237                invokeAll(f, g);
1238                assertEquals(21, f.number);
1239                assertEquals(34, g.number);
1240                checkCompletedNormally(f);
1241                checkCompletedNormally(g);
1242            }};
1243        testInvokeOnPool(singletonPool(), a);
1244    }
1245
1246    /**
1247     * invokeAll(tasks) with 1 argument invokes task
1248     */
1249    public void testInvokeAll1Singleton() {
1250        RecursiveAction a = new CheckedRecursiveAction() {
1251            protected void realCompute() {
1252                AsyncFib f = new AsyncFib(8);
1253                invokeAll(f);
1254                checkCompletedNormally(f);
1255                assertEquals(21, f.number);
1256            }};
1257        testInvokeOnPool(singletonPool(), a);
1258    }
1259
1260    /**
1261     * invokeAll(tasks) with > 2 argument invokes tasks
1262     */
1263    public void testInvokeAll3Singleton() {
1264        RecursiveAction a = new CheckedRecursiveAction() {
1265            protected void realCompute() {
1266                AsyncFib f = new AsyncFib(8);
1267                AsyncFib g = new AsyncFib(9);
1268                AsyncFib h = new AsyncFib(7);
1269                invokeAll(f, g, h);
1270                assertEquals(21, f.number);
1271                assertEquals(34, g.number);
1272                assertEquals(13, h.number);
1273                checkCompletedNormally(f);
1274                checkCompletedNormally(g);
1275                checkCompletedNormally(h);
1276            }};
1277        testInvokeOnPool(singletonPool(), a);
1278    }
1279
1280    /**
1281     * invokeAll(collection) invokes all tasks in the collection
1282     */
1283    public void testInvokeAllCollectionSingleton() {
1284        RecursiveAction a = new CheckedRecursiveAction() {
1285            protected void realCompute() {
1286                AsyncFib f = new AsyncFib(8);
1287                AsyncFib g = new AsyncFib(9);
1288                AsyncFib h = new AsyncFib(7);
1289                HashSet set = new HashSet();
1290                set.add(f);
1291                set.add(g);
1292                set.add(h);
1293                invokeAll(set);
1294                assertEquals(21, f.number);
1295                assertEquals(34, g.number);
1296                assertEquals(13, h.number);
1297                checkCompletedNormally(f);
1298                checkCompletedNormally(g);
1299                checkCompletedNormally(h);
1300            }};
1301        testInvokeOnPool(singletonPool(), a);
1302    }
1303
1304    /**
1305     * invokeAll(tasks) with any null task throws NullPointerException
1306     */
1307    public void testInvokeAllNullTaskSingleton() {
1308        RecursiveAction a = new CheckedRecursiveAction() {
1309            protected void realCompute() {
1310                AsyncFib f = new AsyncFib(8);
1311                AsyncFib g = new AsyncFib(9);
1312                AsyncFib nul = null;
1313                Runnable[] throwingActions = {
1314                    () -> invokeAll(nul),
1315                    () -> invokeAll(nul, nul),
1316                    () -> invokeAll(f, g, nul),
1317                    () -> invokeAll(f, nul, g),
1318                    () -> invokeAll(nul, f, g),
1319                };
1320                assertThrows(NullPointerException.class, throwingActions);
1321            }};
1322        testInvokeOnPool(singletonPool(), a);
1323    }
1324
1325    /**
1326     * invokeAll(t1, t2) throw exception if any task does
1327     */
1328    public void testAbnormalInvokeAll2Singleton() {
1329        RecursiveAction a = new CheckedRecursiveAction() {
1330            protected void realCompute() {
1331                AsyncFib f = new AsyncFib(8);
1332                FailingAsyncFib g = new FailingAsyncFib(9);
1333                try {
1334                    invokeAll(f, g);
1335                    shouldThrow();
1336                } catch (FJException success) {
1337                    checkCompletedAbnormally(g, success);
1338                }
1339            }};
1340        testInvokeOnPool(singletonPool(), a);
1341    }
1342
1343    /**
1344     * invokeAll(tasks) with 1 argument throws exception if task does
1345     */
1346    public void testAbnormalInvokeAll1Singleton() {
1347        RecursiveAction a = new CheckedRecursiveAction() {
1348            protected void realCompute() {
1349                FailingAsyncFib g = new FailingAsyncFib(9);
1350                try {
1351                    invokeAll(g);
1352                    shouldThrow();
1353                } catch (FJException success) {
1354                    checkCompletedAbnormally(g, success);
1355                }
1356            }};
1357        testInvokeOnPool(singletonPool(), a);
1358    }
1359
1360    /**
1361     * invokeAll(tasks) with > 2 argument throws exception if any task does
1362     */
1363    public void testAbnormalInvokeAll3Singleton() {
1364        RecursiveAction a = new CheckedRecursiveAction() {
1365            protected void realCompute() {
1366                AsyncFib f = new AsyncFib(8);
1367                FailingAsyncFib g = new FailingAsyncFib(9);
1368                AsyncFib h = new AsyncFib(7);
1369                try {
1370                    invokeAll(f, g, h);
1371                    shouldThrow();
1372                } catch (FJException success) {
1373                    checkCompletedAbnormally(g, success);
1374                }
1375            }};
1376        testInvokeOnPool(singletonPool(), a);
1377    }
1378
1379    /**
1380     * invokeAll(collection) throws exception if any task does
1381     */
1382    public void testAbnormalInvokeAllCollectionSingleton() {
1383        RecursiveAction a = new CheckedRecursiveAction() {
1384            protected void realCompute() {
1385                FailingAsyncFib f = new FailingAsyncFib(8);
1386                AsyncFib g = new AsyncFib(9);
1387                AsyncFib h = new AsyncFib(7);
1388                HashSet set = new HashSet();
1389                set.add(f);
1390                set.add(g);
1391                set.add(h);
1392                try {
1393                    invokeAll(set);
1394                    shouldThrow();
1395                } catch (FJException success) {
1396                    checkCompletedAbnormally(f, success);
1397                }
1398            }};
1399        testInvokeOnPool(singletonPool(), a);
1400    }
1401
1145      /**
1146       * ForkJoinTask.quietlyComplete returns when task completes
1147       * normally without setting a value. The most recent value
# Line 1420 | Line 1163 | public class ForkJoinTask8Test extends J
1163          testInvokeOnPool(mainPool(), a);
1164      }
1165  
1166 +    // jdk9
1167 +
1168 +    /**
1169 +     * pollSubmission returns unexecuted submitted task, if present
1170 +     */
1171 +    public void testPollSubmission() {
1172 +        final CountDownLatch done = new CountDownLatch(1);
1173 +        final ForkJoinTask a = ForkJoinTask.adapt(awaiter(done));
1174 +        final ForkJoinTask b = ForkJoinTask.adapt(awaiter(done));
1175 +        final ForkJoinTask c = ForkJoinTask.adapt(awaiter(done));
1176 +        final ForkJoinPool p = singletonPool();
1177 +        try (PoolCleaner cleaner = cleaner(p, done)) {
1178 +            Thread external = new Thread(new CheckedRunnable() {
1179 +                public void realRun() {
1180 +                    p.execute(a);
1181 +                    p.execute(b);
1182 +                    p.execute(c);
1183 +                }});
1184 +            RecursiveAction s = new CheckedRecursiveAction() {
1185 +                protected void realCompute() {
1186 +                    external.start();
1187 +                    try {
1188 +                        external.join();
1189 +                    } catch (Exception ex) {
1190 +                        threadUnexpectedException(ex);
1191 +                    }
1192 +                    assertTrue(p.hasQueuedSubmissions());
1193 +                    assertTrue(Thread.currentThread() instanceof ForkJoinWorkerThread);
1194 +                    ForkJoinTask r = ForkJoinTask.pollSubmission();
1195 +                    assertTrue(r == a || r == b || r == c);
1196 +                    assertFalse(r.isDone());
1197 +                }};
1198 +            p.invoke(s);
1199 +        }
1200 +    }
1201 +
1202   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines