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.HashSet; |
11 |
|
import java.util.concurrent.ExecutionException; |
7 |
– |
import java.util.concurrent.CancellationException; |
12 |
|
import java.util.concurrent.ForkJoinPool; |
13 |
|
import java.util.concurrent.ForkJoinTask; |
10 |
– |
import java.util.concurrent.ForkJoinWorkerThread; |
14 |
|
import java.util.concurrent.RecursiveAction; |
12 |
– |
import java.util.concurrent.TimeUnit; |
15 |
|
import java.util.concurrent.TimeoutException; |
16 |
< |
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater; |
17 |
< |
import static java.util.concurrent.TimeUnit.MILLISECONDS; |
18 |
< |
import static java.util.concurrent.TimeUnit.SECONDS; |
17 |
< |
import java.util.HashSet; |
18 |
< |
import junit.framework.*; |
16 |
> |
|
17 |
> |
import junit.framework.Test; |
18 |
> |
import junit.framework.TestSuite; |
19 |
|
|
20 |
|
public class ForkJoinTask8Test extends JSR166TestCase { |
21 |
|
|
32 |
|
static final short INITIAL_STATE = -1; |
33 |
|
static final short COMPLETE_STATE = 0; |
34 |
|
static final short EXCEPTION_STATE = 1; |
35 |
– |
|
35 |
|
|
36 |
|
public static void main(String[] args) { |
37 |
|
junit.textui.TestRunner.run(suite()); |
180 |
|
} catch (Throwable fail) { threadUnexpectedException(fail); } |
181 |
|
} |
182 |
|
|
184 |
– |
|
183 |
|
public static final class FJException extends RuntimeException { |
184 |
|
FJException() { super(); } |
185 |
|
} |
204 |
|
} |
205 |
|
|
206 |
|
protected void onComplete(BinaryAsyncAction x, BinaryAsyncAction y) { |
207 |
< |
if (this.getForkJoinTaskTag() != COMPLETE_STATE || |
208 |
< |
x.getForkJoinTaskTag() != COMPLETE_STATE || |
207 |
> |
if (this.getForkJoinTaskTag() != COMPLETE_STATE || |
208 |
> |
x.getForkJoinTaskTag() != COMPLETE_STATE || |
209 |
|
y.getForkJoinTaskTag() != COMPLETE_STATE) { |
210 |
|
completeThisExceptionally(new FJException()); |
211 |
|
} |
239 |
|
a.sibling = null; |
240 |
|
a.parent = null; |
241 |
|
a.completeThis(); |
242 |
< |
if (p == null || |
242 |
> |
if (p == null || |
243 |
|
p.compareAndSetForkJoinTaskTag(INITIAL_STATE, COMPLETE_STATE)) |
244 |
|
break; |
245 |
|
try { |
277 |
|
super.reinitialize(); |
278 |
|
} |
279 |
|
|
282 |
– |
|
280 |
|
} |
281 |
|
|
282 |
|
static final class AsyncFib extends BinaryAsyncAction { |
301 |
|
} |
302 |
|
f.complete(); |
303 |
|
} |
304 |
< |
catch(Throwable ex) { |
304 |
> |
catch (Throwable ex) { |
305 |
|
compareAndSetForkJoinTaskTag(INITIAL_STATE, EXCEPTION_STATE); |
306 |
|
} |
307 |
|
return false; |
570 |
|
testInvokeOnPool(mainPool(), a); |
571 |
|
} |
572 |
|
|
576 |
– |
|
573 |
|
/** |
574 |
|
* getPool of executing task returns its pool |
575 |
|
*/ |
792 |
|
} |
793 |
|
|
794 |
|
/** |
795 |
< |
* invokeAll(collection) throws exception if any task does |
795 |
> |
* invokeAll(collection) throws exception if any task does |
796 |
|
*/ |
797 |
|
public void testAbnormalInvokeAllCollection() { |
798 |
|
RecursiveAction a = new CheckedRecursiveAction() { |
1369 |
|
} |
1370 |
|
|
1371 |
|
/** |
1372 |
< |
* invokeAll(collection) throws exception if any task does |
1372 |
> |
* invokeAll(collection) throws exception if any task does |
1373 |
|
*/ |
1374 |
|
public void testAbnormalInvokeAllCollectionSingleton() { |
1375 |
|
RecursiveAction a = new CheckedRecursiveAction() { |
1391 |
|
testInvokeOnPool(singletonPool(), a); |
1392 |
|
} |
1393 |
|
|
1398 |
– |
|
1394 |
|
/** |
1395 |
|
* ForkJoinTask.quietlyComplete returns when task completes |
1396 |
|
* normally without setting a value. The most recent value |