91 |
|
} |
92 |
|
} |
93 |
|
|
94 |
< |
void checkNotDone(ForkJoinTask a) { |
94 |
> |
void checkNotDone(ForkJoinTask<?> a) { |
95 |
|
assertFalse(a.isDone()); |
96 |
|
assertFalse(a.isCompletedNormally()); |
97 |
|
assertFalse(a.isCompletedAbnormally()); |
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 |
|
assertEquals(COMPLETE_STATE, |
125 |
|
((BinaryAsyncAction)a).getForkJoinTaskTag()); |
127 |
|
{ |
128 |
|
Thread.currentThread().interrupt(); |
129 |
|
long startTime = System.nanoTime(); |
130 |
< |
assertSame(expected, a.join()); |
130 |
> |
assertSame(expectedValue, a.join()); |
131 |
|
assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS); |
132 |
|
Thread.interrupted(); |
133 |
|
} |
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 |
< |
assertSame(expected, a.get(randomTimeout(), randomTimeUnit())); |
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) { |
155 |
> |
void checkCompletedAbnormally(ForkJoinTask<?> a, Throwable t) { |
156 |
|
assertTrue(a.isDone()); |
157 |
|
assertFalse(a.isCancelled()); |
158 |
|
assertFalse(a.isCompletedNormally()); |
532 |
|
AsyncFib f = new AsyncFib(8); |
533 |
|
assertSame(f, f.fork()); |
534 |
|
helpQuiesce(); |
535 |
+ |
while (!f.isDone()) // wait out race |
536 |
+ |
; |
537 |
|
assertEquals(0, getQueuedTaskCount()); |
538 |
|
f.checkCompletedNormally(); |
539 |
|
}}; |
875 |
|
RecursiveAction a = new CheckedRecursiveAction() { |
876 |
|
protected void realCompute() { |
877 |
|
AsyncFib nul = null; |
878 |
< |
Runnable[] throwingActions = { |
878 |
> |
assertThrows( |
879 |
> |
NullPointerException.class, |
880 |
|
() -> invokeAll(nul), |
881 |
|
() -> invokeAll(nul, nul), |
882 |
|
() -> invokeAll(new AsyncFib(8), new AsyncFib(9), nul), |
883 |
|
() -> invokeAll(new AsyncFib(8), nul, new AsyncFib(9)), |
884 |
< |
() -> invokeAll(nul, new AsyncFib(8), new AsyncFib(9)), |
878 |
< |
}; |
879 |
< |
assertThrows(NullPointerException.class, throwingActions); |
884 |
> |
() -> invokeAll(nul, new AsyncFib(8), new AsyncFib(9))); |
885 |
|
}}; |
886 |
|
testInvokeOnPool(pool, a); |
887 |
|
} |
923 |
|
protected void realCompute() { |
924 |
|
AsyncFib f = new AsyncFib(8); |
925 |
|
FailingAsyncFib g = new FailingAsyncFib(9); |
926 |
< |
ForkJoinTask[] tasks = { f, g }; |
926 |
> |
ForkJoinTask<?>[] tasks = { f, g }; |
927 |
|
shuffle(tasks); |
928 |
|
try { |
929 |
|
invokeAll(tasks[0], tasks[1]); |
950 |
|
AsyncFib f = new AsyncFib(8); |
951 |
|
FailingAsyncFib g = new FailingAsyncFib(9); |
952 |
|
AsyncFib h = new AsyncFib(7); |
953 |
< |
ForkJoinTask[] tasks = { f, g, h }; |
953 |
> |
ForkJoinTask<?>[] tasks = { f, g, h }; |
954 |
|
shuffle(tasks); |
955 |
|
try { |
956 |
|
invokeAll(tasks[0], tasks[1], tasks[2]); |
977 |
|
FailingAsyncFib f = new FailingAsyncFib(8); |
978 |
|
AsyncFib g = new AsyncFib(9); |
979 |
|
AsyncFib h = new AsyncFib(7); |
980 |
< |
ForkJoinTask[] tasks = { f, g, h }; |
980 |
> |
ForkJoinTask<?>[] tasks = { f, g, h }; |
981 |
|
shuffle(tasks); |
982 |
|
try { |
983 |
|
invokeAll(Arrays.asList(tasks)); |
1172 |
|
*/ |
1173 |
|
public void testPollSubmission() { |
1174 |
|
final CountDownLatch done = new CountDownLatch(1); |
1175 |
< |
final ForkJoinTask a = ForkJoinTask.adapt(awaiter(done)); |
1176 |
< |
final ForkJoinTask b = ForkJoinTask.adapt(awaiter(done)); |
1177 |
< |
final ForkJoinTask c = ForkJoinTask.adapt(awaiter(done)); |
1175 |
> |
final ForkJoinTask<?> a = ForkJoinTask.adapt(awaiter(done)); |
1176 |
> |
final ForkJoinTask<?> b = ForkJoinTask.adapt(awaiter(done)); |
1177 |
> |
final ForkJoinTask<?> c = ForkJoinTask.adapt(awaiter(done)); |
1178 |
|
final ForkJoinPool p = singletonPool(); |
1179 |
|
try (PoolCleaner cleaner = cleaner(p, done)) { |
1180 |
|
Thread external = new Thread(new CheckedRunnable() { |
1193 |
|
} |
1194 |
|
assertTrue(p.hasQueuedSubmissions()); |
1195 |
|
assertTrue(Thread.currentThread() instanceof ForkJoinWorkerThread); |
1196 |
< |
ForkJoinTask r = ForkJoinTask.pollSubmission(); |
1196 |
> |
ForkJoinTask<?> r = ForkJoinTask.pollSubmission(); |
1197 |
|
assertTrue(r == a || r == b || r == c); |
1198 |
|
assertFalse(r.isDone()); |
1199 |
|
}}; |