ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/CompletableFutureTest.java
Revision: 1.64
Committed: Fri Jun 6 17:08:48 2014 UTC (9 years, 11 months ago) by jsr166
Branch: MAIN
Changes since 1.63: +26 -27 lines
Log Message:
IncAction -> NoopConsumer

File Contents

# User Rev Content
1 jsr166 1.1 /*
2 jsr166 1.4 * Written by Doug Lea and Martin Buchholz with assistance from
3     * members of JCP JSR-166 Expert Group and released to the public
4     * domain, as explained at
5 jsr166 1.1 * http://creativecommons.org/publicdomain/zero/1.0/
6     */
7    
8     import junit.framework.*;
9     import java.util.concurrent.Callable;
10 dl 1.5 import java.util.concurrent.Executor;
11     import java.util.concurrent.ExecutorService;
12     import java.util.concurrent.Executors;
13 jsr166 1.1 import java.util.concurrent.CancellationException;
14     import java.util.concurrent.CountDownLatch;
15     import java.util.concurrent.ExecutionException;
16     import java.util.concurrent.Future;
17     import java.util.concurrent.CompletableFuture;
18 dl 1.5 import java.util.concurrent.CompletionException;
19 jsr166 1.35 import java.util.concurrent.CompletionStage;
20 jsr166 1.48 import java.util.concurrent.ForkJoinPool;
21     import java.util.concurrent.ForkJoinTask;
22 jsr166 1.1 import java.util.concurrent.TimeoutException;
23     import java.util.concurrent.atomic.AtomicInteger;
24     import static java.util.concurrent.TimeUnit.MILLISECONDS;
25     import static java.util.concurrent.TimeUnit.SECONDS;
26     import java.util.*;
27 dl 1.5 import java.util.function.Supplier;
28     import java.util.function.Consumer;
29     import java.util.function.BiConsumer;
30     import java.util.function.Function;
31     import java.util.function.BiFunction;
32 jsr166 1.1
33     public class CompletableFutureTest extends JSR166TestCase {
34    
35     public static void main(String[] args) {
36     junit.textui.TestRunner.run(suite());
37     }
38     public static Test suite() {
39     return new TestSuite(CompletableFutureTest.class);
40     }
41    
42 dl 1.5 static class CFException extends RuntimeException {}
43    
44 jsr166 1.4 void checkIncomplete(CompletableFuture<?> f) {
45     assertFalse(f.isDone());
46     assertFalse(f.isCancelled());
47     assertTrue(f.toString().contains("[Not completed]"));
48     try {
49     assertNull(f.getNow(null));
50     } catch (Throwable fail) { threadUnexpectedException(fail); }
51     try {
52     f.get(0L, SECONDS);
53     shouldThrow();
54     }
55     catch (TimeoutException success) {}
56     catch (Throwable fail) { threadUnexpectedException(fail); }
57     }
58    
59 jsr166 1.11 <T> void checkCompletedNormally(CompletableFuture<T> f, T value) {
60 jsr166 1.4 try {
61 jsr166 1.20 assertEquals(value, f.get(LONG_DELAY_MS, MILLISECONDS));
62     } catch (Throwable fail) { threadUnexpectedException(fail); }
63     try {
64 dl 1.5 assertEquals(value, f.join());
65 jsr166 1.4 } catch (Throwable fail) { threadUnexpectedException(fail); }
66     try {
67 dl 1.5 assertEquals(value, f.getNow(null));
68 jsr166 1.4 } catch (Throwable fail) { threadUnexpectedException(fail); }
69     try {
70 dl 1.5 assertEquals(value, f.get());
71 jsr166 1.4 } catch (Throwable fail) { threadUnexpectedException(fail); }
72 dl 1.5 assertTrue(f.isDone());
73     assertFalse(f.isCancelled());
74 dl 1.26 assertFalse(f.isCompletedExceptionally());
75 dl 1.5 assertTrue(f.toString().contains("[Completed normally]"));
76     }
77    
78     void checkCompletedWithWrappedCFException(CompletableFuture<?> f) {
79     try {
80 jsr166 1.20 f.get(LONG_DELAY_MS, MILLISECONDS);
81     shouldThrow();
82     } catch (ExecutionException success) {
83     assertTrue(success.getCause() instanceof CFException);
84     } catch (Throwable fail) { threadUnexpectedException(fail); }
85     try {
86 dl 1.5 f.join();
87     shouldThrow();
88 jsr166 1.8 } catch (CompletionException success) {
89     assertTrue(success.getCause() instanceof CFException);
90 dl 1.5 }
91     try {
92     f.getNow(null);
93     shouldThrow();
94 jsr166 1.8 } catch (CompletionException success) {
95     assertTrue(success.getCause() instanceof CFException);
96 dl 1.5 }
97     try {
98     f.get();
99     shouldThrow();
100 jsr166 1.8 } catch (ExecutionException success) {
101     assertTrue(success.getCause() instanceof CFException);
102     } catch (Throwable fail) { threadUnexpectedException(fail); }
103 dl 1.5 assertTrue(f.isDone());
104     assertFalse(f.isCancelled());
105 jsr166 1.14 assertTrue(f.toString().contains("[Completed exceptionally]"));
106 dl 1.5 }
107    
108 jsr166 1.33 void checkCompletedWithWrappedCFException(CompletableFuture<?> f,
109     CFException ex) {
110     try {
111     f.get(LONG_DELAY_MS, MILLISECONDS);
112     shouldThrow();
113     } catch (ExecutionException success) {
114     assertSame(ex, success.getCause());
115     } catch (Throwable fail) { threadUnexpectedException(fail); }
116     try {
117     f.join();
118     shouldThrow();
119     } catch (CompletionException success) {
120     assertSame(ex, success.getCause());
121     }
122     try {
123     f.getNow(null);
124     shouldThrow();
125     } catch (CompletionException success) {
126     assertSame(ex, success.getCause());
127     }
128     try {
129     f.get();
130     shouldThrow();
131     } catch (ExecutionException success) {
132     assertSame(ex, success.getCause());
133     } catch (Throwable fail) { threadUnexpectedException(fail); }
134     assertTrue(f.isDone());
135     assertFalse(f.isCancelled());
136     assertTrue(f.toString().contains("[Completed exceptionally]"));
137     }
138    
139 dl 1.5 void checkCancelled(CompletableFuture<?> f) {
140     try {
141 jsr166 1.20 f.get(LONG_DELAY_MS, MILLISECONDS);
142     shouldThrow();
143     } catch (CancellationException success) {
144     } catch (Throwable fail) { threadUnexpectedException(fail); }
145     try {
146 dl 1.5 f.join();
147     shouldThrow();
148 jsr166 1.8 } catch (CancellationException success) {}
149 dl 1.5 try {
150     f.getNow(null);
151     shouldThrow();
152 jsr166 1.8 } catch (CancellationException success) {}
153 dl 1.5 try {
154     f.get();
155     shouldThrow();
156 jsr166 1.8 } catch (CancellationException success) {
157     } catch (Throwable fail) { threadUnexpectedException(fail); }
158 dl 1.5 assertTrue(f.isDone());
159 dl 1.26 assertTrue(f.isCompletedExceptionally());
160 dl 1.5 assertTrue(f.isCancelled());
161 jsr166 1.14 assertTrue(f.toString().contains("[Completed exceptionally]"));
162 dl 1.5 }
163    
164     void checkCompletedWithWrappedCancellationException(CompletableFuture<?> f) {
165     try {
166 jsr166 1.20 f.get(LONG_DELAY_MS, MILLISECONDS);
167     shouldThrow();
168     } catch (ExecutionException success) {
169     assertTrue(success.getCause() instanceof CancellationException);
170     } catch (Throwable fail) { threadUnexpectedException(fail); }
171     try {
172 dl 1.5 f.join();
173     shouldThrow();
174 jsr166 1.8 } catch (CompletionException success) {
175     assertTrue(success.getCause() instanceof CancellationException);
176 dl 1.5 }
177     try {
178     f.getNow(null);
179     shouldThrow();
180 jsr166 1.8 } catch (CompletionException success) {
181     assertTrue(success.getCause() instanceof CancellationException);
182 dl 1.5 }
183     try {
184     f.get();
185     shouldThrow();
186 jsr166 1.8 } catch (ExecutionException success) {
187     assertTrue(success.getCause() instanceof CancellationException);
188     } catch (Throwable fail) { threadUnexpectedException(fail); }
189 dl 1.5 assertTrue(f.isDone());
190     assertFalse(f.isCancelled());
191 dl 1.26 assertTrue(f.isCompletedExceptionally());
192 jsr166 1.14 assertTrue(f.toString().contains("[Completed exceptionally]"));
193 dl 1.5 }
194    
195     /**
196     * A newly constructed CompletableFuture is incomplete, as indicated
197     * by methods isDone, isCancelled, and getNow
198     */
199     public void testConstructor() {
200 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
201 dl 1.5 checkIncomplete(f);
202     }
203    
204     /**
205     * complete completes normally, as indicated by methods isDone,
206     * isCancelled, join, get, and getNow
207     */
208     public void testComplete() {
209 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
210 dl 1.5 checkIncomplete(f);
211     f.complete(one);
212     checkCompletedNormally(f, one);
213     }
214    
215     /**
216     * completeExceptionally completes exceptionally, as indicated by
217     * methods isDone, isCancelled, join, get, and getNow
218     */
219     public void testCompleteExceptionally() {
220 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
221 dl 1.5 checkIncomplete(f);
222     f.completeExceptionally(new CFException());
223     checkCompletedWithWrappedCFException(f);
224     }
225    
226     /**
227     * cancel completes exceptionally and reports cancelled, as indicated by
228     * methods isDone, isCancelled, join, get, and getNow
229     */
230     public void testCancel() {
231 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
232 dl 1.5 checkIncomplete(f);
233     assertTrue(f.cancel(true));
234     checkCancelled(f);
235     }
236    
237     /**
238     * obtrudeValue forces completion with given value
239     */
240     public void testObtrudeValue() {
241 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
242 dl 1.5 checkIncomplete(f);
243     f.complete(one);
244     checkCompletedNormally(f, one);
245     f.obtrudeValue(three);
246     checkCompletedNormally(f, three);
247     f.obtrudeValue(two);
248     checkCompletedNormally(f, two);
249 jsr166 1.22 f = new CompletableFuture<>();
250 dl 1.5 f.obtrudeValue(three);
251     checkCompletedNormally(f, three);
252 jsr166 1.46 f.obtrudeValue(null);
253     checkCompletedNormally(f, null);
254 jsr166 1.22 f = new CompletableFuture<>();
255 dl 1.5 f.completeExceptionally(new CFException());
256     f.obtrudeValue(four);
257     checkCompletedNormally(f, four);
258 jsr166 1.4 }
259    
260 dl 1.5 /**
261     * obtrudeException forces completion with given exception
262     */
263     public void testObtrudeException() {
264 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
265 dl 1.5 checkIncomplete(f);
266     f.complete(one);
267     checkCompletedNormally(f, one);
268     f.obtrudeException(new CFException());
269     checkCompletedWithWrappedCFException(f);
270 jsr166 1.22 f = new CompletableFuture<>();
271 dl 1.5 f.obtrudeException(new CFException());
272     checkCompletedWithWrappedCFException(f);
273 jsr166 1.22 f = new CompletableFuture<>();
274 dl 1.5 f.completeExceptionally(new CFException());
275     f.obtrudeValue(four);
276     checkCompletedNormally(f, four);
277     f.obtrudeException(new CFException());
278     checkCompletedWithWrappedCFException(f);
279     }
280 jsr166 1.6
281 dl 1.5 /**
282     * getNumberOfDependents returns number of dependent tasks
283     */
284     public void testGetNumberOfDependents() {
285 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
286 jsr166 1.46 assertEquals(0, f.getNumberOfDependents());
287 jsr166 1.55 CompletableFuture g = f.thenRun(new Noop(ExecutionMode.DEFAULT));
288 jsr166 1.46 assertEquals(1, f.getNumberOfDependents());
289     assertEquals(0, g.getNumberOfDependents());
290 jsr166 1.55 CompletableFuture h = f.thenRun(new Noop(ExecutionMode.DEFAULT));
291 jsr166 1.46 assertEquals(2, f.getNumberOfDependents());
292 dl 1.5 f.complete(1);
293     checkCompletedNormally(g, null);
294 jsr166 1.46 assertEquals(0, f.getNumberOfDependents());
295     assertEquals(0, g.getNumberOfDependents());
296 jsr166 1.3 }
297    
298 dl 1.5 /**
299     * toString indicates current completion state
300     */
301 jsr166 1.1 public void testToString() {
302     CompletableFuture<String> f;
303 jsr166 1.2
304 jsr166 1.1 f = new CompletableFuture<String>();
305 jsr166 1.2 assertTrue(f.toString().contains("[Not completed]"));
306    
307 jsr166 1.1 f.complete("foo");
308     assertTrue(f.toString().contains("[Completed normally]"));
309 jsr166 1.2
310 jsr166 1.1 f = new CompletableFuture<String>();
311     f.completeExceptionally(new IndexOutOfBoundsException());
312     assertTrue(f.toString().contains("[Completed exceptionally]"));
313     }
314 jsr166 1.4
315 dl 1.9 /**
316 jsr166 1.10 * completedFuture returns a completed CompletableFuture with given value
317 dl 1.9 */
318     public void testCompletedFuture() {
319     CompletableFuture<String> f = CompletableFuture.completedFuture("test");
320     checkCompletedNormally(f, "test");
321     }
322    
323 jsr166 1.62 abstract class CheckedAction {
324     int invocationCount = 0;
325 jsr166 1.58 final ExecutionMode m;
326 jsr166 1.62 CheckedAction(ExecutionMode m) { this.m = m; }
327     void invoked() {
328     m.checkExecutionMode();
329     assertEquals(0, invocationCount++);
330     }
331     void assertNotInvoked() { assertEquals(0, invocationCount); }
332     void assertInvoked() { assertEquals(1, invocationCount); }
333     }
334    
335     abstract class CheckedIntegerAction extends CheckedAction {
336     Integer value;
337     CheckedIntegerAction(ExecutionMode m) { super(m); }
338     void assertValue(Integer expected) {
339     assertInvoked();
340     assertEquals(expected, value);
341     }
342     }
343    
344     class IntegerSupplier extends CheckedAction
345     implements Supplier<Integer>
346     {
347 jsr166 1.58 final Integer value;
348     IntegerSupplier(ExecutionMode m, Integer value) {
349 jsr166 1.62 super(m);
350 jsr166 1.58 this.value = value;
351     }
352     public Integer get() {
353 jsr166 1.62 invoked();
354 jsr166 1.58 return value;
355     }
356     }
357 jsr166 1.60
358     // A function that handles and produces null values as well.
359     static Integer inc(Integer x) {
360     return (x == null) ? null : x + 1;
361     }
362    
363 jsr166 1.64 class NoopConsumer extends CheckedIntegerAction
364 jsr166 1.62 implements Consumer<Integer>
365     {
366 jsr166 1.64 NoopConsumer(ExecutionMode m) { super(m); }
367 jsr166 1.38 public void accept(Integer x) {
368 jsr166 1.62 invoked();
369 jsr166 1.64 value = x;
370 jsr166 1.38 }
371     }
372 jsr166 1.62
373     class IncFunction extends CheckedIntegerAction
374     implements Function<Integer,Integer>
375     {
376     IncFunction(ExecutionMode m) { super(m); }
377 jsr166 1.38 public Integer apply(Integer x) {
378 jsr166 1.62 invoked();
379 jsr166 1.38 return value = inc(x);
380     }
381 dl 1.5 }
382 jsr166 1.60
383     // Choose non-commutative actions for better coverage
384     // A non-commutative function that handles and produces null values as well.
385     static Integer subtract(Integer x, Integer y) {
386     return (x == null && y == null) ? null :
387     ((x == null) ? 42 : x.intValue())
388     - ((y == null) ? 99 : y.intValue());
389     }
390    
391 jsr166 1.62 class SubtractAction extends CheckedIntegerAction
392     implements BiConsumer<Integer, Integer>
393     {
394     SubtractAction(ExecutionMode m) { super(m); }
395 jsr166 1.6 public void accept(Integer x, Integer y) {
396 jsr166 1.62 invoked();
397 jsr166 1.35 value = subtract(x, y);
398 dl 1.5 }
399     }
400 jsr166 1.62
401     class SubtractFunction extends CheckedIntegerAction
402     implements BiFunction<Integer, Integer, Integer>
403     {
404     SubtractFunction(ExecutionMode m) { super(m); }
405 jsr166 1.36 public Integer apply(Integer x, Integer y) {
406 jsr166 1.62 invoked();
407 jsr166 1.37 return value = subtract(x, y);
408 jsr166 1.36 }
409     }
410 jsr166 1.60
411 jsr166 1.62 class Noop extends CheckedAction implements Runnable {
412     Noop(ExecutionMode m) { super(m); }
413 jsr166 1.41 public void run() {
414 jsr166 1.62 invoked();
415 jsr166 1.41 }
416 dl 1.5 }
417    
418 jsr166 1.63 class FailingSupplier extends CheckedAction
419     implements Supplier<Integer>
420 jsr166 1.62 {
421     FailingSupplier(ExecutionMode m) { super(m); }
422 jsr166 1.44 public Integer get() {
423 jsr166 1.62 invoked();
424 jsr166 1.44 throw new CFException();
425     }
426 dl 1.5 }
427 jsr166 1.62
428 jsr166 1.63 class FailingConsumer extends CheckedIntegerAction
429     implements Consumer<Integer>
430     {
431 jsr166 1.62 FailingConsumer(ExecutionMode m) { super(m); }
432 jsr166 1.44 public void accept(Integer x) {
433 jsr166 1.62 invoked();
434 jsr166 1.63 value = x;
435 jsr166 1.44 throw new CFException();
436     }
437 dl 1.5 }
438 jsr166 1.62
439 jsr166 1.63 class FailingBiConsumer extends CheckedIntegerAction
440 jsr166 1.62 implements BiConsumer<Integer, Integer>
441     {
442     FailingBiConsumer(ExecutionMode m) { super(m); }
443 jsr166 1.44 public void accept(Integer x, Integer y) {
444 jsr166 1.62 invoked();
445 jsr166 1.63 value = subtract(x, y);
446 jsr166 1.44 throw new CFException();
447     }
448 dl 1.5 }
449 jsr166 1.62
450 jsr166 1.63 class FailingFunction extends CheckedIntegerAction
451 jsr166 1.62 implements Function<Integer, Integer>
452     {
453     FailingFunction(ExecutionMode m) { super(m); }
454 jsr166 1.44 public Integer apply(Integer x) {
455 jsr166 1.62 invoked();
456 jsr166 1.63 value = x;
457 jsr166 1.44 throw new CFException();
458     }
459 dl 1.5 }
460 jsr166 1.62
461 jsr166 1.63 class FailingBiFunction extends CheckedIntegerAction
462 jsr166 1.62 implements BiFunction<Integer, Integer, Integer>
463     {
464     FailingBiFunction(ExecutionMode m) { super(m); }
465 jsr166 1.44 public Integer apply(Integer x, Integer y) {
466 jsr166 1.62 invoked();
467 jsr166 1.63 value = subtract(x, y);
468 jsr166 1.44 throw new CFException();
469     }
470 dl 1.5 }
471 jsr166 1.62
472     class FailingRunnable extends CheckedAction implements Runnable {
473     FailingRunnable(ExecutionMode m) { super(m); }
474 jsr166 1.44 public void run() {
475 jsr166 1.62 invoked();
476 jsr166 1.44 throw new CFException();
477     }
478 dl 1.5 }
479    
480 jsr166 1.62
481 jsr166 1.63 class CompletableFutureInc extends CheckedIntegerAction
482 jsr166 1.62 implements Function<Integer, CompletableFuture<Integer>>
483     {
484     CompletableFutureInc(ExecutionMode m) { super(m); }
485 dl 1.5 public CompletableFuture<Integer> apply(Integer x) {
486 jsr166 1.62 invoked();
487 jsr166 1.63 value = x;
488 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
489 jsr166 1.44 f.complete(inc(x));
490 dl 1.5 return f;
491     }
492     }
493    
494 jsr166 1.63 class FailingCompletableFutureFunction extends CheckedIntegerAction
495 jsr166 1.62 implements Function<Integer, CompletableFuture<Integer>>
496     {
497     FailingCompletableFutureFunction(ExecutionMode m) { super(m); }
498 dl 1.5 public CompletableFuture<Integer> apply(Integer x) {
499 jsr166 1.62 invoked();
500 jsr166 1.63 value = x;
501 jsr166 1.44 throw new CFException();
502 dl 1.5 }
503     }
504 jsr166 1.6
505 dl 1.5 // Used for explicit executor tests
506     static final class ThreadExecutor implements Executor {
507 jsr166 1.56 final AtomicInteger count = new AtomicInteger(0);
508     static final ThreadGroup tg = new ThreadGroup("ThreadExecutor");
509     static boolean startedCurrentThread() {
510     return Thread.currentThread().getThreadGroup() == tg;
511     }
512 jsr166 1.17
513 dl 1.5 public void execute(Runnable r) {
514 jsr166 1.17 count.getAndIncrement();
515 jsr166 1.56 new Thread(tg, r).start();
516 dl 1.5 }
517     }
518    
519     /**
520 jsr166 1.35 * Permits the testing of parallel code for the 3 different
521 jsr166 1.60 * execution modes without copy/pasting all the test methods.
522 jsr166 1.35 */
523     enum ExecutionMode {
524     DEFAULT {
525 jsr166 1.48 public void checkExecutionMode() {
526 jsr166 1.60 assertFalse(ThreadExecutor.startedCurrentThread());
527 jsr166 1.48 assertNull(ForkJoinTask.getPool());
528     }
529 jsr166 1.57 public CompletableFuture<Void> runAsync(Runnable a) {
530     throw new UnsupportedOperationException();
531     }
532 jsr166 1.58 public <U> CompletableFuture<U> supplyAsync(Supplier<U> a) {
533     throw new UnsupportedOperationException();
534     }
535 jsr166 1.46 public <T> CompletableFuture<Void> thenRun
536     (CompletableFuture<T> f, Runnable a) {
537     return f.thenRun(a);
538     }
539     public <T> CompletableFuture<Void> thenAccept
540     (CompletableFuture<T> f, Consumer<? super T> a) {
541     return f.thenAccept(a);
542     }
543     public <T,U> CompletableFuture<U> thenApply
544     (CompletableFuture<T> f, Function<? super T,U> a) {
545     return f.thenApply(a);
546     }
547     public <T,U> CompletableFuture<U> thenCompose
548     (CompletableFuture<T> f,
549     Function<? super T,? extends CompletionStage<U>> a) {
550     return f.thenCompose(a);
551     }
552     public <T,U> CompletableFuture<U> handle
553     (CompletableFuture<T> f,
554     BiFunction<? super T,Throwable,? extends U> a) {
555     return f.handle(a);
556     }
557     public <T> CompletableFuture<T> whenComplete
558     (CompletableFuture<T> f,
559     BiConsumer<? super T,? super Throwable> a) {
560     return f.whenComplete(a);
561     }
562 jsr166 1.35 public <T,U> CompletableFuture<Void> runAfterBoth
563     (CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) {
564     return f.runAfterBoth(g, a);
565     }
566     public <T,U> CompletableFuture<Void> thenAcceptBoth
567     (CompletableFuture<T> f,
568     CompletionStage<? extends U> g,
569     BiConsumer<? super T,? super U> a) {
570     return f.thenAcceptBoth(g, a);
571     }
572 jsr166 1.36 public <T,U,V> CompletableFuture<V> thenCombine
573     (CompletableFuture<T> f,
574     CompletionStage<? extends U> g,
575     BiFunction<? super T,? super U,? extends V> a) {
576     return f.thenCombine(g, a);
577     }
578 jsr166 1.46 public <T> CompletableFuture<Void> runAfterEither
579 jsr166 1.38 (CompletableFuture<T> f,
580 jsr166 1.46 CompletionStage<?> g,
581     java.lang.Runnable a) {
582     return f.runAfterEither(g, a);
583 jsr166 1.38 }
584     public <T> CompletableFuture<Void> acceptEither
585     (CompletableFuture<T> f,
586     CompletionStage<? extends T> g,
587     Consumer<? super T> a) {
588     return f.acceptEither(g, a);
589     }
590 jsr166 1.46 public <T,U> CompletableFuture<U> applyToEither
591 jsr166 1.38 (CompletableFuture<T> f,
592 jsr166 1.46 CompletionStage<? extends T> g,
593     Function<? super T,U> a) {
594     return f.applyToEither(g, a);
595     }
596     },
597    
598 jsr166 1.48 ASYNC {
599     public void checkExecutionMode() {
600     assertSame(ForkJoinPool.commonPool(),
601     ForkJoinTask.getPool());
602     }
603 jsr166 1.57 public CompletableFuture<Void> runAsync(Runnable a) {
604     return CompletableFuture.runAsync(a);
605     }
606 jsr166 1.58 public <U> CompletableFuture<U> supplyAsync(Supplier<U> a) {
607     return CompletableFuture.supplyAsync(a);
608     }
609 jsr166 1.46 public <T> CompletableFuture<Void> thenRun
610     (CompletableFuture<T> f, Runnable a) {
611     return f.thenRunAsync(a);
612     }
613     public <T> CompletableFuture<Void> thenAccept
614     (CompletableFuture<T> f, Consumer<? super T> a) {
615     return f.thenAcceptAsync(a);
616     }
617     public <T,U> CompletableFuture<U> thenApply
618     (CompletableFuture<T> f, Function<? super T,U> a) {
619     return f.thenApplyAsync(a);
620 jsr166 1.38 }
621     public <T,U> CompletableFuture<U> thenCompose
622     (CompletableFuture<T> f,
623     Function<? super T,? extends CompletionStage<U>> a) {
624 jsr166 1.46 return f.thenComposeAsync(a);
625     }
626     public <T,U> CompletableFuture<U> handle
627     (CompletableFuture<T> f,
628     BiFunction<? super T,Throwable,? extends U> a) {
629     return f.handleAsync(a);
630 jsr166 1.38 }
631     public <T> CompletableFuture<T> whenComplete
632     (CompletableFuture<T> f,
633     BiConsumer<? super T,? super Throwable> a) {
634 jsr166 1.46 return f.whenCompleteAsync(a);
635 jsr166 1.38 }
636 jsr166 1.35 public <T,U> CompletableFuture<Void> runAfterBoth
637     (CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) {
638     return f.runAfterBothAsync(g, a);
639     }
640     public <T,U> CompletableFuture<Void> thenAcceptBoth
641     (CompletableFuture<T> f,
642     CompletionStage<? extends U> g,
643     BiConsumer<? super T,? super U> a) {
644     return f.thenAcceptBothAsync(g, a);
645     }
646 jsr166 1.36 public <T,U,V> CompletableFuture<V> thenCombine
647     (CompletableFuture<T> f,
648     CompletionStage<? extends U> g,
649     BiFunction<? super T,? super U,? extends V> a) {
650     return f.thenCombineAsync(g, a);
651     }
652 jsr166 1.46 public <T> CompletableFuture<Void> runAfterEither
653 jsr166 1.38 (CompletableFuture<T> f,
654 jsr166 1.46 CompletionStage<?> g,
655     java.lang.Runnable a) {
656     return f.runAfterEitherAsync(g, a);
657 jsr166 1.38 }
658     public <T> CompletableFuture<Void> acceptEither
659     (CompletableFuture<T> f,
660     CompletionStage<? extends T> g,
661     Consumer<? super T> a) {
662     return f.acceptEitherAsync(g, a);
663     }
664 jsr166 1.46 public <T,U> CompletableFuture<U> applyToEither
665 jsr166 1.38 (CompletableFuture<T> f,
666 jsr166 1.46 CompletionStage<? extends T> g,
667     Function<? super T,U> a) {
668     return f.applyToEitherAsync(g, a);
669     }
670     },
671    
672     EXECUTOR {
673 jsr166 1.48 public void checkExecutionMode() {
674 jsr166 1.56 assertTrue(ThreadExecutor.startedCurrentThread());
675 jsr166 1.48 }
676 jsr166 1.57 public CompletableFuture<Void> runAsync(Runnable a) {
677     return CompletableFuture.runAsync(a, new ThreadExecutor());
678     }
679 jsr166 1.58 public <U> CompletableFuture<U> supplyAsync(Supplier<U> a) {
680     return CompletableFuture.supplyAsync(a, new ThreadExecutor());
681     }
682 jsr166 1.46 public <T> CompletableFuture<Void> thenRun
683     (CompletableFuture<T> f, Runnable a) {
684     return f.thenRunAsync(a, new ThreadExecutor());
685     }
686     public <T> CompletableFuture<Void> thenAccept
687     (CompletableFuture<T> f, Consumer<? super T> a) {
688     return f.thenAcceptAsync(a, new ThreadExecutor());
689     }
690     public <T,U> CompletableFuture<U> thenApply
691     (CompletableFuture<T> f, Function<? super T,U> a) {
692     return f.thenApplyAsync(a, new ThreadExecutor());
693 jsr166 1.38 }
694     public <T,U> CompletableFuture<U> thenCompose
695     (CompletableFuture<T> f,
696     Function<? super T,? extends CompletionStage<U>> a) {
697 jsr166 1.46 return f.thenComposeAsync(a, new ThreadExecutor());
698     }
699     public <T,U> CompletableFuture<U> handle
700     (CompletableFuture<T> f,
701     BiFunction<? super T,Throwable,? extends U> a) {
702     return f.handleAsync(a, new ThreadExecutor());
703 jsr166 1.38 }
704     public <T> CompletableFuture<T> whenComplete
705     (CompletableFuture<T> f,
706     BiConsumer<? super T,? super Throwable> a) {
707 jsr166 1.46 return f.whenCompleteAsync(a, new ThreadExecutor());
708 jsr166 1.38 }
709 jsr166 1.35 public <T,U> CompletableFuture<Void> runAfterBoth
710     (CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) {
711     return f.runAfterBothAsync(g, a, new ThreadExecutor());
712     }
713     public <T,U> CompletableFuture<Void> thenAcceptBoth
714     (CompletableFuture<T> f,
715     CompletionStage<? extends U> g,
716     BiConsumer<? super T,? super U> a) {
717     return f.thenAcceptBothAsync(g, a, new ThreadExecutor());
718     }
719 jsr166 1.36 public <T,U,V> CompletableFuture<V> thenCombine
720     (CompletableFuture<T> f,
721     CompletionStage<? extends U> g,
722     BiFunction<? super T,? super U,? extends V> a) {
723     return f.thenCombineAsync(g, a, new ThreadExecutor());
724     }
725 jsr166 1.46 public <T> CompletableFuture<Void> runAfterEither
726 jsr166 1.38 (CompletableFuture<T> f,
727 jsr166 1.46 CompletionStage<?> g,
728     java.lang.Runnable a) {
729     return f.runAfterEitherAsync(g, a, new ThreadExecutor());
730 jsr166 1.38 }
731     public <T> CompletableFuture<Void> acceptEither
732     (CompletableFuture<T> f,
733     CompletionStage<? extends T> g,
734     Consumer<? super T> a) {
735     return f.acceptEitherAsync(g, a, new ThreadExecutor());
736     }
737 jsr166 1.46 public <T,U> CompletableFuture<U> applyToEither
738 jsr166 1.38 (CompletableFuture<T> f,
739 jsr166 1.46 CompletionStage<? extends T> g,
740     Function<? super T,U> a) {
741     return f.applyToEitherAsync(g, a, new ThreadExecutor());
742 jsr166 1.38 }
743 jsr166 1.35 };
744    
745 jsr166 1.48 public abstract void checkExecutionMode();
746 jsr166 1.57 public abstract CompletableFuture<Void> runAsync(Runnable a);
747 jsr166 1.58 public abstract <U> CompletableFuture<U> supplyAsync(Supplier<U> a);
748 jsr166 1.46 public abstract <T> CompletableFuture<Void> thenRun
749     (CompletableFuture<T> f, Runnable a);
750     public abstract <T> CompletableFuture<Void> thenAccept
751     (CompletableFuture<T> f, Consumer<? super T> a);
752     public abstract <T,U> CompletableFuture<U> thenApply
753     (CompletableFuture<T> f, Function<? super T,U> a);
754     public abstract <T,U> CompletableFuture<U> thenCompose
755     (CompletableFuture<T> f,
756     Function<? super T,? extends CompletionStage<U>> a);
757     public abstract <T,U> CompletableFuture<U> handle
758     (CompletableFuture<T> f,
759     BiFunction<? super T,Throwable,? extends U> a);
760     public abstract <T> CompletableFuture<T> whenComplete
761     (CompletableFuture<T> f,
762     BiConsumer<? super T,? super Throwable> a);
763 jsr166 1.35 public abstract <T,U> CompletableFuture<Void> runAfterBoth
764     (CompletableFuture<T> f, CompletableFuture<U> g, Runnable a);
765     public abstract <T,U> CompletableFuture<Void> thenAcceptBoth
766     (CompletableFuture<T> f,
767     CompletionStage<? extends U> g,
768     BiConsumer<? super T,? super U> a);
769 jsr166 1.36 public abstract <T,U,V> CompletableFuture<V> thenCombine
770     (CompletableFuture<T> f,
771     CompletionStage<? extends U> g,
772     BiFunction<? super T,? super U,? extends V> a);
773 jsr166 1.46 public abstract <T> CompletableFuture<Void> runAfterEither
774 jsr166 1.38 (CompletableFuture<T> f,
775 jsr166 1.46 CompletionStage<?> g,
776     java.lang.Runnable a);
777 jsr166 1.38 public abstract <T> CompletableFuture<Void> acceptEither
778     (CompletableFuture<T> f,
779     CompletionStage<? extends T> g,
780     Consumer<? super T> a);
781 jsr166 1.46 public abstract <T,U> CompletableFuture<U> applyToEither
782 jsr166 1.38 (CompletableFuture<T> f,
783 jsr166 1.46 CompletionStage<? extends T> g,
784     Function<? super T,U> a);
785     }
786    
787     /**
788     * exceptionally action is not invoked when source completes
789     * normally, and source result is propagated
790     */
791     public void testExceptionally_normalCompletion() {
792     for (boolean createIncomplete : new boolean[] { true, false })
793     for (Integer v1 : new Integer[] { 1, null })
794     {
795     final AtomicInteger a = new AtomicInteger(0);
796     final CompletableFuture<Integer> f = new CompletableFuture<>();
797     if (!createIncomplete) f.complete(v1);
798     final CompletableFuture<Integer> g = f.exceptionally
799     ((Throwable t) -> {
800     // Should not be called
801     a.getAndIncrement();
802     throw new AssertionError();
803     });
804     if (createIncomplete) f.complete(v1);
805 jsr166 1.38
806 jsr166 1.46 checkCompletedNormally(g, v1);
807     checkCompletedNormally(f, v1);
808     assertEquals(0, a.get());
809     }}
810 jsr166 1.38
811 jsr166 1.35
812     /**
813 dl 1.5 * exceptionally action completes with function value on source
814 jsr166 1.46 * exception
815     */
816     public void testExceptionally_exceptionalCompletion() {
817     for (boolean createIncomplete : new boolean[] { true, false })
818     for (Integer v1 : new Integer[] { 1, null })
819     {
820     final AtomicInteger a = new AtomicInteger(0);
821     final CFException ex = new CFException();
822     final CompletableFuture<Integer> f = new CompletableFuture<>();
823     if (!createIncomplete) f.completeExceptionally(ex);
824     final CompletableFuture<Integer> g = f.exceptionally
825     ((Throwable t) -> {
826 jsr166 1.57 ExecutionMode.DEFAULT.checkExecutionMode();
827 jsr166 1.46 threadAssertSame(t, ex);
828     a.getAndIncrement();
829     return v1;
830     });
831     if (createIncomplete) f.completeExceptionally(ex);
832    
833     checkCompletedNormally(g, v1);
834     assertEquals(1, a.get());
835     }}
836    
837     public void testExceptionally_exceptionalCompletionActionFailed() {
838     for (boolean createIncomplete : new boolean[] { true, false })
839     for (Integer v1 : new Integer[] { 1, null })
840     {
841     final AtomicInteger a = new AtomicInteger(0);
842     final CFException ex1 = new CFException();
843     final CFException ex2 = new CFException();
844     final CompletableFuture<Integer> f = new CompletableFuture<>();
845     if (!createIncomplete) f.completeExceptionally(ex1);
846     final CompletableFuture<Integer> g = f.exceptionally
847     ((Throwable t) -> {
848 jsr166 1.57 ExecutionMode.DEFAULT.checkExecutionMode();
849 jsr166 1.46 threadAssertSame(t, ex1);
850     a.getAndIncrement();
851     throw ex2;
852     });
853     if (createIncomplete) f.completeExceptionally(ex1);
854    
855     checkCompletedWithWrappedCFException(g, ex2);
856     assertEquals(1, a.get());
857     }}
858    
859     /**
860     * handle action completes normally with function value on normal
861     * completion of source
862     */
863     public void testHandle_normalCompletion() {
864     for (ExecutionMode m : ExecutionMode.values())
865     for (boolean createIncomplete : new boolean[] { true, false })
866     for (Integer v1 : new Integer[] { 1, null })
867     {
868     final CompletableFuture<Integer> f = new CompletableFuture<>();
869     final AtomicInteger a = new AtomicInteger(0);
870     if (!createIncomplete) f.complete(v1);
871     final CompletableFuture<Integer> g = m.handle
872     (f,
873     (Integer x, Throwable t) -> {
874 jsr166 1.57 m.checkExecutionMode();
875 jsr166 1.46 threadAssertSame(x, v1);
876     threadAssertNull(t);
877     a.getAndIncrement();
878     return inc(v1);
879     });
880     if (createIncomplete) f.complete(v1);
881    
882     checkCompletedNormally(g, inc(v1));
883     checkCompletedNormally(f, v1);
884     assertEquals(1, a.get());
885     }}
886    
887     /**
888     * handle action completes normally with function value on
889     * exceptional completion of source
890 dl 1.5 */
891 jsr166 1.46 public void testHandle_exceptionalCompletion() {
892     for (ExecutionMode m : ExecutionMode.values())
893     for (boolean createIncomplete : new boolean[] { true, false })
894     for (Integer v1 : new Integer[] { 1, null })
895     {
896     final CompletableFuture<Integer> f = new CompletableFuture<>();
897     final AtomicInteger a = new AtomicInteger(0);
898     final CFException ex = new CFException();
899     if (!createIncomplete) f.completeExceptionally(ex);
900     final CompletableFuture<Integer> g = m.handle
901     (f,
902     (Integer x, Throwable t) -> {
903 jsr166 1.57 m.checkExecutionMode();
904 jsr166 1.46 threadAssertNull(x);
905     threadAssertSame(t, ex);
906     a.getAndIncrement();
907     return v1;
908     });
909     if (createIncomplete) f.completeExceptionally(ex);
910 dl 1.5
911 jsr166 1.46 checkCompletedNormally(g, v1);
912     checkCompletedWithWrappedCFException(f, ex);
913     assertEquals(1, a.get());
914     }}
915 dl 1.5
916     /**
917 jsr166 1.46 * handle action completes normally with function value on
918     * cancelled source
919 dl 1.5 */
920 jsr166 1.46 public void testHandle_sourceCancelled() {
921     for (ExecutionMode m : ExecutionMode.values())
922     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
923     for (boolean createIncomplete : new boolean[] { true, false })
924     for (Integer v1 : new Integer[] { 1, null })
925     {
926     final CompletableFuture<Integer> f = new CompletableFuture<>();
927     final AtomicInteger a = new AtomicInteger(0);
928     if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
929     final CompletableFuture<Integer> g = m.handle
930     (f,
931     (Integer x, Throwable t) -> {
932 jsr166 1.57 m.checkExecutionMode();
933 jsr166 1.46 threadAssertNull(x);
934     threadAssertTrue(t instanceof CancellationException);
935     a.getAndIncrement();
936     return v1;
937     });
938     if (createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
939    
940     checkCompletedNormally(g, v1);
941     checkCancelled(f);
942     assertEquals(1, a.get());
943     }}
944 jsr166 1.15
945 jsr166 1.46 /**
946     * handle result completes exceptionally if action does
947     */
948     public void testHandle_sourceFailedActionFailed() {
949     for (ExecutionMode m : ExecutionMode.values())
950     for (boolean createIncomplete : new boolean[] { true, false })
951     {
952     final CompletableFuture<Integer> f = new CompletableFuture<>();
953     final AtomicInteger a = new AtomicInteger(0);
954     final CFException ex1 = new CFException();
955     final CFException ex2 = new CFException();
956     if (!createIncomplete) f.completeExceptionally(ex1);
957     final CompletableFuture<Integer> g = m.handle
958     (f,
959     (Integer x, Throwable t) -> {
960 jsr166 1.57 m.checkExecutionMode();
961 jsr166 1.46 threadAssertNull(x);
962     threadAssertSame(ex1, t);
963     a.getAndIncrement();
964     throw ex2;
965     });
966     if (createIncomplete) f.completeExceptionally(ex1);
967 dl 1.5
968 jsr166 1.46 checkCompletedWithWrappedCFException(g, ex2);
969     checkCompletedWithWrappedCFException(f, ex1);
970     assertEquals(1, a.get());
971     }}
972 jsr166 1.15
973 jsr166 1.46 public void testHandle_sourceCompletedNormallyActionFailed() {
974     for (ExecutionMode m : ExecutionMode.values())
975     for (boolean createIncomplete : new boolean[] { true, false })
976     for (Integer v1 : new Integer[] { 1, null })
977     {
978     final CompletableFuture<Integer> f = new CompletableFuture<>();
979     final AtomicInteger a = new AtomicInteger(0);
980     final CFException ex = new CFException();
981     if (!createIncomplete) f.complete(v1);
982     final CompletableFuture<Integer> g = m.handle
983     (f,
984     (Integer x, Throwable t) -> {
985 jsr166 1.57 m.checkExecutionMode();
986 jsr166 1.46 threadAssertSame(x, v1);
987     threadAssertNull(t);
988     a.getAndIncrement();
989     throw ex;
990     });
991     if (createIncomplete) f.complete(v1);
992 jsr166 1.15
993 jsr166 1.46 checkCompletedWithWrappedCFException(g, ex);
994     checkCompletedNormally(f, v1);
995     assertEquals(1, a.get());
996     }}
997 dl 1.5
998     /**
999     * runAsync completes after running Runnable
1000     */
1001 jsr166 1.57 public void testRunAsync_normalCompletion() {
1002     ExecutionMode[] executionModes = {
1003     ExecutionMode.ASYNC,
1004     ExecutionMode.EXECUTOR,
1005     };
1006     for (ExecutionMode m : executionModes)
1007     {
1008     final Noop r = new Noop(m);
1009     final CompletableFuture<Void> f = m.runAsync(r);
1010 dl 1.5 assertNull(f.join());
1011 jsr166 1.14 checkCompletedNormally(f, null);
1012 jsr166 1.62 r.assertInvoked();
1013 jsr166 1.57 }}
1014 dl 1.5
1015     /**
1016     * failing runAsync completes exceptionally after running Runnable
1017     */
1018 jsr166 1.57 public void testRunAsync_exceptionalCompletion() {
1019     ExecutionMode[] executionModes = {
1020     ExecutionMode.ASYNC,
1021     ExecutionMode.EXECUTOR,
1022     };
1023     for (ExecutionMode m : executionModes)
1024     {
1025     final FailingRunnable r = new FailingRunnable(m);
1026     final CompletableFuture<Void> f = m.runAsync(r);
1027 dl 1.5 checkCompletedWithWrappedCFException(f);
1028 jsr166 1.62 r.assertInvoked();
1029 jsr166 1.57 }}
1030 dl 1.5
1031     /**
1032     * supplyAsync completes with result of supplier
1033     */
1034 jsr166 1.58 public void testSupplyAsync_normalCompletion() {
1035     ExecutionMode[] executionModes = {
1036     ExecutionMode.ASYNC,
1037     ExecutionMode.EXECUTOR,
1038     };
1039     for (ExecutionMode m : executionModes)
1040     for (Integer v1 : new Integer[] { 1, null })
1041     {
1042     final IntegerSupplier r = new IntegerSupplier(m, v1);
1043     final CompletableFuture<Integer> f = m.supplyAsync(r);
1044     assertSame(v1, f.join());
1045     checkCompletedNormally(f, v1);
1046 jsr166 1.62 r.assertInvoked();
1047 jsr166 1.58 }}
1048 dl 1.5
1049     /**
1050     * Failing supplyAsync completes exceptionally
1051     */
1052 jsr166 1.58 public void testSupplyAsync_exceptionalCompletion() {
1053     ExecutionMode[] executionModes = {
1054     ExecutionMode.ASYNC,
1055     ExecutionMode.EXECUTOR,
1056     };
1057     for (ExecutionMode m : executionModes)
1058     {
1059     FailingSupplier r = new FailingSupplier(m);
1060     CompletableFuture<Integer> f = m.supplyAsync(r);
1061 dl 1.5 checkCompletedWithWrappedCFException(f);
1062 jsr166 1.62 r.assertInvoked();
1063 jsr166 1.58 }}
1064 dl 1.5
1065 jsr166 1.7 // seq completion methods
1066 jsr166 1.6
1067 dl 1.5 /**
1068     * thenRun result completes normally after normal completion of source
1069     */
1070 jsr166 1.48 public void testThenRun_normalCompletion() {
1071     for (ExecutionMode m : ExecutionMode.values())
1072     for (boolean createIncomplete : new boolean[] { true, false })
1073     for (Integer v1 : new Integer[] { 1, null })
1074     {
1075     final CompletableFuture<Integer> f = new CompletableFuture<>();
1076 jsr166 1.55 final Noop r = new Noop(m);
1077 jsr166 1.48 if (!createIncomplete) f.complete(v1);
1078     final CompletableFuture<Void> g = m.thenRun(f, r);
1079 jsr166 1.51 if (createIncomplete) {
1080     checkIncomplete(g);
1081     f.complete(v1);
1082     }
1083 jsr166 1.23
1084 dl 1.5 checkCompletedNormally(g, null);
1085 jsr166 1.48 checkCompletedNormally(f, v1);
1086 jsr166 1.62 r.assertInvoked();
1087 jsr166 1.48 }}
1088 dl 1.5
1089     /**
1090     * thenRun result completes exceptionally after exceptional
1091     * completion of source
1092     */
1093 jsr166 1.48 public void testThenRun_exceptionalCompletion() {
1094     for (ExecutionMode m : ExecutionMode.values())
1095     for (boolean createIncomplete : new boolean[] { true, false })
1096     {
1097     final CFException ex = new CFException();
1098     final CompletableFuture<Integer> f = new CompletableFuture<>();
1099 jsr166 1.55 final Noop r = new Noop(m);
1100 jsr166 1.48 if (!createIncomplete) f.completeExceptionally(ex);
1101     final CompletableFuture<Void> g = m.thenRun(f, r);
1102 jsr166 1.51 if (createIncomplete) {
1103     checkIncomplete(g);
1104     f.completeExceptionally(ex);
1105     }
1106 jsr166 1.23
1107 jsr166 1.48 checkCompletedWithWrappedCFException(g, ex);
1108     checkCompletedWithWrappedCFException(f, ex);
1109 jsr166 1.62 r.assertNotInvoked();
1110 jsr166 1.48 }}
1111    
1112     /**
1113     * thenRun result completes exceptionally if source cancelled
1114     */
1115     public void testThenRun_sourceCancelled() {
1116     for (ExecutionMode m : ExecutionMode.values())
1117     for (boolean createIncomplete : new boolean[] { true, false })
1118     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1119     {
1120     final CompletableFuture<Integer> f = new CompletableFuture<>();
1121 jsr166 1.55 final Noop r = new Noop(m);
1122 jsr166 1.48 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
1123 jsr166 1.56 final CompletableFuture<Void> g = m.thenRun(f, r);
1124 jsr166 1.51 if (createIncomplete) {
1125     checkIncomplete(g);
1126     assertTrue(f.cancel(mayInterruptIfRunning));
1127     }
1128 jsr166 1.23
1129 jsr166 1.48 checkCompletedWithWrappedCancellationException(g);
1130     checkCancelled(f);
1131 jsr166 1.62 r.assertNotInvoked();
1132 jsr166 1.48 }}
1133 dl 1.5
1134     /**
1135     * thenRun result completes exceptionally if action does
1136     */
1137 jsr166 1.48 public void testThenRun_actionFailed() {
1138     for (ExecutionMode m : ExecutionMode.values())
1139     for (boolean createIncomplete : new boolean[] { true, false })
1140     for (Integer v1 : new Integer[] { 1, null })
1141     {
1142     final CompletableFuture<Integer> f = new CompletableFuture<>();
1143 jsr166 1.56 final FailingRunnable r = new FailingRunnable(m);
1144 jsr166 1.48 if (!createIncomplete) f.complete(v1);
1145 jsr166 1.56 final CompletableFuture<Void> g = m.thenRun(f, r);
1146 jsr166 1.51 if (createIncomplete) {
1147     checkIncomplete(g);
1148     f.complete(v1);
1149     }
1150 jsr166 1.23
1151     checkCompletedWithWrappedCFException(g);
1152 jsr166 1.48 checkCompletedNormally(f, v1);
1153     }}
1154 dl 1.5
1155     /**
1156     * thenApply result completes normally after normal completion of source
1157     */
1158 jsr166 1.49 public void testThenApply_normalCompletion() {
1159     for (ExecutionMode m : ExecutionMode.values())
1160     for (boolean createIncomplete : new boolean[] { true, false })
1161     for (Integer v1 : new Integer[] { 1, null })
1162     {
1163     final CompletableFuture<Integer> f = new CompletableFuture<>();
1164 jsr166 1.56 final IncFunction r = new IncFunction(m);
1165 jsr166 1.49 if (!createIncomplete) f.complete(v1);
1166     final CompletableFuture<Integer> g = m.thenApply(f, r);
1167     if (createIncomplete) {
1168     checkIncomplete(g);
1169     f.complete(v1);
1170     }
1171    
1172     checkCompletedNormally(g, inc(v1));
1173     checkCompletedNormally(f, v1);
1174 jsr166 1.62 r.assertInvoked();
1175 jsr166 1.49 }}
1176 dl 1.5
1177     /**
1178     * thenApply result completes exceptionally after exceptional
1179     * completion of source
1180     */
1181 jsr166 1.49 public void testThenApply_exceptionalCompletion() {
1182     for (ExecutionMode m : ExecutionMode.values())
1183     for (boolean createIncomplete : new boolean[] { true, false })
1184     {
1185     final CFException ex = new CFException();
1186     final CompletableFuture<Integer> f = new CompletableFuture<>();
1187 jsr166 1.56 final IncFunction r = new IncFunction(m);
1188 jsr166 1.49 if (!createIncomplete) f.completeExceptionally(ex);
1189     final CompletableFuture<Integer> g = m.thenApply(f, r);
1190 jsr166 1.51 if (createIncomplete) {
1191     checkIncomplete(g);
1192     f.completeExceptionally(ex);
1193     }
1194 jsr166 1.49
1195     checkCompletedWithWrappedCFException(g, ex);
1196     checkCompletedWithWrappedCFException(f, ex);
1197 jsr166 1.62 r.assertNotInvoked();
1198 jsr166 1.49 }}
1199 dl 1.5
1200     /**
1201 jsr166 1.49 * thenApply result completes exceptionally if source cancelled
1202 dl 1.5 */
1203 jsr166 1.49 public void testThenApply_sourceCancelled() {
1204     for (ExecutionMode m : ExecutionMode.values())
1205     for (boolean createIncomplete : new boolean[] { true, false })
1206     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1207     {
1208     final CompletableFuture<Integer> f = new CompletableFuture<>();
1209 jsr166 1.56 final IncFunction r = new IncFunction(m);
1210 jsr166 1.49 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
1211 jsr166 1.56 final CompletableFuture<Integer> g = m.thenApply(f, r);
1212 jsr166 1.51 if (createIncomplete) {
1213     checkIncomplete(g);
1214     assertTrue(f.cancel(mayInterruptIfRunning));
1215     }
1216 jsr166 1.49
1217     checkCompletedWithWrappedCancellationException(g);
1218     checkCancelled(f);
1219 jsr166 1.62 r.assertNotInvoked();
1220 jsr166 1.49 }}
1221 dl 1.5
1222     /**
1223 jsr166 1.49 * thenApply result completes exceptionally if action does
1224 dl 1.5 */
1225 jsr166 1.49 public void testThenApply_actionFailed() {
1226     for (ExecutionMode m : ExecutionMode.values())
1227     for (boolean createIncomplete : new boolean[] { true, false })
1228     for (Integer v1 : new Integer[] { 1, null })
1229     {
1230     final CompletableFuture<Integer> f = new CompletableFuture<>();
1231 jsr166 1.56 final FailingFunction r = new FailingFunction(m);
1232 jsr166 1.49 if (!createIncomplete) f.complete(v1);
1233 jsr166 1.56 final CompletableFuture<Integer> g = m.thenApply(f, r);
1234 jsr166 1.51 if (createIncomplete) {
1235     checkIncomplete(g);
1236     f.complete(v1);
1237     }
1238 jsr166 1.49
1239     checkCompletedWithWrappedCFException(g);
1240     checkCompletedNormally(f, v1);
1241     }}
1242 dl 1.5
1243     /**
1244     * thenAccept result completes normally after normal completion of source
1245     */
1246 jsr166 1.50 public void testThenAccept_normalCompletion() {
1247     for (ExecutionMode m : ExecutionMode.values())
1248     for (boolean createIncomplete : new boolean[] { true, false })
1249     for (Integer v1 : new Integer[] { 1, null })
1250     {
1251     final CompletableFuture<Integer> f = new CompletableFuture<>();
1252 jsr166 1.64 final NoopConsumer r = new NoopConsumer(m);
1253 jsr166 1.50 if (!createIncomplete) f.complete(v1);
1254     final CompletableFuture<Void> g = m.thenAccept(f, r);
1255 jsr166 1.51 if (createIncomplete) {
1256     checkIncomplete(g);
1257     f.complete(v1);
1258     }
1259 jsr166 1.50
1260 dl 1.5 checkCompletedNormally(g, null);
1261 jsr166 1.64 r.assertValue(v1);
1262 jsr166 1.50 checkCompletedNormally(f, v1);
1263     }}
1264 dl 1.5
1265     /**
1266     * thenAccept result completes exceptionally after exceptional
1267     * completion of source
1268     */
1269 jsr166 1.50 public void testThenAccept_exceptionalCompletion() {
1270     for (ExecutionMode m : ExecutionMode.values())
1271     for (boolean createIncomplete : new boolean[] { true, false })
1272     {
1273     final CFException ex = new CFException();
1274     final CompletableFuture<Integer> f = new CompletableFuture<>();
1275 jsr166 1.64 final NoopConsumer r = new NoopConsumer(m);
1276 jsr166 1.50 if (!createIncomplete) f.completeExceptionally(ex);
1277     final CompletableFuture<Void> g = m.thenAccept(f, r);
1278 jsr166 1.51 if (createIncomplete) {
1279     checkIncomplete(g);
1280     f.completeExceptionally(ex);
1281     }
1282 jsr166 1.50
1283     checkCompletedWithWrappedCFException(g, ex);
1284     checkCompletedWithWrappedCFException(f, ex);
1285 jsr166 1.62 r.assertNotInvoked();
1286 jsr166 1.50 }}
1287 dl 1.5
1288     /**
1289 jsr166 1.61 * thenAccept result completes exceptionally if source cancelled
1290 dl 1.5 */
1291 jsr166 1.61 public void testThenAccept_sourceCancelled() {
1292 jsr166 1.50 for (ExecutionMode m : ExecutionMode.values())
1293     for (boolean createIncomplete : new boolean[] { true, false })
1294 jsr166 1.61 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1295 jsr166 1.50 {
1296     final CompletableFuture<Integer> f = new CompletableFuture<>();
1297 jsr166 1.64 final NoopConsumer r = new NoopConsumer(m);
1298 jsr166 1.61 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
1299 jsr166 1.56 final CompletableFuture<Void> g = m.thenAccept(f, r);
1300 jsr166 1.51 if (createIncomplete) {
1301     checkIncomplete(g);
1302 jsr166 1.61 assertTrue(f.cancel(mayInterruptIfRunning));
1303 jsr166 1.51 }
1304 jsr166 1.50
1305 jsr166 1.61 checkCompletedWithWrappedCancellationException(g);
1306     checkCancelled(f);
1307 jsr166 1.62 r.assertNotInvoked();
1308 jsr166 1.50 }}
1309 dl 1.5
1310     /**
1311 jsr166 1.61 * thenAccept result completes exceptionally if action does
1312 dl 1.5 */
1313 jsr166 1.61 public void testThenAccept_actionFailed() {
1314 jsr166 1.50 for (ExecutionMode m : ExecutionMode.values())
1315     for (boolean createIncomplete : new boolean[] { true, false })
1316 jsr166 1.61 for (Integer v1 : new Integer[] { 1, null })
1317 jsr166 1.50 {
1318     final CompletableFuture<Integer> f = new CompletableFuture<>();
1319 jsr166 1.61 final FailingConsumer r = new FailingConsumer(m);
1320     if (!createIncomplete) f.complete(v1);
1321 jsr166 1.56 final CompletableFuture<Void> g = m.thenAccept(f, r);
1322 jsr166 1.50 if (createIncomplete) {
1323     checkIncomplete(g);
1324 jsr166 1.61 f.complete(v1);
1325 jsr166 1.50 }
1326    
1327 jsr166 1.61 checkCompletedWithWrappedCFException(g);
1328     checkCompletedNormally(f, v1);
1329 jsr166 1.50 }}
1330 dl 1.5
1331     /**
1332 jsr166 1.18 * thenCombine result completes normally after normal completion
1333     * of sources
1334 dl 1.5 */
1335 jsr166 1.51 public void testThenCombine_normalCompletion() {
1336     for (ExecutionMode m : ExecutionMode.values())
1337 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
1338 jsr166 1.43 for (boolean fFirst : new boolean[] { true, false })
1339 jsr166 1.36 for (Integer v1 : new Integer[] { 1, null })
1340 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1341     {
1342 jsr166 1.36 final CompletableFuture<Integer> f = new CompletableFuture<>();
1343     final CompletableFuture<Integer> g = new CompletableFuture<>();
1344 jsr166 1.56 final SubtractFunction r = new SubtractFunction(m);
1345 jsr166 1.36
1346 jsr166 1.51 if (fFirst) f.complete(v1); else g.complete(v2);
1347     if (!createIncomplete)
1348     if (!fFirst) f.complete(v1); else g.complete(v2);
1349     final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1350     if (createIncomplete) {
1351     checkIncomplete(h);
1352 jsr166 1.62 r.assertNotInvoked();
1353 jsr166 1.51 if (!fFirst) f.complete(v1); else g.complete(v2);
1354     }
1355 jsr166 1.36
1356     checkCompletedNormally(h, subtract(v1, v2));
1357     checkCompletedNormally(f, v1);
1358     checkCompletedNormally(g, v2);
1359 jsr166 1.62 r.assertInvoked();
1360 jsr166 1.47 }}
1361 dl 1.5
1362     /**
1363     * thenCombine result completes exceptionally after exceptional
1364     * completion of either source
1365     */
1366 jsr166 1.52 public void testThenCombine_exceptionalCompletion() {
1367 jsr166 1.36 for (ExecutionMode m : ExecutionMode.values())
1368 jsr166 1.52 for (boolean createIncomplete : new boolean[] { true, false })
1369     for (boolean fFirst : new boolean[] { true, false })
1370 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1371     {
1372 jsr166 1.36 final CompletableFuture<Integer> f = new CompletableFuture<>();
1373     final CompletableFuture<Integer> g = new CompletableFuture<>();
1374     final CFException ex = new CFException();
1375 jsr166 1.56 final SubtractFunction r = new SubtractFunction(m);
1376 jsr166 1.18
1377 jsr166 1.52 (fFirst ? f : g).complete(v1);
1378     if (!createIncomplete)
1379     (!fFirst ? f : g).completeExceptionally(ex);
1380 jsr166 1.37 final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1381 jsr166 1.52 if (createIncomplete) {
1382     checkIncomplete(h);
1383     (!fFirst ? f : g).completeExceptionally(ex);
1384     }
1385 dl 1.5
1386 jsr166 1.36 checkCompletedWithWrappedCFException(h, ex);
1387 jsr166 1.62 r.assertNotInvoked();
1388 jsr166 1.52 checkCompletedNormally(fFirst ? f : g, v1);
1389     checkCompletedWithWrappedCFException(!fFirst ? f : g, ex);
1390 jsr166 1.47 }}
1391 dl 1.5
1392     /**
1393     * thenCombine result completes exceptionally if either source cancelled
1394     */
1395 jsr166 1.52 public void testThenCombine_sourceCancelled() {
1396 jsr166 1.36 for (ExecutionMode m : ExecutionMode.values())
1397     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1398 jsr166 1.52 for (boolean createIncomplete : new boolean[] { true, false })
1399     for (boolean fFirst : new boolean[] { true, false })
1400 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1401     {
1402 jsr166 1.36 final CompletableFuture<Integer> f = new CompletableFuture<>();
1403     final CompletableFuture<Integer> g = new CompletableFuture<>();
1404 jsr166 1.56 final SubtractFunction r = new SubtractFunction(m);
1405 jsr166 1.18
1406 jsr166 1.52 (fFirst ? f : g).complete(v1);
1407     if (!createIncomplete)
1408     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1409 jsr166 1.36 final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1410 jsr166 1.52 if (createIncomplete) {
1411     checkIncomplete(h);
1412     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1413     }
1414 jsr166 1.36
1415 jsr166 1.18 checkCompletedWithWrappedCancellationException(h);
1416 jsr166 1.52 checkCancelled(!fFirst ? f : g);
1417 jsr166 1.62 r.assertNotInvoked();
1418 jsr166 1.52 checkCompletedNormally(fFirst ? f : g, v1);
1419 jsr166 1.47 }}
1420 dl 1.5
1421     /**
1422 jsr166 1.61 * thenCombine result completes exceptionally if action does
1423     */
1424     public void testThenCombine_actionFailed() {
1425     for (ExecutionMode m : ExecutionMode.values())
1426     for (boolean fFirst : new boolean[] { true, false })
1427     for (Integer v1 : new Integer[] { 1, null })
1428     for (Integer v2 : new Integer[] { 2, null })
1429     {
1430     final CompletableFuture<Integer> f = new CompletableFuture<>();
1431     final CompletableFuture<Integer> g = new CompletableFuture<>();
1432     final FailingBiFunction r = new FailingBiFunction(m);
1433     final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1434    
1435     if (fFirst) {
1436     f.complete(v1);
1437     g.complete(v2);
1438     } else {
1439     g.complete(v2);
1440     f.complete(v1);
1441     }
1442    
1443     checkCompletedWithWrappedCFException(h);
1444     checkCompletedNormally(f, v1);
1445     checkCompletedNormally(g, v2);
1446     }}
1447    
1448     /**
1449 dl 1.5 * thenAcceptBoth result completes normally after normal
1450     * completion of sources
1451     */
1452 jsr166 1.53 public void testThenAcceptBoth_normalCompletion() {
1453 jsr166 1.35 for (ExecutionMode m : ExecutionMode.values())
1454 jsr166 1.53 for (boolean createIncomplete : new boolean[] { true, false })
1455     for (boolean fFirst : new boolean[] { true, false })
1456 jsr166 1.35 for (Integer v1 : new Integer[] { 1, null })
1457 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1458     {
1459 jsr166 1.35 final CompletableFuture<Integer> f = new CompletableFuture<>();
1460     final CompletableFuture<Integer> g = new CompletableFuture<>();
1461 jsr166 1.56 final SubtractAction r = new SubtractAction(m);
1462 jsr166 1.35
1463 jsr166 1.53 if (fFirst) f.complete(v1); else g.complete(v2);
1464     if (!createIncomplete)
1465     if (!fFirst) f.complete(v1); else g.complete(v2);
1466 jsr166 1.35 final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1467 jsr166 1.53 if (createIncomplete) {
1468     checkIncomplete(h);
1469 jsr166 1.62 r.assertNotInvoked();
1470 jsr166 1.53 if (!fFirst) f.complete(v1); else g.complete(v2);
1471     }
1472 dl 1.5
1473 jsr166 1.22 checkCompletedNormally(h, null);
1474 jsr166 1.62 r.assertValue(subtract(v1, v2));
1475 jsr166 1.35 checkCompletedNormally(f, v1);
1476     checkCompletedNormally(g, v2);
1477 jsr166 1.47 }}
1478 dl 1.5
1479     /**
1480     * thenAcceptBoth result completes exceptionally after exceptional
1481     * completion of either source
1482     */
1483 jsr166 1.53 public void testThenAcceptBoth_exceptionalCompletion() {
1484 jsr166 1.35 for (ExecutionMode m : ExecutionMode.values())
1485 jsr166 1.53 for (boolean createIncomplete : new boolean[] { true, false })
1486     for (boolean fFirst : new boolean[] { true, false })
1487 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1488     {
1489 jsr166 1.35 final CompletableFuture<Integer> f = new CompletableFuture<>();
1490     final CompletableFuture<Integer> g = new CompletableFuture<>();
1491     final CFException ex = new CFException();
1492 jsr166 1.56 final SubtractAction r = new SubtractAction(m);
1493 jsr166 1.35
1494 jsr166 1.53 (fFirst ? f : g).complete(v1);
1495     if (!createIncomplete)
1496     (!fFirst ? f : g).completeExceptionally(ex);
1497 jsr166 1.35 final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1498 jsr166 1.53 if (createIncomplete) {
1499     checkIncomplete(h);
1500     (!fFirst ? f : g).completeExceptionally(ex);
1501     }
1502 jsr166 1.35
1503     checkCompletedWithWrappedCFException(h, ex);
1504 jsr166 1.62 r.assertNotInvoked();
1505 jsr166 1.53 checkCompletedNormally(fFirst ? f : g, v1);
1506     checkCompletedWithWrappedCFException(!fFirst ? f : g, ex);
1507 jsr166 1.47 }}
1508 dl 1.5
1509     /**
1510     * thenAcceptBoth result completes exceptionally if either source cancelled
1511     */
1512 jsr166 1.53 public void testThenAcceptBoth_sourceCancelled() {
1513 jsr166 1.35 for (ExecutionMode m : ExecutionMode.values())
1514     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1515 jsr166 1.53 for (boolean createIncomplete : new boolean[] { true, false })
1516     for (boolean fFirst : new boolean[] { true, false })
1517 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1518     {
1519 jsr166 1.35 final CompletableFuture<Integer> f = new CompletableFuture<>();
1520     final CompletableFuture<Integer> g = new CompletableFuture<>();
1521 jsr166 1.56 final SubtractAction r = new SubtractAction(m);
1522 jsr166 1.35
1523 jsr166 1.53 (fFirst ? f : g).complete(v1);
1524     if (!createIncomplete)
1525     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1526 jsr166 1.35 final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1527 jsr166 1.53 if (createIncomplete) {
1528     checkIncomplete(h);
1529     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1530     }
1531 jsr166 1.22
1532     checkCompletedWithWrappedCancellationException(h);
1533 jsr166 1.53 checkCancelled(!fFirst ? f : g);
1534 jsr166 1.62 r.assertNotInvoked();
1535 jsr166 1.53 checkCompletedNormally(fFirst ? f : g, v1);
1536 jsr166 1.47 }}
1537 jsr166 1.34
1538     /**
1539 jsr166 1.61 * thenAcceptBoth result completes exceptionally if action does
1540     */
1541     public void testThenAcceptBoth_actionFailed() {
1542     for (ExecutionMode m : ExecutionMode.values())
1543     for (boolean fFirst : new boolean[] { true, false })
1544     for (Integer v1 : new Integer[] { 1, null })
1545     for (Integer v2 : new Integer[] { 2, null })
1546     {
1547     final CompletableFuture<Integer> f = new CompletableFuture<>();
1548     final CompletableFuture<Integer> g = new CompletableFuture<>();
1549     final FailingBiConsumer r = new FailingBiConsumer(m);
1550     final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1551    
1552     if (fFirst) {
1553     f.complete(v1);
1554     g.complete(v2);
1555     } else {
1556     g.complete(v2);
1557     f.complete(v1);
1558     }
1559    
1560     checkCompletedWithWrappedCFException(h);
1561     checkCompletedNormally(f, v1);
1562     checkCompletedNormally(g, v2);
1563     }}
1564    
1565     /**
1566 dl 1.5 * runAfterBoth result completes normally after normal
1567     * completion of sources
1568     */
1569 jsr166 1.54 public void testRunAfterBoth_normalCompletion() {
1570 jsr166 1.34 for (ExecutionMode m : ExecutionMode.values())
1571 jsr166 1.54 for (boolean createIncomplete : new boolean[] { true, false })
1572     for (boolean fFirst : new boolean[] { true, false })
1573 jsr166 1.33 for (Integer v1 : new Integer[] { 1, null })
1574 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1575     {
1576 jsr166 1.33 final CompletableFuture<Integer> f = new CompletableFuture<>();
1577     final CompletableFuture<Integer> g = new CompletableFuture<>();
1578 jsr166 1.55 final Noop r = new Noop(m);
1579 jsr166 1.33
1580 jsr166 1.54 if (fFirst) f.complete(v1); else g.complete(v2);
1581     if (!createIncomplete)
1582     if (!fFirst) f.complete(v1); else g.complete(v2);
1583 jsr166 1.34 final CompletableFuture<Void> h = m.runAfterBoth(f, g, r);
1584 jsr166 1.54 if (createIncomplete) {
1585     checkIncomplete(h);
1586 jsr166 1.62 r.assertNotInvoked();
1587 jsr166 1.54 if (!fFirst) f.complete(v1); else g.complete(v2);
1588     }
1589 dl 1.5
1590 jsr166 1.22 checkCompletedNormally(h, null);
1591 jsr166 1.62 r.assertInvoked();
1592 jsr166 1.33 checkCompletedNormally(f, v1);
1593     checkCompletedNormally(g, v2);
1594 jsr166 1.47 }}
1595 dl 1.5
1596     /**
1597     * runAfterBoth result completes exceptionally after exceptional
1598     * completion of either source
1599     */
1600 jsr166 1.54 public void testRunAfterBoth_exceptionalCompletion() {
1601 jsr166 1.34 for (ExecutionMode m : ExecutionMode.values())
1602 jsr166 1.54 for (boolean createIncomplete : new boolean[] { true, false })
1603     for (boolean fFirst : new boolean[] { true, false })
1604 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1605     {
1606 jsr166 1.33 final CompletableFuture<Integer> f = new CompletableFuture<>();
1607     final CompletableFuture<Integer> g = new CompletableFuture<>();
1608     final CFException ex = new CFException();
1609 jsr166 1.55 final Noop r = new Noop(m);
1610 jsr166 1.33
1611 jsr166 1.54 (fFirst ? f : g).complete(v1);
1612     if (!createIncomplete)
1613     (!fFirst ? f : g).completeExceptionally(ex);
1614 jsr166 1.34 final CompletableFuture<Void> h = m.runAfterBoth(f, g, r);
1615 jsr166 1.54 if (createIncomplete) {
1616     checkIncomplete(h);
1617     (!fFirst ? f : g).completeExceptionally(ex);
1618     }
1619 dl 1.5
1620 jsr166 1.33 checkCompletedWithWrappedCFException(h, ex);
1621 jsr166 1.62 r.assertNotInvoked();
1622 jsr166 1.54 checkCompletedNormally(fFirst ? f : g, v1);
1623     checkCompletedWithWrappedCFException(!fFirst ? f : g, ex);
1624 jsr166 1.47 }}
1625 dl 1.5
1626 jsr166 1.4 /**
1627 dl 1.5 * runAfterBoth result completes exceptionally if either source cancelled
1628 jsr166 1.4 */
1629 jsr166 1.54 public void testRunAfterBoth_sourceCancelled() {
1630 jsr166 1.34 for (ExecutionMode m : ExecutionMode.values())
1631 jsr166 1.33 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1632 jsr166 1.54 for (boolean createIncomplete : new boolean[] { true, false })
1633     for (boolean fFirst : new boolean[] { true, false })
1634 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1635     {
1636 jsr166 1.33 final CompletableFuture<Integer> f = new CompletableFuture<>();
1637     final CompletableFuture<Integer> g = new CompletableFuture<>();
1638 jsr166 1.55 final Noop r = new Noop(m);
1639 jsr166 1.33
1640    
1641 jsr166 1.54 (fFirst ? f : g).complete(v1);
1642     if (!createIncomplete)
1643     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1644 jsr166 1.34 final CompletableFuture<Void> h = m.runAfterBoth(f, g, r);
1645 jsr166 1.54 if (createIncomplete) {
1646     checkIncomplete(h);
1647     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1648     }
1649 jsr166 1.33
1650     checkCompletedWithWrappedCancellationException(h);
1651 jsr166 1.54 checkCancelled(!fFirst ? f : g);
1652 jsr166 1.62 r.assertNotInvoked();
1653 jsr166 1.54 checkCompletedNormally(fFirst ? f : g, v1);
1654 jsr166 1.47 }}
1655 dl 1.5
1656     /**
1657 jsr166 1.61 * runAfterBoth result completes exceptionally if action does
1658     */
1659     public void testRunAfterBoth_actionFailed() {
1660     for (ExecutionMode m : ExecutionMode.values())
1661     for (boolean fFirst : new boolean[] { true, false })
1662     for (Integer v1 : new Integer[] { 1, null })
1663     for (Integer v2 : new Integer[] { 2, null })
1664     {
1665     final CompletableFuture<Integer> f = new CompletableFuture<>();
1666     final CompletableFuture<Integer> g = new CompletableFuture<>();
1667 jsr166 1.62 final FailingRunnable r1 = new FailingRunnable(m);
1668     final FailingRunnable r2 = new FailingRunnable(m);
1669 jsr166 1.61
1670 jsr166 1.62 CompletableFuture<Void> h1 = m.runAfterBoth(f, g, r1);
1671 jsr166 1.61 if (fFirst) {
1672     f.complete(v1);
1673     g.complete(v2);
1674     } else {
1675     g.complete(v2);
1676     f.complete(v1);
1677     }
1678 jsr166 1.62 CompletableFuture<Void> h2 = m.runAfterBoth(f, g, r2);
1679 jsr166 1.61
1680     checkCompletedWithWrappedCFException(h1);
1681     checkCompletedWithWrappedCFException(h2);
1682     checkCompletedNormally(f, v1);
1683     checkCompletedNormally(g, v2);
1684     }}
1685    
1686     /**
1687 dl 1.5 * applyToEither result completes normally after normal completion
1688     * of either source
1689     */
1690 jsr166 1.54 public void testApplyToEither_normalCompletion() {
1691 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1692     for (Integer v1 : new Integer[] { 1, null })
1693 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1694     {
1695 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1696     final CompletableFuture<Integer> g = new CompletableFuture<>();
1697 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1698     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1699 jsr166 1.54
1700 jsr166 1.62 final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1701     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1702     checkIncomplete(h0);
1703     checkIncomplete(h1);
1704     rs[0].assertNotInvoked();
1705     rs[1].assertNotInvoked();
1706     f.complete(v1);
1707     checkCompletedNormally(h0, inc(v1));
1708     checkCompletedNormally(h1, inc(v1));
1709     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1710     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1711     checkCompletedNormally(h2, inc(v1));
1712     checkCompletedNormally(h3, inc(v1));
1713     g.complete(v2);
1714 jsr166 1.39
1715 jsr166 1.62 // unspecified behavior - both source completions available
1716     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1717     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1718     rs[4].assertValue(h4.join());
1719     rs[5].assertValue(h5.join());
1720     assertTrue(Objects.equals(inc(v1), h4.join()) ||
1721     Objects.equals(inc(v2), h4.join()));
1722     assertTrue(Objects.equals(inc(v1), h5.join()) ||
1723     Objects.equals(inc(v2), h5.join()));
1724 jsr166 1.39
1725     checkCompletedNormally(f, v1);
1726     checkCompletedNormally(g, v2);
1727 jsr166 1.62 checkCompletedNormally(h0, inc(v1));
1728     checkCompletedNormally(h1, inc(v1));
1729     checkCompletedNormally(h2, inc(v1));
1730     checkCompletedNormally(h3, inc(v1));
1731     for (int i = 0; i < 4; i++) rs[i].assertValue(inc(v1));
1732 jsr166 1.47 }}
1733 dl 1.5
1734     /**
1735     * applyToEither result completes exceptionally after exceptional
1736     * completion of either source
1737     */
1738 jsr166 1.62 public void testApplyToEither_exceptionalCompletion() {
1739 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1740 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1741     {
1742 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1743     final CompletableFuture<Integer> g = new CompletableFuture<>();
1744 jsr166 1.54 final CFException ex = new CFException();
1745 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1746     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1747    
1748     final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1749     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1750     checkIncomplete(h0);
1751     checkIncomplete(h1);
1752     rs[0].assertNotInvoked();
1753     rs[1].assertNotInvoked();
1754     f.completeExceptionally(ex);
1755     checkCompletedWithWrappedCFException(h0, ex);
1756     checkCompletedWithWrappedCFException(h1, ex);
1757     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1758     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1759     checkCompletedWithWrappedCFException(h2, ex);
1760     checkCompletedWithWrappedCFException(h3, ex);
1761     g.complete(v1);
1762 jsr166 1.54
1763 jsr166 1.62 // unspecified behavior - both source completions available
1764     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1765     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1766     try {
1767     assertEquals(inc(v1), h4.join());
1768     rs[4].assertInvoked();
1769     } catch (CompletionException ok) {
1770     checkCompletedWithWrappedCFException(h4, ex);
1771     rs[4].assertNotInvoked();
1772     }
1773     try {
1774     assertEquals(inc(v1), h5.join());
1775     rs[5].assertInvoked();
1776     } catch (CompletionException ok) {
1777     checkCompletedWithWrappedCFException(h5, ex);
1778     rs[5].assertNotInvoked();
1779 jsr166 1.54 }
1780 jsr166 1.39
1781 jsr166 1.62 checkCompletedWithWrappedCFException(f, ex);
1782     checkCompletedNormally(g, v1);
1783     checkCompletedWithWrappedCFException(h0, ex);
1784     checkCompletedWithWrappedCFException(h1, ex);
1785     checkCompletedWithWrappedCFException(h2, ex);
1786     checkCompletedWithWrappedCFException(h3, ex);
1787     checkCompletedWithWrappedCFException(h4, ex);
1788     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1789 jsr166 1.47 }}
1790 jsr166 1.39
1791 jsr166 1.62 /**
1792     * applyToEither result completes exceptionally if either source cancelled
1793     */
1794     public void testApplyToEither_sourceCancelled() {
1795 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1796 jsr166 1.62 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1797 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1798     {
1799 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1800     final CompletableFuture<Integer> g = new CompletableFuture<>();
1801 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1802     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1803    
1804     final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1805     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1806     checkIncomplete(h0);
1807     checkIncomplete(h1);
1808     rs[0].assertNotInvoked();
1809     rs[1].assertNotInvoked();
1810     f.cancel(mayInterruptIfRunning);
1811     checkCompletedWithWrappedCancellationException(h0);
1812     checkCompletedWithWrappedCancellationException(h1);
1813     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1814     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1815     checkCompletedWithWrappedCancellationException(h2);
1816     checkCompletedWithWrappedCancellationException(h3);
1817     g.complete(v1);
1818 jsr166 1.39
1819 jsr166 1.62 // unspecified behavior - both source completions available
1820     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1821     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1822 jsr166 1.39 try {
1823 jsr166 1.62 assertEquals(inc(v1), h4.join());
1824     rs[4].assertInvoked();
1825 jsr166 1.39 } catch (CompletionException ok) {
1826 jsr166 1.62 checkCompletedWithWrappedCancellationException(h4);
1827     rs[4].assertNotInvoked();
1828 jsr166 1.39 }
1829     try {
1830 jsr166 1.62 assertEquals(inc(v1), h5.join());
1831     rs[5].assertInvoked();
1832 jsr166 1.39 } catch (CompletionException ok) {
1833 jsr166 1.62 checkCompletedWithWrappedCancellationException(h5);
1834     rs[5].assertNotInvoked();
1835 jsr166 1.39 }
1836 dl 1.5
1837 jsr166 1.62 checkCancelled(f);
1838     checkCompletedNormally(g, v1);
1839     checkCompletedWithWrappedCancellationException(h0);
1840     checkCompletedWithWrappedCancellationException(h1);
1841     checkCompletedWithWrappedCancellationException(h2);
1842     checkCompletedWithWrappedCancellationException(h3);
1843     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1844 jsr166 1.47 }}
1845 dl 1.5
1846     /**
1847     * applyToEither result completes exceptionally if action does
1848     */
1849 jsr166 1.62 public void testApplyToEither_actionFailed() {
1850 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1851     for (Integer v1 : new Integer[] { 1, null })
1852 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1853     {
1854 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1855     final CompletableFuture<Integer> g = new CompletableFuture<>();
1856 jsr166 1.62 final FailingFunction[] rs = new FailingFunction[6];
1857     for (int i = 0; i < rs.length; i++) rs[i] = new FailingFunction(m);
1858 jsr166 1.39
1859 jsr166 1.62 final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1860     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1861 jsr166 1.39 f.complete(v1);
1862 jsr166 1.62 final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1863     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1864     checkCompletedWithWrappedCFException(h0);
1865     checkCompletedWithWrappedCFException(h1);
1866     checkCompletedWithWrappedCFException(h2);
1867     checkCompletedWithWrappedCFException(h3);
1868 jsr166 1.63 for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
1869    
1870     g.complete(v2);
1871    
1872     // unspecified behavior - both source completions available
1873     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1874     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1875    
1876 jsr166 1.62 checkCompletedWithWrappedCFException(h4);
1877 jsr166 1.63 assertTrue(Objects.equals(v1, rs[4].value) ||
1878     Objects.equals(v2, rs[4].value));
1879 jsr166 1.62 checkCompletedWithWrappedCFException(h5);
1880 jsr166 1.63 assertTrue(Objects.equals(v1, rs[5].value) ||
1881     Objects.equals(v2, rs[5].value));
1882    
1883     checkCompletedNormally(f, v1);
1884     checkCompletedNormally(g, v2);
1885 jsr166 1.47 }}
1886 dl 1.5
1887     /**
1888     * acceptEither result completes normally after normal completion
1889     * of either source
1890     */
1891 jsr166 1.63 public void testAcceptEither_normalCompletion() {
1892 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
1893     for (Integer v1 : new Integer[] { 1, null })
1894 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1895     {
1896 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
1897     final CompletableFuture<Integer> g = new CompletableFuture<>();
1898 jsr166 1.64 final NoopConsumer[] rs = new NoopConsumer[6];
1899     for (int i = 0; i < rs.length; i++) rs[i] = new NoopConsumer(m);
1900 jsr166 1.40
1901 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
1902     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
1903     checkIncomplete(h0);
1904     checkIncomplete(h1);
1905     rs[0].assertNotInvoked();
1906     rs[1].assertNotInvoked();
1907 jsr166 1.40 f.complete(v1);
1908 jsr166 1.63 checkCompletedNormally(h0, null);
1909     checkCompletedNormally(h1, null);
1910 jsr166 1.64 rs[0].assertValue(v1);
1911     rs[1].assertValue(v1);
1912 jsr166 1.63 final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
1913     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
1914     checkCompletedNormally(h2, null);
1915     checkCompletedNormally(h3, null);
1916 jsr166 1.64 rs[2].assertValue(v1);
1917     rs[3].assertValue(v1);
1918 jsr166 1.40 g.complete(v2);
1919    
1920 jsr166 1.63 // unspecified behavior - both source completions available
1921     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
1922     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
1923     checkCompletedNormally(h4, null);
1924     checkCompletedNormally(h5, null);
1925 jsr166 1.64 assertTrue(Objects.equals(v1, rs[4].value) ||
1926     Objects.equals(v2, rs[4].value));
1927     assertTrue(Objects.equals(v1, rs[5].value) ||
1928     Objects.equals(v2, rs[5].value));
1929 jsr166 1.40
1930     checkCompletedNormally(f, v1);
1931     checkCompletedNormally(g, v2);
1932 jsr166 1.63 checkCompletedNormally(h0, null);
1933     checkCompletedNormally(h1, null);
1934     checkCompletedNormally(h2, null);
1935     checkCompletedNormally(h3, null);
1936 jsr166 1.64 for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
1937 jsr166 1.47 }}
1938 dl 1.5
1939     /**
1940     * acceptEither result completes exceptionally after exceptional
1941     * completion of either source
1942     */
1943 jsr166 1.63 public void testAcceptEither_exceptionalCompletion() {
1944 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
1945 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1946     {
1947 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
1948     final CompletableFuture<Integer> g = new CompletableFuture<>();
1949     final CFException ex = new CFException();
1950 jsr166 1.64 final NoopConsumer[] rs = new NoopConsumer[6];
1951     for (int i = 0; i < rs.length; i++) rs[i] = new NoopConsumer(m);
1952 jsr166 1.40
1953 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
1954     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
1955     checkIncomplete(h0);
1956     checkIncomplete(h1);
1957     rs[0].assertNotInvoked();
1958     rs[1].assertNotInvoked();
1959 jsr166 1.40 f.completeExceptionally(ex);
1960 jsr166 1.63 checkCompletedWithWrappedCFException(h0, ex);
1961     checkCompletedWithWrappedCFException(h1, ex);
1962     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
1963     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
1964     checkCompletedWithWrappedCFException(h2, ex);
1965     checkCompletedWithWrappedCFException(h3, ex);
1966    
1967 jsr166 1.40 g.complete(v1);
1968    
1969 jsr166 1.63 // unspecified behavior - both source completions available
1970     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
1971     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
1972 jsr166 1.40 try {
1973 jsr166 1.63 assertNull(h4.join());
1974 jsr166 1.64 rs[4].assertValue(v1);
1975 jsr166 1.40 } catch (CompletionException ok) {
1976 jsr166 1.63 checkCompletedWithWrappedCFException(h4, ex);
1977     rs[4].assertNotInvoked();
1978 jsr166 1.40 }
1979     try {
1980 jsr166 1.63 assertNull(h5.join());
1981 jsr166 1.64 rs[5].assertValue(v1);
1982 jsr166 1.40 } catch (CompletionException ok) {
1983 jsr166 1.63 checkCompletedWithWrappedCFException(h5, ex);
1984     rs[5].assertNotInvoked();
1985 jsr166 1.40 }
1986 dl 1.5
1987 jsr166 1.40 checkCompletedWithWrappedCFException(f, ex);
1988     checkCompletedNormally(g, v1);
1989 jsr166 1.63 checkCompletedWithWrappedCFException(h0, ex);
1990     checkCompletedWithWrappedCFException(h1, ex);
1991     checkCompletedWithWrappedCFException(h2, ex);
1992     checkCompletedWithWrappedCFException(h3, ex);
1993     checkCompletedWithWrappedCFException(h4, ex);
1994     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1995 jsr166 1.47 }}
1996 dl 1.5
1997     /**
1998     * acceptEither result completes exceptionally if either source cancelled
1999     */
2000 jsr166 1.63 public void testAcceptEither_sourceCancelled() {
2001 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2002     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2003 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2004     {
2005 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2006     final CompletableFuture<Integer> g = new CompletableFuture<>();
2007 jsr166 1.64 final NoopConsumer[] rs = new NoopConsumer[6];
2008     for (int i = 0; i < rs.length; i++) rs[i] = new NoopConsumer(m);
2009 jsr166 1.63
2010     final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
2011     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
2012     checkIncomplete(h0);
2013     checkIncomplete(h1);
2014     rs[0].assertNotInvoked();
2015     rs[1].assertNotInvoked();
2016     f.cancel(mayInterruptIfRunning);
2017     checkCompletedWithWrappedCancellationException(h0);
2018     checkCompletedWithWrappedCancellationException(h1);
2019     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2020     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2021     checkCompletedWithWrappedCancellationException(h2);
2022     checkCompletedWithWrappedCancellationException(h3);
2023 jsr166 1.40
2024     g.complete(v1);
2025    
2026 jsr166 1.63 // unspecified behavior - both source completions available
2027     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
2028     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
2029     try {
2030     assertNull(h4.join());
2031 jsr166 1.64 rs[4].assertValue(v1);
2032 jsr166 1.63 } catch (CompletionException ok) {
2033     checkCompletedWithWrappedCancellationException(h4);
2034     rs[4].assertNotInvoked();
2035     }
2036     try {
2037     assertNull(h5.join());
2038 jsr166 1.64 rs[5].assertValue(v1);
2039 jsr166 1.63 } catch (CompletionException ok) {
2040     checkCompletedWithWrappedCancellationException(h5);
2041     rs[5].assertNotInvoked();
2042     }
2043    
2044 jsr166 1.40 checkCancelled(f);
2045     checkCompletedNormally(g, v1);
2046 jsr166 1.63 checkCompletedWithWrappedCancellationException(h0);
2047     checkCompletedWithWrappedCancellationException(h1);
2048     checkCompletedWithWrappedCancellationException(h2);
2049     checkCompletedWithWrappedCancellationException(h3);
2050     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
2051 jsr166 1.47 }}
2052 jsr166 1.40
2053 jsr166 1.63 /**
2054     * acceptEither result completes exceptionally if action does
2055     */
2056     public void testAcceptEither_actionFailed() {
2057 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2058 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2059 jsr166 1.63 for (Integer v2 : new Integer[] { 2, null })
2060 jsr166 1.47 {
2061 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2062     final CompletableFuture<Integer> g = new CompletableFuture<>();
2063 jsr166 1.63 final FailingConsumer[] rs = new FailingConsumer[6];
2064     for (int i = 0; i < rs.length; i++) rs[i] = new FailingConsumer(m);
2065 jsr166 1.40
2066 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
2067     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
2068 jsr166 1.40 f.complete(v1);
2069 jsr166 1.63 final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2070     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2071     checkCompletedWithWrappedCFException(h0);
2072     checkCompletedWithWrappedCFException(h1);
2073     checkCompletedWithWrappedCFException(h2);
2074     checkCompletedWithWrappedCFException(h3);
2075     for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
2076 jsr166 1.40
2077 jsr166 1.63 g.complete(v2);
2078 jsr166 1.40
2079 jsr166 1.63 // unspecified behavior - both source completions available
2080     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
2081     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
2082 jsr166 1.40
2083 jsr166 1.63 checkCompletedWithWrappedCFException(h4);
2084     assertTrue(Objects.equals(v1, rs[4].value) ||
2085     Objects.equals(v2, rs[4].value));
2086     checkCompletedWithWrappedCFException(h5);
2087     assertTrue(Objects.equals(v1, rs[5].value) ||
2088     Objects.equals(v2, rs[5].value));
2089 jsr166 1.40
2090     checkCompletedNormally(f, v1);
2091 jsr166 1.63 checkCompletedNormally(g, v2);
2092 jsr166 1.47 }}
2093 dl 1.5
2094     /**
2095     * runAfterEither result completes normally after normal completion
2096     * of either source
2097     */
2098 jsr166 1.41 public void testRunAfterEither_normalCompletion1() {
2099     for (ExecutionMode m : ExecutionMode.values())
2100     for (Integer v1 : new Integer[] { 1, null })
2101 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2102     {
2103 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2104     final CompletableFuture<Integer> g = new CompletableFuture<>();
2105 jsr166 1.55 final Noop r = new Noop(m);
2106 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2107    
2108     f.complete(v1);
2109     checkCompletedNormally(h, null);
2110 jsr166 1.62 r.assertInvoked();
2111 jsr166 1.41 g.complete(v2);
2112    
2113     checkCompletedNormally(f, v1);
2114     checkCompletedNormally(g, v2);
2115     checkCompletedNormally(h, null);
2116 jsr166 1.62 r.assertInvoked();
2117 jsr166 1.47 }}
2118 jsr166 1.41
2119     public void testRunAfterEither_normalCompletion2() {
2120     for (ExecutionMode m : ExecutionMode.values())
2121     for (Integer v1 : new Integer[] { 1, null })
2122 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2123     {
2124 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2125     final CompletableFuture<Integer> g = new CompletableFuture<>();
2126 jsr166 1.55 final Noop r = new Noop(m);
2127 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2128    
2129     g.complete(v2);
2130     checkCompletedNormally(h, null);
2131 jsr166 1.62 r.assertInvoked();
2132 jsr166 1.41 f.complete(v1);
2133    
2134     checkCompletedNormally(f, v1);
2135     checkCompletedNormally(g, v2);
2136     checkCompletedNormally(h, null);
2137 jsr166 1.62 r.assertInvoked();
2138 jsr166 1.47 }}
2139    
2140 jsr166 1.41 public void testRunAfterEither_normalCompletion3() {
2141     for (ExecutionMode m : ExecutionMode.values())
2142     for (Integer v1 : new Integer[] { 1, null })
2143 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2144     {
2145 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2146     final CompletableFuture<Integer> g = new CompletableFuture<>();
2147 jsr166 1.55 final Noop r = new Noop(m);
2148 jsr166 1.41
2149     f.complete(v1);
2150     g.complete(v2);
2151     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2152 dl 1.5
2153 jsr166 1.41 checkCompletedNormally(h, null);
2154     checkCompletedNormally(f, v1);
2155     checkCompletedNormally(g, v2);
2156 jsr166 1.62 r.assertInvoked();
2157 jsr166 1.47 }}
2158 dl 1.5
2159     /**
2160     * runAfterEither result completes exceptionally after exceptional
2161     * completion of either source
2162     */
2163 jsr166 1.41 public void testRunAfterEither_exceptionalCompletion1() {
2164     for (ExecutionMode m : ExecutionMode.values())
2165 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2166     {
2167 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2168     final CompletableFuture<Integer> g = new CompletableFuture<>();
2169 jsr166 1.55 final Noop r = new Noop(m);
2170 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2171     final CFException ex = new CFException();
2172    
2173     f.completeExceptionally(ex);
2174     checkCompletedWithWrappedCFException(h, ex);
2175     g.complete(v1);
2176    
2177 jsr166 1.62 r.assertNotInvoked();
2178 jsr166 1.41 checkCompletedNormally(g, v1);
2179     checkCompletedWithWrappedCFException(f, ex);
2180     checkCompletedWithWrappedCFException(h, ex);
2181 jsr166 1.47 }}
2182 jsr166 1.41
2183     public void testRunAfterEither_exceptionalCompletion2() {
2184     for (ExecutionMode m : ExecutionMode.values())
2185 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2186     {
2187 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2188     final CompletableFuture<Integer> g = new CompletableFuture<>();
2189 jsr166 1.55 final Noop r = new Noop(m);
2190 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2191     final CFException ex = new CFException();
2192    
2193     g.completeExceptionally(ex);
2194     checkCompletedWithWrappedCFException(h, ex);
2195     f.complete(v1);
2196    
2197 jsr166 1.62 r.assertNotInvoked();
2198 jsr166 1.41 checkCompletedNormally(f, v1);
2199     checkCompletedWithWrappedCFException(g, ex);
2200     checkCompletedWithWrappedCFException(h, ex);
2201 jsr166 1.47 }}
2202 jsr166 1.41
2203     public void testRunAfterEither_exceptionalCompletion3() {
2204     for (ExecutionMode m : ExecutionMode.values())
2205 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2206     {
2207 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2208     final CompletableFuture<Integer> g = new CompletableFuture<>();
2209 jsr166 1.55 final Noop r = new Noop(m);
2210 jsr166 1.41 final CFException ex = new CFException();
2211    
2212     g.completeExceptionally(ex);
2213     f.complete(v1);
2214     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2215    
2216     // unspecified behavior
2217     Integer v;
2218     try {
2219 jsr166 1.46 assertNull(h.join());
2220 jsr166 1.62 r.assertInvoked();
2221 jsr166 1.41 } catch (CompletionException ok) {
2222     checkCompletedWithWrappedCFException(h, ex);
2223 jsr166 1.62 r.assertNotInvoked();
2224 jsr166 1.41 }
2225    
2226     checkCompletedWithWrappedCFException(g, ex);
2227     checkCompletedNormally(f, v1);
2228 jsr166 1.47 }}
2229 jsr166 1.41
2230     public void testRunAfterEither_exceptionalCompletion4() {
2231     for (ExecutionMode m : ExecutionMode.values())
2232 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2233     {
2234 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2235     final CompletableFuture<Integer> g = new CompletableFuture<>();
2236 jsr166 1.55 final Noop r = new Noop(m);
2237 jsr166 1.41 final CFException ex = new CFException();
2238    
2239     f.completeExceptionally(ex);
2240     g.complete(v1);
2241     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2242    
2243     // unspecified behavior
2244     Integer v;
2245     try {
2246 jsr166 1.46 assertNull(h.join());
2247 jsr166 1.62 r.assertInvoked();
2248 jsr166 1.41 } catch (CompletionException ok) {
2249     checkCompletedWithWrappedCFException(h, ex);
2250 jsr166 1.62 r.assertNotInvoked();
2251 jsr166 1.41 }
2252 dl 1.5
2253 jsr166 1.41 checkCompletedWithWrappedCFException(f, ex);
2254     checkCompletedNormally(g, v1);
2255 jsr166 1.47 }}
2256 dl 1.5
2257     /**
2258     * runAfterEither result completes exceptionally if action does
2259     */
2260 jsr166 1.41 public void testRunAfterEither_actionFailed1() {
2261     for (ExecutionMode m : ExecutionMode.values())
2262     for (Integer v1 : new Integer[] { 1, null })
2263 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2264     {
2265 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2266     final CompletableFuture<Integer> g = new CompletableFuture<>();
2267 jsr166 1.56 final FailingRunnable r = new FailingRunnable(m);
2268 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2269    
2270     f.complete(v1);
2271     checkCompletedWithWrappedCFException(h);
2272     g.complete(v2);
2273     checkCompletedNormally(f, v1);
2274     checkCompletedNormally(g, v2);
2275 jsr166 1.47 }}
2276 jsr166 1.41
2277     public void testRunAfterEither_actionFailed2() {
2278     for (ExecutionMode m : ExecutionMode.values())
2279     for (Integer v1 : new Integer[] { 1, null })
2280 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2281     {
2282 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2283     final CompletableFuture<Integer> g = new CompletableFuture<>();
2284 jsr166 1.56 final FailingRunnable r = new FailingRunnable(m);
2285 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2286    
2287     g.complete(v2);
2288     checkCompletedWithWrappedCFException(h);
2289     f.complete(v1);
2290     checkCompletedNormally(f, v1);
2291     checkCompletedNormally(g, v2);
2292 jsr166 1.47 }}
2293 dl 1.5
2294     /**
2295     * runAfterEither result completes exceptionally if either source cancelled
2296     */
2297 jsr166 1.41 public void testRunAfterEither_sourceCancelled1() {
2298     for (ExecutionMode m : ExecutionMode.values())
2299     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2300 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2301     {
2302 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2303     final CompletableFuture<Integer> g = new CompletableFuture<>();
2304 jsr166 1.55 final Noop r = new Noop(m);
2305 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2306    
2307     assertTrue(f.cancel(mayInterruptIfRunning));
2308     checkCompletedWithWrappedCancellationException(h);
2309     g.complete(v1);
2310    
2311     checkCancelled(f);
2312 jsr166 1.62 r.assertNotInvoked();
2313 jsr166 1.41 checkCompletedNormally(g, v1);
2314     checkCompletedWithWrappedCancellationException(h);
2315 jsr166 1.47 }}
2316 jsr166 1.41
2317     public void testRunAfterEither_sourceCancelled2() {
2318     for (ExecutionMode m : ExecutionMode.values())
2319     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2320 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2321     {
2322 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2323     final CompletableFuture<Integer> g = new CompletableFuture<>();
2324 jsr166 1.55 final Noop r = new Noop(m);
2325 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2326    
2327     assertTrue(g.cancel(mayInterruptIfRunning));
2328     checkCompletedWithWrappedCancellationException(h);
2329     f.complete(v1);
2330    
2331     checkCancelled(g);
2332 jsr166 1.62 r.assertNotInvoked();
2333 jsr166 1.41 checkCompletedNormally(f, v1);
2334     checkCompletedWithWrappedCancellationException(h);
2335 jsr166 1.47 }}
2336 jsr166 1.41
2337     public void testRunAfterEither_sourceCancelled3() {
2338     for (ExecutionMode m : ExecutionMode.values())
2339     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2340 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2341     {
2342 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2343     final CompletableFuture<Integer> g = new CompletableFuture<>();
2344 jsr166 1.55 final Noop r = new Noop(m);
2345 jsr166 1.41
2346     assertTrue(g.cancel(mayInterruptIfRunning));
2347     f.complete(v1);
2348     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2349    
2350     // unspecified behavior
2351     Integer v;
2352     try {
2353 jsr166 1.46 assertNull(h.join());
2354 jsr166 1.62 r.assertInvoked();
2355 jsr166 1.41 } catch (CompletionException ok) {
2356     checkCompletedWithWrappedCancellationException(h);
2357 jsr166 1.62 r.assertNotInvoked();
2358 jsr166 1.41 }
2359    
2360     checkCancelled(g);
2361     checkCompletedNormally(f, v1);
2362 jsr166 1.47 }}
2363 jsr166 1.41
2364     public void testRunAfterEither_sourceCancelled4() {
2365     for (ExecutionMode m : ExecutionMode.values())
2366     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2367 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2368     {
2369 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2370     final CompletableFuture<Integer> g = new CompletableFuture<>();
2371 jsr166 1.55 final Noop r = new Noop(m);
2372 jsr166 1.41
2373     assertTrue(f.cancel(mayInterruptIfRunning));
2374     g.complete(v1);
2375     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2376    
2377     // unspecified behavior
2378     Integer v;
2379     try {
2380 jsr166 1.46 assertNull(h.join());
2381 jsr166 1.62 r.assertInvoked();
2382 jsr166 1.41 } catch (CompletionException ok) {
2383     checkCompletedWithWrappedCancellationException(h);
2384 jsr166 1.62 r.assertNotInvoked();
2385 jsr166 1.41 }
2386    
2387     checkCancelled(f);
2388     checkCompletedNormally(g, v1);
2389 jsr166 1.47 }}
2390 dl 1.5
2391     /**
2392     * thenCompose result completes normally after normal completion of source
2393     */
2394 jsr166 1.48 public void testThenCompose_normalCompletion() {
2395 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2396 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2397 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2398     {
2399 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2400 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2401 jsr166 1.48 if (!createIncomplete) f.complete(v1);
2402 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2403 jsr166 1.48 if (createIncomplete) f.complete(v1);
2404 jsr166 1.21
2405 jsr166 1.44 checkCompletedNormally(g, inc(v1));
2406     checkCompletedNormally(f, v1);
2407 jsr166 1.62 r.assertInvoked();
2408 jsr166 1.47 }}
2409 dl 1.5
2410     /**
2411     * thenCompose result completes exceptionally after exceptional
2412     * completion of source
2413     */
2414 jsr166 1.48 public void testThenCompose_exceptionalCompletion() {
2415 jsr166 1.47 for (ExecutionMode m : ExecutionMode.values())
2416 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2417 jsr166 1.47 {
2418 jsr166 1.44 final CFException ex = new CFException();
2419 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2420 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2421 jsr166 1.48 if (!createIncomplete) f.completeExceptionally(ex);
2422 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2423 jsr166 1.48 if (createIncomplete) f.completeExceptionally(ex);
2424 jsr166 1.21
2425 jsr166 1.44 checkCompletedWithWrappedCFException(g, ex);
2426     checkCompletedWithWrappedCFException(f, ex);
2427 jsr166 1.62 r.assertNotInvoked();
2428 jsr166 1.47 }}
2429 dl 1.5
2430     /**
2431     * thenCompose result completes exceptionally if action does
2432     */
2433 jsr166 1.48 public void testThenCompose_actionFailed() {
2434 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2435 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2436 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2437     {
2438 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2439     final FailingCompletableFutureFunction r
2440 jsr166 1.56 = new FailingCompletableFutureFunction(m);
2441 jsr166 1.48 if (!createIncomplete) f.complete(v1);
2442 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2443 jsr166 1.48 if (createIncomplete) f.complete(v1);
2444 jsr166 1.44
2445 dl 1.5 checkCompletedWithWrappedCFException(g);
2446 jsr166 1.44 checkCompletedNormally(f, v1);
2447 jsr166 1.47 }}
2448 dl 1.5
2449     /**
2450     * thenCompose result completes exceptionally if source cancelled
2451     */
2452 jsr166 1.48 public void testThenCompose_sourceCancelled() {
2453 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2454 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2455 jsr166 1.47 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2456     {
2457 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2458 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2459 jsr166 1.48 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2460 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2461 jsr166 1.50 if (createIncomplete) {
2462     checkIncomplete(g);
2463     assertTrue(f.cancel(mayInterruptIfRunning));
2464     }
2465 jsr166 1.44
2466 dl 1.5 checkCompletedWithWrappedCancellationException(g);
2467 jsr166 1.44 checkCancelled(f);
2468 jsr166 1.47 }}
2469 dl 1.5
2470 jsr166 1.6 // other static methods
2471 dl 1.5
2472     /**
2473     * allOf(no component futures) returns a future completed normally
2474     * with the value null
2475     */
2476     public void testAllOf_empty() throws Exception {
2477 jsr166 1.24 CompletableFuture<Void> f = CompletableFuture.allOf();
2478 dl 1.5 checkCompletedNormally(f, null);
2479     }
2480    
2481     /**
2482 jsr166 1.25 * allOf returns a future completed normally with the value null
2483     * when all components complete normally
2484 dl 1.5 */
2485 jsr166 1.25 public void testAllOf_normal() throws Exception {
2486 dl 1.5 for (int k = 1; k < 20; ++k) {
2487 jsr166 1.59 CompletableFuture<Integer>[] fs
2488     = (CompletableFuture<Integer>[]) new CompletableFuture[k];
2489 jsr166 1.6 for (int i = 0; i < k; ++i)
2490 jsr166 1.22 fs[i] = new CompletableFuture<>();
2491 dl 1.9 CompletableFuture<Void> f = CompletableFuture.allOf(fs);
2492 dl 1.5 for (int i = 0; i < k; ++i) {
2493     checkIncomplete(f);
2494 jsr166 1.24 checkIncomplete(CompletableFuture.allOf(fs));
2495 dl 1.5 fs[i].complete(one);
2496     }
2497 dl 1.9 checkCompletedNormally(f, null);
2498 jsr166 1.24 checkCompletedNormally(CompletableFuture.allOf(fs), null);
2499 dl 1.5 }
2500     }
2501    
2502 jsr166 1.59 public void testAllOf_backwards() throws Exception {
2503     for (int k = 1; k < 20; ++k) {
2504     CompletableFuture<Integer>[] fs
2505     = (CompletableFuture<Integer>[]) new CompletableFuture[k];
2506     for (int i = 0; i < k; ++i)
2507     fs[i] = new CompletableFuture<>();
2508     CompletableFuture<Void> f = CompletableFuture.allOf(fs);
2509     for (int i = k - 1; i >= 0; i--) {
2510     checkIncomplete(f);
2511     checkIncomplete(CompletableFuture.allOf(fs));
2512     fs[i].complete(one);
2513     }
2514     checkCompletedNormally(f, null);
2515     checkCompletedNormally(CompletableFuture.allOf(fs), null);
2516     }
2517     }
2518    
2519 dl 1.5 /**
2520     * anyOf(no component futures) returns an incomplete future
2521     */
2522     public void testAnyOf_empty() throws Exception {
2523 jsr166 1.24 CompletableFuture<Object> f = CompletableFuture.anyOf();
2524 dl 1.5 checkIncomplete(f);
2525     }
2526    
2527     /**
2528 jsr166 1.25 * anyOf returns a future completed normally with a value when
2529     * a component future does
2530 dl 1.5 */
2531 jsr166 1.24 public void testAnyOf_normal() throws Exception {
2532     for (int k = 0; k < 10; ++k) {
2533 dl 1.5 CompletableFuture[] fs = new CompletableFuture[k];
2534 jsr166 1.6 for (int i = 0; i < k; ++i)
2535 jsr166 1.22 fs[i] = new CompletableFuture<>();
2536 dl 1.9 CompletableFuture<Object> f = CompletableFuture.anyOf(fs);
2537 dl 1.5 checkIncomplete(f);
2538     for (int i = 0; i < k; ++i) {
2539     fs[i].complete(one);
2540 dl 1.9 checkCompletedNormally(f, one);
2541 jsr166 1.24 checkCompletedNormally(CompletableFuture.anyOf(fs), one);
2542     }
2543     }
2544     }
2545    
2546     /**
2547     * anyOf result completes exceptionally when any component does.
2548     */
2549     public void testAnyOf_exceptional() throws Exception {
2550     for (int k = 0; k < 10; ++k) {
2551     CompletableFuture[] fs = new CompletableFuture[k];
2552     for (int i = 0; i < k; ++i)
2553     fs[i] = new CompletableFuture<>();
2554     CompletableFuture<Object> f = CompletableFuture.anyOf(fs);
2555     checkIncomplete(f);
2556     for (int i = 0; i < k; ++i) {
2557     fs[i].completeExceptionally(new CFException());
2558     checkCompletedWithWrappedCFException(f);
2559     checkCompletedWithWrappedCFException(CompletableFuture.anyOf(fs));
2560 dl 1.5 }
2561     }
2562     }
2563    
2564     /**
2565     * Completion methods throw NullPointerException with null arguments
2566     */
2567     public void testNPE() {
2568 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
2569     CompletableFuture<Integer> g = new CompletableFuture<>();
2570 jsr166 1.14 CompletableFuture<Integer> nullFuture = (CompletableFuture<Integer>)null;
2571     CompletableFuture<?> h;
2572 jsr166 1.17 ThreadExecutor exec = new ThreadExecutor();
2573 jsr166 1.14
2574     Runnable[] throwingActions = {
2575 jsr166 1.31 () -> CompletableFuture.supplyAsync(null),
2576     () -> CompletableFuture.supplyAsync(null, exec),
2577 jsr166 1.58 () -> CompletableFuture.supplyAsync(new IntegerSupplier(ExecutionMode.DEFAULT, 42), null),
2578 jsr166 1.31
2579     () -> CompletableFuture.runAsync(null),
2580     () -> CompletableFuture.runAsync(null, exec),
2581     () -> CompletableFuture.runAsync(() -> {}, null),
2582    
2583     () -> f.completeExceptionally(null),
2584    
2585     () -> f.thenApply(null),
2586     () -> f.thenApplyAsync(null),
2587     () -> f.thenApplyAsync((x) -> x, null),
2588     () -> f.thenApplyAsync(null, exec),
2589    
2590     () -> f.thenAccept(null),
2591     () -> f.thenAcceptAsync(null),
2592     () -> f.thenAcceptAsync((x) -> {} , null),
2593     () -> f.thenAcceptAsync(null, exec),
2594    
2595     () -> f.thenRun(null),
2596     () -> f.thenRunAsync(null),
2597     () -> f.thenRunAsync(() -> {} , null),
2598     () -> f.thenRunAsync(null, exec),
2599    
2600     () -> f.thenCombine(g, null),
2601     () -> f.thenCombineAsync(g, null),
2602     () -> f.thenCombineAsync(g, null, exec),
2603     () -> f.thenCombine(nullFuture, (x, y) -> x),
2604     () -> f.thenCombineAsync(nullFuture, (x, y) -> x),
2605     () -> f.thenCombineAsync(nullFuture, (x, y) -> x, exec),
2606     () -> f.thenCombineAsync(g, (x, y) -> x, null),
2607    
2608     () -> f.thenAcceptBoth(g, null),
2609     () -> f.thenAcceptBothAsync(g, null),
2610     () -> f.thenAcceptBothAsync(g, null, exec),
2611     () -> f.thenAcceptBoth(nullFuture, (x, y) -> {}),
2612     () -> f.thenAcceptBothAsync(nullFuture, (x, y) -> {}),
2613     () -> f.thenAcceptBothAsync(nullFuture, (x, y) -> {}, exec),
2614     () -> f.thenAcceptBothAsync(g, (x, y) -> {}, null),
2615    
2616     () -> f.runAfterBoth(g, null),
2617     () -> f.runAfterBothAsync(g, null),
2618     () -> f.runAfterBothAsync(g, null, exec),
2619     () -> f.runAfterBoth(nullFuture, () -> {}),
2620     () -> f.runAfterBothAsync(nullFuture, () -> {}),
2621     () -> f.runAfterBothAsync(nullFuture, () -> {}, exec),
2622     () -> f.runAfterBothAsync(g, () -> {}, null),
2623    
2624     () -> f.applyToEither(g, null),
2625     () -> f.applyToEitherAsync(g, null),
2626     () -> f.applyToEitherAsync(g, null, exec),
2627     () -> f.applyToEither(nullFuture, (x) -> x),
2628     () -> f.applyToEitherAsync(nullFuture, (x) -> x),
2629     () -> f.applyToEitherAsync(nullFuture, (x) -> x, exec),
2630     () -> f.applyToEitherAsync(g, (x) -> x, null),
2631    
2632     () -> f.acceptEither(g, null),
2633     () -> f.acceptEitherAsync(g, null),
2634     () -> f.acceptEitherAsync(g, null, exec),
2635     () -> f.acceptEither(nullFuture, (x) -> {}),
2636     () -> f.acceptEitherAsync(nullFuture, (x) -> {}),
2637     () -> f.acceptEitherAsync(nullFuture, (x) -> {}, exec),
2638     () -> f.acceptEitherAsync(g, (x) -> {}, null),
2639    
2640     () -> f.runAfterEither(g, null),
2641     () -> f.runAfterEitherAsync(g, null),
2642     () -> f.runAfterEitherAsync(g, null, exec),
2643     () -> f.runAfterEither(nullFuture, () -> {}),
2644     () -> f.runAfterEitherAsync(nullFuture, () -> {}),
2645     () -> f.runAfterEitherAsync(nullFuture, () -> {}, exec),
2646     () -> f.runAfterEitherAsync(g, () -> {}, null),
2647    
2648     () -> f.thenCompose(null),
2649     () -> f.thenComposeAsync(null),
2650 jsr166 1.56 () -> f.thenComposeAsync(new CompletableFutureInc(ExecutionMode.EXECUTOR), null),
2651 jsr166 1.31 () -> f.thenComposeAsync(null, exec),
2652    
2653     () -> f.exceptionally(null),
2654    
2655     () -> f.handle(null),
2656    
2657     () -> CompletableFuture.allOf((CompletableFuture<?>)null),
2658     () -> CompletableFuture.allOf((CompletableFuture<?>[])null),
2659     () -> CompletableFuture.allOf(f, null),
2660     () -> CompletableFuture.allOf(null, f),
2661    
2662     () -> CompletableFuture.anyOf((CompletableFuture<?>)null),
2663     () -> CompletableFuture.anyOf((CompletableFuture<?>[])null),
2664     () -> CompletableFuture.anyOf(f, null),
2665     () -> CompletableFuture.anyOf(null, f),
2666 jsr166 1.32
2667     () -> f.obtrudeException(null),
2668 jsr166 1.14 };
2669 dl 1.5
2670 jsr166 1.14 assertThrows(NullPointerException.class, throwingActions);
2671 jsr166 1.17 assertEquals(0, exec.count.get());
2672 dl 1.5 }
2673    
2674 dl 1.26 /**
2675     * toCompletableFuture returns this CompletableFuture.
2676     */
2677     public void testToCompletableFuture() {
2678     CompletableFuture<Integer> f = new CompletableFuture<>();
2679     assertSame(f, f.toCompletableFuture());
2680     }
2681    
2682     /**
2683     * whenComplete action executes on normal completion, propagating
2684     * source result.
2685     */
2686 jsr166 1.42 public void testWhenComplete_normalCompletion1() {
2687 jsr166 1.46 for (ExecutionMode m : ExecutionMode.values())
2688 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2689 jsr166 1.46 for (Integer v1 : new Integer[] { 1, null })
2690     {
2691     final AtomicInteger a = new AtomicInteger(0);
2692 jsr166 1.42 final CompletableFuture<Integer> f = new CompletableFuture<>();
2693 jsr166 1.44 if (!createIncomplete) f.complete(v1);
2694 jsr166 1.46 final CompletableFuture<Integer> g = m.whenComplete
2695     (f,
2696     (Integer x, Throwable t) -> {
2697     threadAssertSame(x, v1);
2698     threadAssertNull(t);
2699     a.getAndIncrement();
2700     });
2701 jsr166 1.44 if (createIncomplete) f.complete(v1);
2702 jsr166 1.46
2703     checkCompletedNormally(g, v1);
2704 jsr166 1.42 checkCompletedNormally(f, v1);
2705 jsr166 1.46 assertEquals(1, a.get());
2706     }}
2707 dl 1.26
2708     /**
2709     * whenComplete action executes on exceptional completion, propagating
2710     * source result.
2711     */
2712 jsr166 1.42 public void testWhenComplete_exceptionalCompletion() {
2713 jsr166 1.46 for (ExecutionMode m : ExecutionMode.values())
2714 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2715 jsr166 1.46 for (Integer v1 : new Integer[] { 1, null })
2716     {
2717     final AtomicInteger a = new AtomicInteger(0);
2718 jsr166 1.42 final CFException ex = new CFException();
2719     final CompletableFuture<Integer> f = new CompletableFuture<>();
2720 jsr166 1.44 if (!createIncomplete) f.completeExceptionally(ex);
2721 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2722     (f,
2723     (Integer x, Throwable t) -> {
2724     threadAssertNull(x);
2725     threadAssertSame(t, ex);
2726     a.getAndIncrement();
2727     });
2728 jsr166 1.44 if (createIncomplete) f.completeExceptionally(ex);
2729 jsr166 1.42 checkCompletedWithWrappedCFException(f, ex);
2730     checkCompletedWithWrappedCFException(g, ex);
2731 jsr166 1.46 assertEquals(1, a.get());
2732     }}
2733    
2734     /**
2735     * whenComplete action executes on cancelled source, propagating
2736     * CancellationException.
2737     */
2738     public void testWhenComplete_sourceCancelled() {
2739     for (ExecutionMode m : ExecutionMode.values())
2740     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2741     for (boolean createIncomplete : new boolean[] { true, false })
2742     {
2743     final AtomicInteger a = new AtomicInteger(0);
2744     final CompletableFuture<Integer> f = new CompletableFuture<>();
2745     if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2746     final CompletableFuture<Integer> g = m.whenComplete
2747     (f,
2748     (Integer x, Throwable t) -> {
2749     threadAssertNull(x);
2750     threadAssertTrue(t instanceof CancellationException);
2751     a.getAndIncrement();
2752     });
2753     if (createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2754    
2755     //try { g.join(); } catch (Throwable t) { throw new Error(t); }
2756     checkCompletedWithWrappedCancellationException(g);
2757     checkCancelled(f);
2758     assertEquals(1, a.get());
2759     }}
2760 dl 1.26
2761     /**
2762     * If a whenComplete action throws an exception when triggered by
2763     * a normal completion, it completes exceptionally
2764     */
2765 jsr166 1.42 public void testWhenComplete_actionFailed() {
2766 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2767 jsr166 1.42 for (ExecutionMode m : ExecutionMode.values())
2768 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2769     {
2770 jsr166 1.46 final AtomicInteger a = new AtomicInteger(0);
2771 jsr166 1.42 final CFException ex = new CFException();
2772     final CompletableFuture<Integer> f = new CompletableFuture<>();
2773 jsr166 1.44 if (!createIncomplete) f.complete(v1);
2774 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2775     (f,
2776     (Integer x, Throwable t) -> {
2777     threadAssertSame(x, v1);
2778     threadAssertNull(t);
2779 jsr166 1.46 a.getAndIncrement();
2780 jsr166 1.42 throw ex;
2781     });
2782 jsr166 1.44 if (createIncomplete) f.complete(v1);
2783 jsr166 1.42 checkCompletedNormally(f, v1);
2784     checkCompletedWithWrappedCFException(g, ex);
2785 jsr166 1.46 assertEquals(1, a.get());
2786 jsr166 1.47 }}
2787 dl 1.26
2788     /**
2789 jsr166 1.42 * If a whenComplete action throws an exception when triggered by
2790     * a source completion that also throws an exception, the source
2791     * exception takes precedence.
2792 dl 1.26 */
2793 jsr166 1.42 public void testWhenComplete_actionFailedSourceFailed() {
2794 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2795 jsr166 1.42 for (ExecutionMode m : ExecutionMode.values())
2796 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2797     {
2798 jsr166 1.46 final AtomicInteger a = new AtomicInteger(0);
2799 jsr166 1.42 final CFException ex1 = new CFException();
2800     final CFException ex2 = new CFException();
2801     final CompletableFuture<Integer> f = new CompletableFuture<>();
2802 jsr166 1.44
2803     if (!createIncomplete) f.completeExceptionally(ex1);
2804 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2805     (f,
2806     (Integer x, Throwable t) -> {
2807     threadAssertSame(t, ex1);
2808     threadAssertNull(x);
2809 jsr166 1.46 a.getAndIncrement();
2810 jsr166 1.42 throw ex2;
2811     });
2812 jsr166 1.44 if (createIncomplete) f.completeExceptionally(ex1);
2813    
2814 jsr166 1.42 checkCompletedWithWrappedCFException(f, ex1);
2815     checkCompletedWithWrappedCFException(g, ex1);
2816 jsr166 1.46 assertEquals(1, a.get());
2817 jsr166 1.47 }}
2818 dl 1.26
2819 jsr166 1.1 }