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.2 by jsr166, Mon Jul 22 15:55:43 2013 UTC vs.
Revision 1.16 by jsr166, Wed Sep 9 00:26:59 2015 UTC

# Line 3 | Line 3
3   * Expert Group and released to the public domain, as explained at
4   * http://creativecommons.org/publicdomain/zero/1.0/
5   */
6 +
7 + import static java.util.concurrent.TimeUnit.MILLISECONDS;
8 + import static java.util.concurrent.TimeUnit.SECONDS;
9 +
10 + import java.util.Arrays;
11 + import java.util.Collections;
12 + import java.util.concurrent.CountDownLatch;
13   import java.util.concurrent.ExecutionException;
7 import java.util.concurrent.CancellationException;
14   import java.util.concurrent.ForkJoinPool;
15   import java.util.concurrent.ForkJoinTask;
16   import java.util.concurrent.ForkJoinWorkerThread;
17   import java.util.concurrent.RecursiveAction;
12 import java.util.concurrent.TimeUnit;
18   import java.util.concurrent.TimeoutException;
19 < import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
20 < import static java.util.concurrent.TimeUnit.MILLISECONDS;
21 < import static java.util.concurrent.TimeUnit.SECONDS;
17 < import java.util.HashSet;
18 < import junit.framework.*;
19 >
20 > import junit.framework.Test;
21 > import junit.framework.TestSuite;
22  
23   public class ForkJoinTask8Test extends JSR166TestCase {
24  
# Line 34 | Line 37 | public class ForkJoinTask8Test extends J
37      static final short EXCEPTION_STATE = 1;
38  
39      public static void main(String[] args) {
40 <        junit.textui.TestRunner.run(suite());
40 >        main(suite(), args);
41      }
42  
43      public static Test suite() {
# Line 59 | Line 62 | public class ForkJoinTask8Test extends J
62                                  null, true);
63      }
64  
65 +    // Compute fib naively and efficiently
66 +    final int[] fib;
67 +    {
68 +        int[] fib = new int[10];
69 +        fib[0] = 0;
70 +        fib[1] = 1;
71 +        for (int i = 2; i < fib.length; i++)
72 +            fib[i] = fib[i - 1] + fib[i - 2];
73 +        this.fib = fib;
74 +    }
75 +
76      private void testInvokeOnPool(ForkJoinPool pool, RecursiveAction a) {
77          try {
78              assertFalse(a.isDone());
# Line 180 | Line 194 | public class ForkJoinTask8Test extends J
194          } catch (Throwable fail) { threadUnexpectedException(fail); }
195      }
196  
183
197      public static final class FJException extends RuntimeException {
198          FJException() { super(); }
199      }
# Line 278 | Line 291 | public class ForkJoinTask8Test extends J
291              super.reinitialize();
292          }
293  
281
294      }
295  
296 <    static final class AsyncFib extends BinaryAsyncAction {
296 >    final class AsyncFib extends BinaryAsyncAction {
297          int number;
298 <        public AsyncFib(int n) {
299 <            this.number = n;
298 >        int expectedResult;
299 >        public AsyncFib(int number) {
300 >            this.number = number;
301 >            this.expectedResult = fib[number];
302          }
303  
304          public final boolean exec() {
# Line 313 | Line 327 | public class ForkJoinTask8Test extends J
327              number = ((AsyncFib)x).number + ((AsyncFib)y).number;
328              super.onComplete(x, y);
329          }
330 +
331 +        public void checkCompletedNormally() {
332 +            assertEquals(expectedResult, number);
333 +            ForkJoinTask8Test.this.checkCompletedNormally(this);
334 +        }
335      }
336  
337      static final class FailingAsyncFib extends BinaryAsyncAction {
# Line 349 | Line 368 | public class ForkJoinTask8Test extends J
368       * completed tasks; getRawResult returns null.
369       */
370      public void testInvoke() {
371 +        testInvoke(mainPool());
372 +    }
373 +    public void testInvoke_Singleton() {
374 +        testInvoke(singletonPool());
375 +    }
376 +    public void testInvoke(ForkJoinPool pool) {
377          RecursiveAction a = new CheckedRecursiveAction() {
378              protected void realCompute() {
379                  AsyncFib f = new AsyncFib(8);
380                  assertNull(f.invoke());
381 <                assertEquals(21, f.number);
357 <                checkCompletedNormally(f);
381 >                f.checkCompletedNormally();
382              }};
383 <        testInvokeOnPool(mainPool(), a);
383 >        testInvokeOnPool(pool, a);
384      }
385  
386      /**
# Line 365 | Line 389 | public class ForkJoinTask8Test extends J
389       * completed tasks
390       */
391      public void testQuietlyInvoke() {
392 +        testQuietlyInvoke(mainPool());
393 +    }
394 +    public void testQuietlyInvoke_Singleton() {
395 +        testQuietlyInvoke(singletonPool());
396 +    }
397 +    public void testQuietlyInvoke(ForkJoinPool pool) {
398          RecursiveAction a = new CheckedRecursiveAction() {
399              protected void realCompute() {
400                  AsyncFib f = new AsyncFib(8);
401                  f.quietlyInvoke();
402 <                assertEquals(21, f.number);
373 <                checkCompletedNormally(f);
402 >                f.checkCompletedNormally();
403              }};
404 <        testInvokeOnPool(mainPool(), a);
404 >        testInvokeOnPool(pool, a);
405      }
406  
407      /**
408       * join of a forked task returns when task completes
409       */
410      public void testForkJoin() {
411 +        testForkJoin(mainPool());
412 +    }
413 +    public void testForkJoin_Singleton() {
414 +        testForkJoin(singletonPool());
415 +    }
416 +    public void testForkJoin(ForkJoinPool pool) {
417          RecursiveAction a = new CheckedRecursiveAction() {
418              protected void realCompute() {
419                  AsyncFib f = new AsyncFib(8);
420                  assertSame(f, f.fork());
421                  assertNull(f.join());
422 <                assertEquals(21, f.number);
388 <                checkCompletedNormally(f);
422 >                f.checkCompletedNormally();
423              }};
424 <        testInvokeOnPool(mainPool(), a);
424 >        testInvokeOnPool(pool, a);
425      }
426  
427      /**
428       * get of a forked task returns when task completes
429       */
430      public void testForkGet() {
431 +        testForkGet(mainPool());
432 +    }
433 +    public void testForkGet_Singleton() {
434 +        testForkGet(singletonPool());
435 +    }
436 +    public void testForkGet(ForkJoinPool pool) {
437          RecursiveAction a = new CheckedRecursiveAction() {
438              protected void realCompute() throws Exception {
439                  AsyncFib f = new AsyncFib(8);
440                  assertSame(f, f.fork());
441                  assertNull(f.get());
442 <                assertEquals(21, f.number);
403 <                checkCompletedNormally(f);
442 >                f.checkCompletedNormally();
443              }};
444 <        testInvokeOnPool(mainPool(), a);
444 >        testInvokeOnPool(pool, a);
445      }
446  
447      /**
448       * timed get of a forked task returns when task completes
449       */
450      public void testForkTimedGet() {
451 +        testForkTimedGet(mainPool());
452 +    }
453 +    public void testForkTimedGet_Singleton() {
454 +        testForkTimedGet(singletonPool());
455 +    }
456 +    public void testForkTimedGet(ForkJoinPool pool) {
457          RecursiveAction a = new CheckedRecursiveAction() {
458              protected void realCompute() throws Exception {
459                  AsyncFib f = new AsyncFib(8);
460                  assertSame(f, f.fork());
461                  assertNull(f.get(LONG_DELAY_MS, MILLISECONDS));
462 <                assertEquals(21, f.number);
418 <                checkCompletedNormally(f);
462 >                f.checkCompletedNormally();
463              }};
464 <        testInvokeOnPool(mainPool(), a);
464 >        testInvokeOnPool(pool, a);
465      }
466  
467      /**
468 <     * timed get with null time unit throws NPE
468 >     * timed get with null time unit throws NullPointerException
469       */
470 <    public void testForkTimedGetNPE() {
470 >    public void testForkTimedGetNullTimeUnit() {
471 >        testForkTimedGetNullTimeUnit(mainPool());
472 >    }
473 >    public void testForkTimedGetNullTimeUnit_Singleton() {
474 >        testForkTimedGet(singletonPool());
475 >    }
476 >    public void testForkTimedGetNullTimeUnit(ForkJoinPool pool) {
477          RecursiveAction a = new CheckedRecursiveAction() {
478              protected void realCompute() throws Exception {
479                  AsyncFib f = new AsyncFib(8);
# Line 433 | Line 483 | public class ForkJoinTask8Test extends J
483                      shouldThrow();
484                  } catch (NullPointerException success) {}
485              }};
486 <        testInvokeOnPool(mainPool(), a);
486 >        testInvokeOnPool(pool, a);
487      }
488  
489      /**
490       * quietlyJoin of a forked task returns when task completes
491       */
492      public void testForkQuietlyJoin() {
493 +        testForkQuietlyJoin(mainPool());
494 +    }
495 +    public void testForkQuietlyJoin_Singleton() {
496 +        testForkQuietlyJoin(singletonPool());
497 +    }
498 +    public void testForkQuietlyJoin(ForkJoinPool pool) {
499          RecursiveAction a = new CheckedRecursiveAction() {
500              protected void realCompute() {
501                  AsyncFib f = new AsyncFib(8);
502                  assertSame(f, f.fork());
503                  f.quietlyJoin();
504 <                assertEquals(21, f.number);
449 <                checkCompletedNormally(f);
504 >                f.checkCompletedNormally();
505              }};
506 <        testInvokeOnPool(mainPool(), a);
506 >        testInvokeOnPool(pool, a);
507      }
508  
509      /**
# Line 456 | Line 511 | public class ForkJoinTask8Test extends J
511       * getQueuedTaskCount returns 0 when quiescent
512       */
513      public void testForkHelpQuiesce() {
514 +        testForkHelpQuiesce(mainPool());
515 +    }
516 +    public void testForkHelpQuiesce_Singleton() {
517 +        testForkHelpQuiesce(singletonPool());
518 +    }
519 +    public void testForkHelpQuiesce(ForkJoinPool pool) {
520          RecursiveAction a = new CheckedRecursiveAction() {
521              protected void realCompute() {
522                  AsyncFib f = new AsyncFib(8);
523                  assertSame(f, f.fork());
524                  helpQuiesce();
464                assertEquals(21, f.number);
525                  assertEquals(0, getQueuedTaskCount());
526 <                checkCompletedNormally(f);
526 >                f.checkCompletedNormally();
527              }};
528 <        testInvokeOnPool(mainPool(), a);
528 >        testInvokeOnPool(pool, a);
529      }
530  
531      /**
532       * invoke task throws exception when task completes abnormally
533       */
534      public void testAbnormalInvoke() {
535 +        testAbnormalInvoke(mainPool());
536 +    }
537 +    public void testAbnormalInvoke_Singleton() {
538 +        testAbnormalInvoke(singletonPool());
539 +    }
540 +    public void testAbnormalInvoke(ForkJoinPool pool) {
541          RecursiveAction a = new CheckedRecursiveAction() {
542              protected void realCompute() {
543                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 482 | Line 548 | public class ForkJoinTask8Test extends J
548                      checkCompletedAbnormally(f, success);
549                  }
550              }};
551 <        testInvokeOnPool(mainPool(), a);
551 >        testInvokeOnPool(pool, a);
552      }
553  
554      /**
555       * quietlyInvoke task returns when task completes abnormally
556       */
557      public void testAbnormalQuietlyInvoke() {
558 +        testAbnormalQuietlyInvoke(mainPool());
559 +    }
560 +    public void testAbnormalQuietlyInvoke_Singleton() {
561 +        testAbnormalQuietlyInvoke(singletonPool());
562 +    }
563 +    public void testAbnormalQuietlyInvoke(ForkJoinPool pool) {
564          RecursiveAction a = new CheckedRecursiveAction() {
565              protected void realCompute() {
566                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 496 | Line 568 | public class ForkJoinTask8Test extends J
568                  assertTrue(f.getException() instanceof FJException);
569                  checkCompletedAbnormally(f, f.getException());
570              }};
571 <        testInvokeOnPool(mainPool(), a);
571 >        testInvokeOnPool(pool, a);
572      }
573  
574      /**
575       * join of a forked task throws exception when task completes abnormally
576       */
577      public void testAbnormalForkJoin() {
578 +        testAbnormalForkJoin(mainPool());
579 +    }
580 +    public void testAbnormalForkJoin_Singleton() {
581 +        testAbnormalForkJoin(singletonPool());
582 +    }
583 +    public void testAbnormalForkJoin(ForkJoinPool pool) {
584          RecursiveAction a = new CheckedRecursiveAction() {
585              protected void realCompute() {
586                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 514 | Line 592 | public class ForkJoinTask8Test extends J
592                      checkCompletedAbnormally(f, success);
593                  }
594              }};
595 <        testInvokeOnPool(mainPool(), a);
595 >        testInvokeOnPool(pool, a);
596      }
597  
598      /**
599       * get of a forked task throws exception when task completes abnormally
600       */
601      public void testAbnormalForkGet() {
602 +        testAbnormalForkGet(mainPool());
603 +    }
604 +    public void testAbnormalForkGet_Singleton() {
605 +        testAbnormalForkJoin(singletonPool());
606 +    }
607 +    public void testAbnormalForkGet(ForkJoinPool pool) {
608          RecursiveAction a = new CheckedRecursiveAction() {
609              protected void realCompute() throws Exception {
610                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 534 | Line 618 | public class ForkJoinTask8Test extends J
618                      checkCompletedAbnormally(f, cause);
619                  }
620              }};
621 <        testInvokeOnPool(mainPool(), a);
621 >        testInvokeOnPool(pool, a);
622      }
623  
624      /**
625       * timed get of a forked task throws exception when task completes abnormally
626       */
627      public void testAbnormalForkTimedGet() {
628 +        testAbnormalForkTimedGet(mainPool());
629 +    }
630 +    public void testAbnormalForkTimedGet_Singleton() {
631 +        testAbnormalForkTimedGet(singletonPool());
632 +    }
633 +    public void testAbnormalForkTimedGet(ForkJoinPool pool) {
634          RecursiveAction a = new CheckedRecursiveAction() {
635              protected void realCompute() throws Exception {
636                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 554 | Line 644 | public class ForkJoinTask8Test extends J
644                      checkCompletedAbnormally(f, cause);
645                  }
646              }};
647 <        testInvokeOnPool(mainPool(), a);
647 >        testInvokeOnPool(pool, a);
648      }
649  
650      /**
651       * quietlyJoin of a forked task returns when task completes abnormally
652       */
653      public void testAbnormalForkQuietlyJoin() {
654 +        testAbnormalForkQuietlyJoin(mainPool());
655 +    }
656 +    public void testAbnormalForkQuietlyJoin_Singleton() {
657 +        testAbnormalForkQuietlyJoin(singletonPool());
658 +    }
659 +    public void testAbnormalForkQuietlyJoin(ForkJoinPool pool) {
660          RecursiveAction a = new CheckedRecursiveAction() {
661              protected void realCompute() {
662                  FailingAsyncFib f = new FailingAsyncFib(8);
# Line 569 | Line 665 | public class ForkJoinTask8Test extends J
665                  assertTrue(f.getException() instanceof FJException);
666                  checkCompletedAbnormally(f, f.getException());
667              }};
668 <        testInvokeOnPool(mainPool(), a);
668 >        testInvokeOnPool(pool, a);
669      }
670  
575
671      /**
672       * getPool of executing task returns its pool
673       */
674      public void testGetPool() {
675 <        final ForkJoinPool mainPool = mainPool();
675 >        testGetPool(mainPool());
676 >    }
677 >    public void testGetPool_Singleton() {
678 >        testGetPool(singletonPool());
679 >    }
680 >    public void testGetPool(ForkJoinPool pool) {
681          RecursiveAction a = new CheckedRecursiveAction() {
682              protected void realCompute() {
683 <                assertSame(mainPool, getPool());
683 >                assertSame(pool, getPool());
684              }};
685 <        testInvokeOnPool(mainPool, a);
685 >        testInvokeOnPool(pool, a);
686      }
687  
688      /**
# Line 600 | Line 700 | public class ForkJoinTask8Test extends J
700       * inForkJoinPool of executing task returns true
701       */
702      public void testInForkJoinPool() {
703 +        testInForkJoinPool(mainPool());
704 +    }
705 +    public void testInForkJoinPool_Singleton() {
706 +        testInForkJoinPool(singletonPool());
707 +    }
708 +    public void testInForkJoinPool(ForkJoinPool pool) {
709          RecursiveAction a = new CheckedRecursiveAction() {
710              protected void realCompute() {
711                  assertTrue(inForkJoinPool());
712              }};
713 <        testInvokeOnPool(mainPool(), a);
713 >        testInvokeOnPool(pool, a);
714      }
715  
716      /**
# Line 634 | Line 740 | public class ForkJoinTask8Test extends J
740       * invoke task throws exception after invoking completeExceptionally
741       */
742      public void testCompleteExceptionally() {
743 +        testCompleteExceptionally(mainPool());
744 +    }
745 +    public void testCompleteExceptionally_Singleton() {
746 +        testCompleteExceptionally(singletonPool());
747 +    }
748 +    public void testCompleteExceptionally(ForkJoinPool pool) {
749          RecursiveAction a = new CheckedRecursiveAction() {
750              protected void realCompute() {
751                  AsyncFib f = new AsyncFib(8);
# Line 645 | Line 757 | public class ForkJoinTask8Test extends J
757                      checkCompletedAbnormally(f, success);
758                  }
759              }};
760 <        testInvokeOnPool(mainPool(), a);
760 >        testInvokeOnPool(pool, a);
761      }
762  
763      /**
764 <     * invokeAll(t1, t2) invokes all task arguments
764 >     * invokeAll(tasks) with 1 argument invokes task
765       */
766 <    public void testInvokeAll2() {
766 >    public void testInvokeAll1() {
767 >        testInvokeAll1(mainPool());
768 >    }
769 >    public void testInvokeAll1_Singleton() {
770 >        testInvokeAll1(singletonPool());
771 >    }
772 >    public void testInvokeAll1(ForkJoinPool pool) {
773          RecursiveAction a = new CheckedRecursiveAction() {
774              protected void realCompute() {
775                  AsyncFib f = new AsyncFib(8);
776 <                AsyncFib g = new AsyncFib(9);
777 <                invokeAll(f, g);
660 <                assertEquals(21, f.number);
661 <                assertEquals(34, g.number);
662 <                checkCompletedNormally(f);
663 <                checkCompletedNormally(g);
776 >                invokeAll(f);
777 >                f.checkCompletedNormally();
778              }};
779 <        testInvokeOnPool(mainPool(), a);
779 >        testInvokeOnPool(pool, a);
780      }
781  
782      /**
783 <     * invokeAll(tasks) with 1 argument invokes task
783 >     * invokeAll(t1, t2) invokes all task arguments
784       */
785 <    public void testInvokeAll1() {
785 >    public void testInvokeAll2() {
786 >        testInvokeAll2(mainPool());
787 >    }
788 >    public void testInvokeAll2_Singleton() {
789 >        testInvokeAll2(singletonPool());
790 >    }
791 >    public void testInvokeAll2(ForkJoinPool pool) {
792          RecursiveAction a = new CheckedRecursiveAction() {
793              protected void realCompute() {
794 <                AsyncFib f = new AsyncFib(8);
795 <                invokeAll(f);
796 <                checkCompletedNormally(f);
797 <                assertEquals(21, f.number);
794 >                AsyncFib[] tasks = {
795 >                    new AsyncFib(8),
796 >                    new AsyncFib(9),
797 >                };
798 >                invokeAll(tasks[0], tasks[1]);
799 >                for (AsyncFib task : tasks) assertTrue(task.isDone());
800 >                for (AsyncFib task : tasks) task.checkCompletedNormally();
801              }};
802 <        testInvokeOnPool(mainPool(), a);
802 >        testInvokeOnPool(pool, a);
803      }
804  
805      /**
806       * invokeAll(tasks) with > 2 argument invokes tasks
807       */
808      public void testInvokeAll3() {
809 +        testInvokeAll3(mainPool());
810 +    }
811 +    public void testInvokeAll3_Singleton() {
812 +        testInvokeAll3(singletonPool());
813 +    }
814 +    public void testInvokeAll3(ForkJoinPool pool) {
815          RecursiveAction a = new CheckedRecursiveAction() {
816              protected void realCompute() {
817 <                AsyncFib f = new AsyncFib(8);
818 <                AsyncFib g = new AsyncFib(9);
819 <                AsyncFib h = new AsyncFib(7);
820 <                invokeAll(f, g, h);
821 <                assertEquals(21, f.number);
822 <                assertEquals(34, g.number);
823 <                assertEquals(13, h.number);
824 <                checkCompletedNormally(f);
696 <                checkCompletedNormally(g);
697 <                checkCompletedNormally(h);
817 >                AsyncFib[] tasks = {
818 >                    new AsyncFib(8),
819 >                    new AsyncFib(9),
820 >                    new AsyncFib(7),
821 >                };
822 >                invokeAll(tasks[0], tasks[1], tasks[2]);
823 >                for (AsyncFib task : tasks) assertTrue(task.isDone());
824 >                for (AsyncFib task : tasks) task.checkCompletedNormally();
825              }};
826 <        testInvokeOnPool(mainPool(), a);
826 >        testInvokeOnPool(pool, a);
827      }
828  
829      /**
830       * invokeAll(collection) invokes all tasks in the collection
831       */
832      public void testInvokeAllCollection() {
833 +        testInvokeAllCollection(mainPool());
834 +    }
835 +    public void testInvokeAllCollection_Singleton() {
836 +        testInvokeAllCollection(singletonPool());
837 +    }
838 +    public void testInvokeAllCollection(ForkJoinPool pool) {
839          RecursiveAction a = new CheckedRecursiveAction() {
840              protected void realCompute() {
841 <                AsyncFib f = new AsyncFib(8);
842 <                AsyncFib g = new AsyncFib(9);
843 <                AsyncFib h = new AsyncFib(7);
844 <                HashSet set = new HashSet();
845 <                set.add(f);
846 <                set.add(g);
847 <                set.add(h);
848 <                invokeAll(set);
716 <                assertEquals(21, f.number);
717 <                assertEquals(34, g.number);
718 <                assertEquals(13, h.number);
719 <                checkCompletedNormally(f);
720 <                checkCompletedNormally(g);
721 <                checkCompletedNormally(h);
841 >                AsyncFib[] tasks = {
842 >                    new AsyncFib(8),
843 >                    new AsyncFib(9),
844 >                    new AsyncFib(7),
845 >                };
846 >                invokeAll(Arrays.asList(tasks));
847 >                for (AsyncFib task : tasks) assertTrue(task.isDone());
848 >                for (AsyncFib task : tasks) task.checkCompletedNormally();
849              }};
850 <        testInvokeOnPool(mainPool(), a);
850 >        testInvokeOnPool(pool, a);
851      }
852  
853      /**
854 <     * invokeAll(tasks) with any null task throws NPE
854 >     * invokeAll(tasks) with any null task throws NullPointerException
855       */
856 <    public void testInvokeAllNPE() {
856 >    public void testInvokeAllNullTask() {
857 >        testInvokeAllNullTask(mainPool());
858 >    }
859 >    public void testInvokeAllNullTask_Singleton() {
860 >        testInvokeAllNullTask(singletonPool());
861 >    }
862 >    public void testInvokeAllNullTask(ForkJoinPool pool) {
863          RecursiveAction a = new CheckedRecursiveAction() {
864              protected void realCompute() {
865 <                AsyncFib f = new AsyncFib(8);
866 <                AsyncFib g = new AsyncFib(9);
867 <                AsyncFib h = null;
868 <                try {
869 <                    invokeAll(f, g, h);
870 <                    shouldThrow();
871 <                } catch (NullPointerException success) {}
865 >                AsyncFib nul = null;
866 >                Runnable[] throwingActions = {
867 >                    () -> invokeAll(nul),
868 >                    () -> invokeAll(nul, nul),
869 >                    () -> invokeAll(new AsyncFib(8), new AsyncFib(9), nul),
870 >                    () -> invokeAll(new AsyncFib(8), nul, new AsyncFib(9)),
871 >                    () -> invokeAll(nul, new AsyncFib(8), new AsyncFib(9)),
872 >                };
873 >                assertThrows(NullPointerException.class, throwingActions);
874              }};
875 <        testInvokeOnPool(mainPool(), a);
875 >        testInvokeOnPool(pool, a);
876      }
877  
878      /**
879 <     * invokeAll(t1, t2) throw exception if any task does
879 >     * invokeAll(tasks) with 1 argument throws exception if task does
880       */
881 <    public void testAbnormalInvokeAll2() {
881 >    public void testAbnormalInvokeAll1() {
882 >        testAbnormalInvokeAll1(mainPool());
883 >    }
884 >    public void testAbnormalInvokeAll1_Singleton() {
885 >        testAbnormalInvokeAll1(singletonPool());
886 >    }
887 >    public void testAbnormalInvokeAll1(ForkJoinPool pool) {
888          RecursiveAction a = new CheckedRecursiveAction() {
889              protected void realCompute() {
749                AsyncFib f = new AsyncFib(8);
890                  FailingAsyncFib g = new FailingAsyncFib(9);
891                  try {
892 <                    invokeAll(f, g);
892 >                    invokeAll(g);
893                      shouldThrow();
894                  } catch (FJException success) {
895                      checkCompletedAbnormally(g, success);
896                  }
897              }};
898 <        testInvokeOnPool(mainPool(), a);
898 >        testInvokeOnPool(pool, a);
899      }
900  
901      /**
902 <     * invokeAll(tasks) with 1 argument throws exception if task does
902 >     * invokeAll(t1, t2) throw exception if any task does
903       */
904 <    public void testAbnormalInvokeAll1() {
904 >    public void testAbnormalInvokeAll2() {
905 >        testAbnormalInvokeAll2(mainPool());
906 >    }
907 >    public void testAbnormalInvokeAll2_Singleton() {
908 >        testAbnormalInvokeAll2(singletonPool());
909 >    }
910 >    public void testAbnormalInvokeAll2(ForkJoinPool pool) {
911          RecursiveAction a = new CheckedRecursiveAction() {
912              protected void realCompute() {
913 +                AsyncFib f = new AsyncFib(8);
914                  FailingAsyncFib g = new FailingAsyncFib(9);
915 +                ForkJoinTask[] tasks = { f, g };
916 +                Collections.shuffle(Arrays.asList(tasks));
917                  try {
918 <                    invokeAll(g);
918 >                    invokeAll(tasks[0], tasks[1]);
919                      shouldThrow();
920                  } catch (FJException success) {
921                      checkCompletedAbnormally(g, success);
922                  }
923              }};
924 <        testInvokeOnPool(mainPool(), a);
924 >        testInvokeOnPool(pool, a);
925      }
926  
927      /**
928       * invokeAll(tasks) with > 2 argument throws exception if any task does
929       */
930      public void testAbnormalInvokeAll3() {
931 +        testAbnormalInvokeAll3(mainPool());
932 +    }
933 +    public void testAbnormalInvokeAll3_Singleton() {
934 +        testAbnormalInvokeAll3(singletonPool());
935 +    }
936 +    public void testAbnormalInvokeAll3(ForkJoinPool pool) {
937          RecursiveAction a = new CheckedRecursiveAction() {
938              protected void realCompute() {
939                  AsyncFib f = new AsyncFib(8);
940                  FailingAsyncFib g = new FailingAsyncFib(9);
941                  AsyncFib h = new AsyncFib(7);
942 +                ForkJoinTask[] tasks = { f, g, h };
943 +                Collections.shuffle(Arrays.asList(tasks));
944                  try {
945 <                    invokeAll(f, g, h);
945 >                    invokeAll(tasks[0], tasks[1], tasks[2]);
946                      shouldThrow();
947                  } catch (FJException success) {
948                      checkCompletedAbnormally(g, success);
949                  }
950              }};
951 <        testInvokeOnPool(mainPool(), a);
951 >        testInvokeOnPool(pool, a);
952      }
953  
954      /**
955 <     * invokeAll(collection)  throws exception if any task does
955 >     * invokeAll(collection) throws exception if any task does
956       */
957      public void testAbnormalInvokeAllCollection() {
958 +        testAbnormalInvokeAllCollection(mainPool());
959 +    }
960 +    public void testAbnormalInvokeAllCollection_Singleton() {
961 +        testAbnormalInvokeAllCollection(singletonPool());
962 +    }
963 +    public void testAbnormalInvokeAllCollection(ForkJoinPool pool) {
964          RecursiveAction a = new CheckedRecursiveAction() {
965              protected void realCompute() {
966                  FailingAsyncFib f = new FailingAsyncFib(8);
967                  AsyncFib g = new AsyncFib(9);
968                  AsyncFib h = new AsyncFib(7);
969 <                HashSet set = new HashSet();
970 <                set.add(f);
808 <                set.add(g);
809 <                set.add(h);
969 >                ForkJoinTask[] tasks = { f, g, h };
970 >                Collections.shuffle(Arrays.asList(tasks));
971                  try {
972 <                    invokeAll(set);
972 >                    invokeAll(Arrays.asList(tasks));
973                      shouldThrow();
974                  } catch (FJException success) {
975                      checkCompletedAbnormally(f, success);
976                  }
977              }};
978 <        testInvokeOnPool(mainPool(), a);
978 >        testInvokeOnPool(pool, a);
979      }
980  
981      /**
# Line 831 | Line 992 | public class ForkJoinTask8Test extends J
992                  assertTrue(f.tryUnfork());
993                  helpQuiesce();
994                  checkNotDone(f);
995 <                checkCompletedNormally(g);
995 >                g.checkCompletedNormally();
996              }};
997          testInvokeOnPool(singletonPool(), a);
998      }
# Line 852 | Line 1013 | public class ForkJoinTask8Test extends J
1013                  assertTrue(getSurplusQueuedTaskCount() > 0);
1014                  helpQuiesce();
1015                  assertEquals(0, getSurplusQueuedTaskCount());
1016 <                checkCompletedNormally(f);
1017 <                checkCompletedNormally(g);
1018 <                checkCompletedNormally(h);
1016 >                f.checkCompletedNormally();
1017 >                g.checkCompletedNormally();
1018 >                h.checkCompletedNormally();
1019              }};
1020          testInvokeOnPool(singletonPool(), a);
1021      }
# Line 871 | Line 1032 | public class ForkJoinTask8Test extends J
1032                  assertSame(f, f.fork());
1033                  assertSame(f, peekNextLocalTask());
1034                  assertNull(f.join());
1035 <                checkCompletedNormally(f);
1035 >                f.checkCompletedNormally();
1036                  helpQuiesce();
1037 <                checkCompletedNormally(g);
1037 >                g.checkCompletedNormally();
1038              }};
1039          testInvokeOnPool(singletonPool(), a);
1040      }
# Line 892 | Line 1053 | public class ForkJoinTask8Test extends J
1053                  assertSame(f, pollNextLocalTask());
1054                  helpQuiesce();
1055                  checkNotDone(f);
1056 <                assertEquals(34, g.number);
896 <                checkCompletedNormally(g);
1056 >                g.checkCompletedNormally();
1057              }};
1058          testInvokeOnPool(singletonPool(), a);
1059      }
# Line 911 | Line 1071 | public class ForkJoinTask8Test extends J
1071                  assertSame(f, pollTask());
1072                  helpQuiesce();
1073                  checkNotDone(f);
1074 <                checkCompletedNormally(g);
1074 >                g.checkCompletedNormally();
1075              }};
1076          testInvokeOnPool(singletonPool(), a);
1077      }
# Line 929 | Line 1089 | public class ForkJoinTask8Test extends J
1089                  assertSame(g, peekNextLocalTask());
1090                  assertNull(f.join());
1091                  helpQuiesce();
1092 <                checkCompletedNormally(f);
1093 <                assertEquals(34, g.number);
934 <                checkCompletedNormally(g);
1092 >                f.checkCompletedNormally();
1093 >                g.checkCompletedNormally();
1094              }};
1095          testInvokeOnPool(asyncSingletonPool(), a);
1096      }
# Line 949 | Line 1108 | public class ForkJoinTask8Test extends J
1108                  assertSame(f, f.fork());
1109                  assertSame(g, pollNextLocalTask());
1110                  helpQuiesce();
1111 <                assertEquals(21, f.number);
953 <                checkCompletedNormally(f);
1111 >                f.checkCompletedNormally();
1112                  checkNotDone(g);
1113              }};
1114          testInvokeOnPool(asyncSingletonPool(), a);
# Line 969 | Line 1127 | public class ForkJoinTask8Test extends J
1127                  assertSame(f, f.fork());
1128                  assertSame(g, pollTask());
1129                  helpQuiesce();
1130 <                assertEquals(21, f.number);
973 <                checkCompletedNormally(f);
1130 >                f.checkCompletedNormally();
1131                  checkNotDone(g);
1132              }};
1133          testInvokeOnPool(asyncSingletonPool(), a);
1134      }
1135  
979    // versions for singleton pools
980
981    /**
982     * invoke returns when task completes normally.
983     * isCompletedAbnormally and isCancelled return false for normally
984     * completed tasks; getRawResult returns null.
985     */
986    public void testInvokeSingleton() {
987        RecursiveAction a = new CheckedRecursiveAction() {
988            protected void realCompute() {
989                AsyncFib f = new AsyncFib(8);
990                assertNull(f.invoke());
991                assertEquals(21, f.number);
992                checkCompletedNormally(f);
993            }};
994        testInvokeOnPool(singletonPool(), a);
995    }
996
997    /**
998     * quietlyInvoke task returns when task completes normally.
999     * isCompletedAbnormally and isCancelled return false for normally
1000     * completed tasks
1001     */
1002    public void testQuietlyInvokeSingleton() {
1003        RecursiveAction a = new CheckedRecursiveAction() {
1004            protected void realCompute() {
1005                AsyncFib f = new AsyncFib(8);
1006                f.quietlyInvoke();
1007                assertEquals(21, f.number);
1008                checkCompletedNormally(f);
1009            }};
1010        testInvokeOnPool(singletonPool(), a);
1011    }
1012
1013    /**
1014     * join of a forked task returns when task completes
1015     */
1016    public void testForkJoinSingleton() {
1017        RecursiveAction a = new CheckedRecursiveAction() {
1018            protected void realCompute() {
1019                AsyncFib f = new AsyncFib(8);
1020                assertSame(f, f.fork());
1021                assertNull(f.join());
1022                assertEquals(21, f.number);
1023                checkCompletedNormally(f);
1024            }};
1025        testInvokeOnPool(singletonPool(), a);
1026    }
1027
1028    /**
1029     * get of a forked task returns when task completes
1030     */
1031    public void testForkGetSingleton() {
1032        RecursiveAction a = new CheckedRecursiveAction() {
1033            protected void realCompute() throws Exception {
1034                AsyncFib f = new AsyncFib(8);
1035                assertSame(f, f.fork());
1036                assertNull(f.get());
1037                assertEquals(21, f.number);
1038                checkCompletedNormally(f);
1039            }};
1040        testInvokeOnPool(singletonPool(), a);
1041    }
1042
1043    /**
1044     * timed get of a forked task returns when task completes
1045     */
1046    public void testForkTimedGetSingleton() {
1047        RecursiveAction a = new CheckedRecursiveAction() {
1048            protected void realCompute() throws Exception {
1049                AsyncFib f = new AsyncFib(8);
1050                assertSame(f, f.fork());
1051                assertNull(f.get(LONG_DELAY_MS, MILLISECONDS));
1052                assertEquals(21, f.number);
1053                checkCompletedNormally(f);
1054            }};
1055        testInvokeOnPool(singletonPool(), a);
1056    }
1057
1058    /**
1059     * timed get with null time unit throws NPE
1060     */
1061    public void testForkTimedGetNPESingleton() {
1062        RecursiveAction a = new CheckedRecursiveAction() {
1063            protected void realCompute() throws Exception {
1064                AsyncFib f = new AsyncFib(8);
1065                assertSame(f, f.fork());
1066                try {
1067                    f.get(5L, null);
1068                    shouldThrow();
1069                } catch (NullPointerException success) {}
1070            }};
1071        testInvokeOnPool(singletonPool(), a);
1072    }
1073
1074    /**
1075     * quietlyJoin of a forked task returns when task completes
1076     */
1077    public void testForkQuietlyJoinSingleton() {
1078        RecursiveAction a = new CheckedRecursiveAction() {
1079            protected void realCompute() {
1080                AsyncFib f = new AsyncFib(8);
1081                assertSame(f, f.fork());
1082                f.quietlyJoin();
1083                assertEquals(21, f.number);
1084                checkCompletedNormally(f);
1085            }};
1086        testInvokeOnPool(singletonPool(), a);
1087    }
1088
1089    /**
1090     * helpQuiesce returns when tasks are complete.
1091     * getQueuedTaskCount returns 0 when quiescent
1092     */
1093    public void testForkHelpQuiesceSingleton() {
1094        RecursiveAction a = new CheckedRecursiveAction() {
1095            protected void realCompute() {
1096                AsyncFib f = new AsyncFib(8);
1097                assertSame(f, f.fork());
1098                helpQuiesce();
1099                assertEquals(0, getQueuedTaskCount());
1100                assertEquals(21, f.number);
1101                checkCompletedNormally(f);
1102            }};
1103        testInvokeOnPool(singletonPool(), a);
1104    }
1105
1106    /**
1107     * invoke task throws exception when task completes abnormally
1108     */
1109    public void testAbnormalInvokeSingleton() {
1110        RecursiveAction a = new CheckedRecursiveAction() {
1111            protected void realCompute() {
1112                FailingAsyncFib f = new FailingAsyncFib(8);
1113                try {
1114                    f.invoke();
1115                    shouldThrow();
1116                } catch (FJException success) {
1117                    checkCompletedAbnormally(f, success);
1118                }
1119            }};
1120        testInvokeOnPool(singletonPool(), a);
1121    }
1122
1123    /**
1124     * quietlyInvoke task returns when task completes abnormally
1125     */
1126    public void testAbnormalQuietlyInvokeSingleton() {
1127        RecursiveAction a = new CheckedRecursiveAction() {
1128            protected void realCompute() {
1129                FailingAsyncFib f = new FailingAsyncFib(8);
1130                f.quietlyInvoke();
1131                assertTrue(f.getException() instanceof FJException);
1132                checkCompletedAbnormally(f, f.getException());
1133            }};
1134        testInvokeOnPool(singletonPool(), a);
1135    }
1136
1137    /**
1138     * join of a forked task throws exception when task completes abnormally
1139     */
1140    public void testAbnormalForkJoinSingleton() {
1141        RecursiveAction a = new CheckedRecursiveAction() {
1142            protected void realCompute() {
1143                FailingAsyncFib f = new FailingAsyncFib(8);
1144                assertSame(f, f.fork());
1145                try {
1146                    f.join();
1147                    shouldThrow();
1148                } catch (FJException success) {
1149                    checkCompletedAbnormally(f, success);
1150                }
1151            }};
1152        testInvokeOnPool(singletonPool(), a);
1153    }
1154
1155    /**
1156     * get of a forked task throws exception when task completes abnormally
1157     */
1158    public void testAbnormalForkGetSingleton() {
1159        RecursiveAction a = new CheckedRecursiveAction() {
1160            protected void realCompute() throws Exception {
1161                FailingAsyncFib f = new FailingAsyncFib(8);
1162                assertSame(f, f.fork());
1163                try {
1164                    f.get();
1165                    shouldThrow();
1166                } catch (ExecutionException success) {
1167                    Throwable cause = success.getCause();
1168                    assertTrue(cause instanceof FJException);
1169                    checkCompletedAbnormally(f, cause);
1170                }
1171            }};
1172        testInvokeOnPool(singletonPool(), a);
1173    }
1174
1175    /**
1176     * timed get of a forked task throws exception when task completes abnormally
1177     */
1178    public void testAbnormalForkTimedGetSingleton() {
1179        RecursiveAction a = new CheckedRecursiveAction() {
1180            protected void realCompute() throws Exception {
1181                FailingAsyncFib f = new FailingAsyncFib(8);
1182                assertSame(f, f.fork());
1183                try {
1184                    f.get(LONG_DELAY_MS, MILLISECONDS);
1185                    shouldThrow();
1186                } catch (ExecutionException success) {
1187                    Throwable cause = success.getCause();
1188                    assertTrue(cause instanceof FJException);
1189                    checkCompletedAbnormally(f, cause);
1190                }
1191            }};
1192        testInvokeOnPool(singletonPool(), a);
1193    }
1194
1195    /**
1196     * quietlyJoin of a forked task returns when task completes abnormally
1197     */
1198    public void testAbnormalForkQuietlyJoinSingleton() {
1199        RecursiveAction a = new CheckedRecursiveAction() {
1200            protected void realCompute() {
1201                FailingAsyncFib f = new FailingAsyncFib(8);
1202                assertSame(f, f.fork());
1203                f.quietlyJoin();
1204                assertTrue(f.getException() instanceof FJException);
1205                checkCompletedAbnormally(f, f.getException());
1206            }};
1207        testInvokeOnPool(singletonPool(), a);
1208    }
1209
1210    /**
1211     * invoke task throws exception after invoking completeExceptionally
1212     */
1213    public void testCompleteExceptionallySingleton() {
1214        RecursiveAction a = new CheckedRecursiveAction() {
1215            protected void realCompute() {
1216                AsyncFib f = new AsyncFib(8);
1217                f.completeExceptionally(new FJException());
1218                try {
1219                    f.invoke();
1220                    shouldThrow();
1221                } catch (FJException success) {
1222                    checkCompletedAbnormally(f, success);
1223                }
1224            }};
1225        testInvokeOnPool(singletonPool(), a);
1226    }
1227
1228    /**
1229     * invokeAll(t1, t2) invokes all task arguments
1230     */
1231    public void testInvokeAll2Singleton() {
1232        RecursiveAction a = new CheckedRecursiveAction() {
1233            protected void realCompute() {
1234                AsyncFib f = new AsyncFib(8);
1235                AsyncFib g = new AsyncFib(9);
1236                invokeAll(f, g);
1237                assertEquals(21, f.number);
1238                assertEquals(34, g.number);
1239                checkCompletedNormally(f);
1240                checkCompletedNormally(g);
1241            }};
1242        testInvokeOnPool(singletonPool(), a);
1243    }
1244
1245    /**
1246     * invokeAll(tasks) with 1 argument invokes task
1247     */
1248    public void testInvokeAll1Singleton() {
1249        RecursiveAction a = new CheckedRecursiveAction() {
1250            protected void realCompute() {
1251                AsyncFib f = new AsyncFib(8);
1252                invokeAll(f);
1253                checkCompletedNormally(f);
1254                assertEquals(21, f.number);
1255            }};
1256        testInvokeOnPool(singletonPool(), a);
1257    }
1258
1259    /**
1260     * invokeAll(tasks) with > 2 argument invokes tasks
1261     */
1262    public void testInvokeAll3Singleton() {
1263        RecursiveAction a = new CheckedRecursiveAction() {
1264            protected void realCompute() {
1265                AsyncFib f = new AsyncFib(8);
1266                AsyncFib g = new AsyncFib(9);
1267                AsyncFib h = new AsyncFib(7);
1268                invokeAll(f, g, h);
1269                assertEquals(21, f.number);
1270                assertEquals(34, g.number);
1271                assertEquals(13, h.number);
1272                checkCompletedNormally(f);
1273                checkCompletedNormally(g);
1274                checkCompletedNormally(h);
1275            }};
1276        testInvokeOnPool(singletonPool(), a);
1277    }
1278
1279    /**
1280     * invokeAll(collection) invokes all tasks in the collection
1281     */
1282    public void testInvokeAllCollectionSingleton() {
1283        RecursiveAction a = new CheckedRecursiveAction() {
1284            protected void realCompute() {
1285                AsyncFib f = new AsyncFib(8);
1286                AsyncFib g = new AsyncFib(9);
1287                AsyncFib h = new AsyncFib(7);
1288                HashSet set = new HashSet();
1289                set.add(f);
1290                set.add(g);
1291                set.add(h);
1292                invokeAll(set);
1293                assertEquals(21, f.number);
1294                assertEquals(34, g.number);
1295                assertEquals(13, h.number);
1296                checkCompletedNormally(f);
1297                checkCompletedNormally(g);
1298                checkCompletedNormally(h);
1299            }};
1300        testInvokeOnPool(singletonPool(), a);
1301    }
1302
1303    /**
1304     * invokeAll(tasks) with any null task throws NPE
1305     */
1306    public void testInvokeAllNPESingleton() {
1307        RecursiveAction a = new CheckedRecursiveAction() {
1308            protected void realCompute() {
1309                AsyncFib f = new AsyncFib(8);
1310                AsyncFib g = new AsyncFib(9);
1311                AsyncFib h = null;
1312                try {
1313                    invokeAll(f, g, h);
1314                    shouldThrow();
1315                } catch (NullPointerException success) {}
1316            }};
1317        testInvokeOnPool(singletonPool(), a);
1318    }
1319
1320    /**
1321     * invokeAll(t1, t2) throw exception if any task does
1322     */
1323    public void testAbnormalInvokeAll2Singleton() {
1324        RecursiveAction a = new CheckedRecursiveAction() {
1325            protected void realCompute() {
1326                AsyncFib f = new AsyncFib(8);
1327                FailingAsyncFib g = new FailingAsyncFib(9);
1328                try {
1329                    invokeAll(f, g);
1330                    shouldThrow();
1331                } catch (FJException success) {
1332                    checkCompletedAbnormally(g, success);
1333                }
1334            }};
1335        testInvokeOnPool(singletonPool(), a);
1336    }
1337
1338    /**
1339     * invokeAll(tasks) with 1 argument throws exception if task does
1340     */
1341    public void testAbnormalInvokeAll1Singleton() {
1342        RecursiveAction a = new CheckedRecursiveAction() {
1343            protected void realCompute() {
1344                FailingAsyncFib g = new FailingAsyncFib(9);
1345                try {
1346                    invokeAll(g);
1347                    shouldThrow();
1348                } catch (FJException success) {
1349                    checkCompletedAbnormally(g, success);
1350                }
1351            }};
1352        testInvokeOnPool(singletonPool(), a);
1353    }
1354
1355    /**
1356     * invokeAll(tasks) with > 2 argument throws exception if any task does
1357     */
1358    public void testAbnormalInvokeAll3Singleton() {
1359        RecursiveAction a = new CheckedRecursiveAction() {
1360            protected void realCompute() {
1361                AsyncFib f = new AsyncFib(8);
1362                FailingAsyncFib g = new FailingAsyncFib(9);
1363                AsyncFib h = new AsyncFib(7);
1364                try {
1365                    invokeAll(f, g, h);
1366                    shouldThrow();
1367                } catch (FJException success) {
1368                    checkCompletedAbnormally(g, success);
1369                }
1370            }};
1371        testInvokeOnPool(singletonPool(), a);
1372    }
1373
1374    /**
1375     * invokeAll(collection)  throws exception if any task does
1376     */
1377    public void testAbnormalInvokeAllCollectionSingleton() {
1378        RecursiveAction a = new CheckedRecursiveAction() {
1379            protected void realCompute() {
1380                FailingAsyncFib f = new FailingAsyncFib(8);
1381                AsyncFib g = new AsyncFib(9);
1382                AsyncFib h = new AsyncFib(7);
1383                HashSet set = new HashSet();
1384                set.add(f);
1385                set.add(g);
1386                set.add(h);
1387                try {
1388                    invokeAll(set);
1389                    shouldThrow();
1390                } catch (FJException success) {
1391                    checkCompletedAbnormally(f, success);
1392                }
1393            }};
1394        testInvokeOnPool(singletonPool(), a);
1395    }
1396
1136      /**
1137       * ForkJoinTask.quietlyComplete returns when task completes
1138       * normally without setting a value. The most recent value
# Line 1415 | Line 1154 | public class ForkJoinTask8Test extends J
1154          testInvokeOnPool(mainPool(), a);
1155      }
1156  
1157 +    // jdk9
1158 +
1159 +    /**
1160 +     * pollSubmission returns unexecuted submitted task, if present
1161 +     */
1162 +    public void testPollSubmission() {
1163 +        final CountDownLatch done = new CountDownLatch(1);
1164 +        final ForkJoinTask a = ForkJoinTask.adapt(awaiter(done));
1165 +        final ForkJoinTask b = ForkJoinTask.adapt(awaiter(done));
1166 +        final ForkJoinTask c = ForkJoinTask.adapt(awaiter(done));
1167 +        final ForkJoinPool p = singletonPool();
1168 +        Thread external = new Thread() {
1169 +                public void run() {
1170 +                    p.execute(a);
1171 +                    p.execute(b);
1172 +                    p.execute(c);
1173 +                }};
1174 +        RecursiveAction s = new CheckedRecursiveAction() {
1175 +                protected void realCompute() {
1176 +                    external.start();
1177 +                    try {
1178 +                        external.join();
1179 +                    } catch (Exception ex) {
1180 +                        threadUnexpectedException(ex);
1181 +                    }
1182 +                    assertTrue(p.hasQueuedSubmissions());
1183 +                    assertTrue(Thread.currentThread() instanceof ForkJoinWorkerThread);
1184 +                    ForkJoinTask r = ForkJoinTask.pollSubmission();
1185 +                    assertTrue(r == a || r == b || r == c);
1186 +                    assertFalse(r.isDone());
1187 +                }};
1188 +        try {
1189 +            p.invoke(s);
1190 +        } finally {
1191 +            done.countDown();
1192 +            joinPool(p);
1193 +        }
1194 +    }
1195 +
1196   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines