ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/CompletableFutureTest.java
Revision: 1.63
Committed: Fri Jun 6 16:54:16 2014 UTC (9 years, 11 months ago) by jsr166
Branch: MAIN
Changes since 1.62: +164 -242 lines
Log Message:
improve tests for acceptEither

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.62 class IncAction extends CheckedIntegerAction
364     implements Consumer<Integer>
365     {
366     IncAction(ExecutionMode m) { super(m); }
367 jsr166 1.38 public void accept(Integer x) {
368 jsr166 1.62 invoked();
369 jsr166 1.38 value = inc(x);
370     }
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.62 final IncAction r = new IncAction(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.50 checkCompletedNormally(f, v1);
1262 jsr166 1.62 r.assertInvoked();
1263     r.assertValue(inc(v1));
1264 jsr166 1.50 }}
1265 dl 1.5
1266     /**
1267     * thenAccept result completes exceptionally after exceptional
1268     * completion of source
1269     */
1270 jsr166 1.50 public void testThenAccept_exceptionalCompletion() {
1271     for (ExecutionMode m : ExecutionMode.values())
1272     for (boolean createIncomplete : new boolean[] { true, false })
1273     {
1274     final CFException ex = new CFException();
1275     final CompletableFuture<Integer> f = new CompletableFuture<>();
1276 jsr166 1.62 final IncAction r = new IncAction(m);
1277 jsr166 1.50 if (!createIncomplete) f.completeExceptionally(ex);
1278     final CompletableFuture<Void> g = m.thenAccept(f, r);
1279 jsr166 1.51 if (createIncomplete) {
1280     checkIncomplete(g);
1281     f.completeExceptionally(ex);
1282     }
1283 jsr166 1.50
1284     checkCompletedWithWrappedCFException(g, ex);
1285     checkCompletedWithWrappedCFException(f, ex);
1286 jsr166 1.62 r.assertNotInvoked();
1287 jsr166 1.50 }}
1288 dl 1.5
1289     /**
1290 jsr166 1.61 * thenAccept result completes exceptionally if source cancelled
1291 dl 1.5 */
1292 jsr166 1.61 public void testThenAccept_sourceCancelled() {
1293 jsr166 1.50 for (ExecutionMode m : ExecutionMode.values())
1294     for (boolean createIncomplete : new boolean[] { true, false })
1295 jsr166 1.61 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1296 jsr166 1.50 {
1297     final CompletableFuture<Integer> f = new CompletableFuture<>();
1298 jsr166 1.62 final IncAction r = new IncAction(m);
1299 jsr166 1.61 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
1300 jsr166 1.56 final CompletableFuture<Void> g = m.thenAccept(f, r);
1301 jsr166 1.51 if (createIncomplete) {
1302     checkIncomplete(g);
1303 jsr166 1.61 assertTrue(f.cancel(mayInterruptIfRunning));
1304 jsr166 1.51 }
1305 jsr166 1.50
1306 jsr166 1.61 checkCompletedWithWrappedCancellationException(g);
1307     checkCancelled(f);
1308 jsr166 1.62 r.assertNotInvoked();
1309 jsr166 1.50 }}
1310 dl 1.5
1311     /**
1312 jsr166 1.61 * thenAccept result completes exceptionally if action does
1313 dl 1.5 */
1314 jsr166 1.61 public void testThenAccept_actionFailed() {
1315 jsr166 1.50 for (ExecutionMode m : ExecutionMode.values())
1316     for (boolean createIncomplete : new boolean[] { true, false })
1317 jsr166 1.61 for (Integer v1 : new Integer[] { 1, null })
1318 jsr166 1.50 {
1319     final CompletableFuture<Integer> f = new CompletableFuture<>();
1320 jsr166 1.61 final FailingConsumer r = new FailingConsumer(m);
1321     if (!createIncomplete) f.complete(v1);
1322 jsr166 1.56 final CompletableFuture<Void> g = m.thenAccept(f, r);
1323 jsr166 1.50 if (createIncomplete) {
1324     checkIncomplete(g);
1325 jsr166 1.61 f.complete(v1);
1326 jsr166 1.50 }
1327    
1328 jsr166 1.61 checkCompletedWithWrappedCFException(g);
1329     checkCompletedNormally(f, v1);
1330 jsr166 1.50 }}
1331 dl 1.5
1332     /**
1333 jsr166 1.18 * thenCombine result completes normally after normal completion
1334     * of sources
1335 dl 1.5 */
1336 jsr166 1.51 public void testThenCombine_normalCompletion() {
1337     for (ExecutionMode m : ExecutionMode.values())
1338 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
1339 jsr166 1.43 for (boolean fFirst : new boolean[] { true, false })
1340 jsr166 1.36 for (Integer v1 : new Integer[] { 1, null })
1341 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1342     {
1343 jsr166 1.36 final CompletableFuture<Integer> f = new CompletableFuture<>();
1344     final CompletableFuture<Integer> g = new CompletableFuture<>();
1345 jsr166 1.56 final SubtractFunction r = new SubtractFunction(m);
1346 jsr166 1.36
1347 jsr166 1.51 if (fFirst) f.complete(v1); else g.complete(v2);
1348     if (!createIncomplete)
1349     if (!fFirst) f.complete(v1); else g.complete(v2);
1350     final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1351     if (createIncomplete) {
1352     checkIncomplete(h);
1353 jsr166 1.62 r.assertNotInvoked();
1354 jsr166 1.51 if (!fFirst) f.complete(v1); else g.complete(v2);
1355     }
1356 jsr166 1.36
1357     checkCompletedNormally(h, subtract(v1, v2));
1358     checkCompletedNormally(f, v1);
1359     checkCompletedNormally(g, v2);
1360 jsr166 1.62 r.assertInvoked();
1361 jsr166 1.47 }}
1362 dl 1.5
1363     /**
1364     * thenCombine result completes exceptionally after exceptional
1365     * completion of either source
1366     */
1367 jsr166 1.52 public void testThenCombine_exceptionalCompletion() {
1368 jsr166 1.36 for (ExecutionMode m : ExecutionMode.values())
1369 jsr166 1.52 for (boolean createIncomplete : new boolean[] { true, false })
1370     for (boolean fFirst : new boolean[] { true, false })
1371 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1372     {
1373 jsr166 1.36 final CompletableFuture<Integer> f = new CompletableFuture<>();
1374     final CompletableFuture<Integer> g = new CompletableFuture<>();
1375     final CFException ex = new CFException();
1376 jsr166 1.56 final SubtractFunction r = new SubtractFunction(m);
1377 jsr166 1.18
1378 jsr166 1.52 (fFirst ? f : g).complete(v1);
1379     if (!createIncomplete)
1380     (!fFirst ? f : g).completeExceptionally(ex);
1381 jsr166 1.37 final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1382 jsr166 1.52 if (createIncomplete) {
1383     checkIncomplete(h);
1384     (!fFirst ? f : g).completeExceptionally(ex);
1385     }
1386 dl 1.5
1387 jsr166 1.36 checkCompletedWithWrappedCFException(h, ex);
1388 jsr166 1.62 r.assertNotInvoked();
1389 jsr166 1.52 checkCompletedNormally(fFirst ? f : g, v1);
1390     checkCompletedWithWrappedCFException(!fFirst ? f : g, ex);
1391 jsr166 1.47 }}
1392 dl 1.5
1393     /**
1394     * thenCombine result completes exceptionally if either source cancelled
1395     */
1396 jsr166 1.52 public void testThenCombine_sourceCancelled() {
1397 jsr166 1.36 for (ExecutionMode m : ExecutionMode.values())
1398     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1399 jsr166 1.52 for (boolean createIncomplete : new boolean[] { true, false })
1400     for (boolean fFirst : new boolean[] { true, false })
1401 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1402     {
1403 jsr166 1.36 final CompletableFuture<Integer> f = new CompletableFuture<>();
1404     final CompletableFuture<Integer> g = new CompletableFuture<>();
1405 jsr166 1.56 final SubtractFunction r = new SubtractFunction(m);
1406 jsr166 1.18
1407 jsr166 1.52 (fFirst ? f : g).complete(v1);
1408     if (!createIncomplete)
1409     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1410 jsr166 1.36 final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1411 jsr166 1.52 if (createIncomplete) {
1412     checkIncomplete(h);
1413     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1414     }
1415 jsr166 1.36
1416 jsr166 1.18 checkCompletedWithWrappedCancellationException(h);
1417 jsr166 1.52 checkCancelled(!fFirst ? f : g);
1418 jsr166 1.62 r.assertNotInvoked();
1419 jsr166 1.52 checkCompletedNormally(fFirst ? f : g, v1);
1420 jsr166 1.47 }}
1421 dl 1.5
1422     /**
1423 jsr166 1.61 * thenCombine result completes exceptionally if action does
1424     */
1425     public void testThenCombine_actionFailed() {
1426     for (ExecutionMode m : ExecutionMode.values())
1427     for (boolean fFirst : new boolean[] { true, false })
1428     for (Integer v1 : new Integer[] { 1, null })
1429     for (Integer v2 : new Integer[] { 2, null })
1430     {
1431     final CompletableFuture<Integer> f = new CompletableFuture<>();
1432     final CompletableFuture<Integer> g = new CompletableFuture<>();
1433     final FailingBiFunction r = new FailingBiFunction(m);
1434     final CompletableFuture<Integer> h = m.thenCombine(f, g, r);
1435    
1436     if (fFirst) {
1437     f.complete(v1);
1438     g.complete(v2);
1439     } else {
1440     g.complete(v2);
1441     f.complete(v1);
1442     }
1443    
1444     checkCompletedWithWrappedCFException(h);
1445     checkCompletedNormally(f, v1);
1446     checkCompletedNormally(g, v2);
1447     }}
1448    
1449     /**
1450 dl 1.5 * thenAcceptBoth result completes normally after normal
1451     * completion of sources
1452     */
1453 jsr166 1.53 public void testThenAcceptBoth_normalCompletion() {
1454 jsr166 1.35 for (ExecutionMode m : ExecutionMode.values())
1455 jsr166 1.53 for (boolean createIncomplete : new boolean[] { true, false })
1456     for (boolean fFirst : new boolean[] { true, false })
1457 jsr166 1.35 for (Integer v1 : new Integer[] { 1, null })
1458 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1459     {
1460 jsr166 1.35 final CompletableFuture<Integer> f = new CompletableFuture<>();
1461     final CompletableFuture<Integer> g = new CompletableFuture<>();
1462 jsr166 1.56 final SubtractAction r = new SubtractAction(m);
1463 jsr166 1.35
1464 jsr166 1.53 if (fFirst) f.complete(v1); else g.complete(v2);
1465     if (!createIncomplete)
1466     if (!fFirst) f.complete(v1); else g.complete(v2);
1467 jsr166 1.35 final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1468 jsr166 1.53 if (createIncomplete) {
1469     checkIncomplete(h);
1470 jsr166 1.62 r.assertNotInvoked();
1471 jsr166 1.53 if (!fFirst) f.complete(v1); else g.complete(v2);
1472     }
1473 dl 1.5
1474 jsr166 1.22 checkCompletedNormally(h, null);
1475 jsr166 1.62 r.assertValue(subtract(v1, v2));
1476 jsr166 1.35 checkCompletedNormally(f, v1);
1477     checkCompletedNormally(g, v2);
1478 jsr166 1.47 }}
1479 dl 1.5
1480     /**
1481     * thenAcceptBoth result completes exceptionally after exceptional
1482     * completion of either source
1483     */
1484 jsr166 1.53 public void testThenAcceptBoth_exceptionalCompletion() {
1485 jsr166 1.35 for (ExecutionMode m : ExecutionMode.values())
1486 jsr166 1.53 for (boolean createIncomplete : new boolean[] { true, false })
1487     for (boolean fFirst : new boolean[] { true, false })
1488 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1489     {
1490 jsr166 1.35 final CompletableFuture<Integer> f = new CompletableFuture<>();
1491     final CompletableFuture<Integer> g = new CompletableFuture<>();
1492     final CFException ex = new CFException();
1493 jsr166 1.56 final SubtractAction r = new SubtractAction(m);
1494 jsr166 1.35
1495 jsr166 1.53 (fFirst ? f : g).complete(v1);
1496     if (!createIncomplete)
1497     (!fFirst ? f : g).completeExceptionally(ex);
1498 jsr166 1.35 final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1499 jsr166 1.53 if (createIncomplete) {
1500     checkIncomplete(h);
1501     (!fFirst ? f : g).completeExceptionally(ex);
1502     }
1503 jsr166 1.35
1504     checkCompletedWithWrappedCFException(h, ex);
1505 jsr166 1.62 r.assertNotInvoked();
1506 jsr166 1.53 checkCompletedNormally(fFirst ? f : g, v1);
1507     checkCompletedWithWrappedCFException(!fFirst ? f : g, ex);
1508 jsr166 1.47 }}
1509 dl 1.5
1510     /**
1511     * thenAcceptBoth result completes exceptionally if either source cancelled
1512     */
1513 jsr166 1.53 public void testThenAcceptBoth_sourceCancelled() {
1514 jsr166 1.35 for (ExecutionMode m : ExecutionMode.values())
1515     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1516 jsr166 1.53 for (boolean createIncomplete : new boolean[] { true, false })
1517     for (boolean fFirst : new boolean[] { true, false })
1518 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1519     {
1520 jsr166 1.35 final CompletableFuture<Integer> f = new CompletableFuture<>();
1521     final CompletableFuture<Integer> g = new CompletableFuture<>();
1522 jsr166 1.56 final SubtractAction r = new SubtractAction(m);
1523 jsr166 1.35
1524 jsr166 1.53 (fFirst ? f : g).complete(v1);
1525     if (!createIncomplete)
1526     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1527 jsr166 1.35 final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1528 jsr166 1.53 if (createIncomplete) {
1529     checkIncomplete(h);
1530     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1531     }
1532 jsr166 1.22
1533     checkCompletedWithWrappedCancellationException(h);
1534 jsr166 1.53 checkCancelled(!fFirst ? f : g);
1535 jsr166 1.62 r.assertNotInvoked();
1536 jsr166 1.53 checkCompletedNormally(fFirst ? f : g, v1);
1537 jsr166 1.47 }}
1538 jsr166 1.34
1539     /**
1540 jsr166 1.61 * thenAcceptBoth result completes exceptionally if action does
1541     */
1542     public void testThenAcceptBoth_actionFailed() {
1543     for (ExecutionMode m : ExecutionMode.values())
1544     for (boolean fFirst : new boolean[] { true, false })
1545     for (Integer v1 : new Integer[] { 1, null })
1546     for (Integer v2 : new Integer[] { 2, null })
1547     {
1548     final CompletableFuture<Integer> f = new CompletableFuture<>();
1549     final CompletableFuture<Integer> g = new CompletableFuture<>();
1550     final FailingBiConsumer r = new FailingBiConsumer(m);
1551     final CompletableFuture<Void> h = m.thenAcceptBoth(f, g, r);
1552    
1553     if (fFirst) {
1554     f.complete(v1);
1555     g.complete(v2);
1556     } else {
1557     g.complete(v2);
1558     f.complete(v1);
1559     }
1560    
1561     checkCompletedWithWrappedCFException(h);
1562     checkCompletedNormally(f, v1);
1563     checkCompletedNormally(g, v2);
1564     }}
1565    
1566     /**
1567 dl 1.5 * runAfterBoth result completes normally after normal
1568     * completion of sources
1569     */
1570 jsr166 1.54 public void testRunAfterBoth_normalCompletion() {
1571 jsr166 1.34 for (ExecutionMode m : ExecutionMode.values())
1572 jsr166 1.54 for (boolean createIncomplete : new boolean[] { true, false })
1573     for (boolean fFirst : new boolean[] { true, false })
1574 jsr166 1.33 for (Integer v1 : new Integer[] { 1, null })
1575 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1576     {
1577 jsr166 1.33 final CompletableFuture<Integer> f = new CompletableFuture<>();
1578     final CompletableFuture<Integer> g = new CompletableFuture<>();
1579 jsr166 1.55 final Noop r = new Noop(m);
1580 jsr166 1.33
1581 jsr166 1.54 if (fFirst) f.complete(v1); else g.complete(v2);
1582     if (!createIncomplete)
1583     if (!fFirst) f.complete(v1); else g.complete(v2);
1584 jsr166 1.34 final CompletableFuture<Void> h = m.runAfterBoth(f, g, r);
1585 jsr166 1.54 if (createIncomplete) {
1586     checkIncomplete(h);
1587 jsr166 1.62 r.assertNotInvoked();
1588 jsr166 1.54 if (!fFirst) f.complete(v1); else g.complete(v2);
1589     }
1590 dl 1.5
1591 jsr166 1.22 checkCompletedNormally(h, null);
1592 jsr166 1.62 r.assertInvoked();
1593 jsr166 1.33 checkCompletedNormally(f, v1);
1594     checkCompletedNormally(g, v2);
1595 jsr166 1.47 }}
1596 dl 1.5
1597     /**
1598     * runAfterBoth result completes exceptionally after exceptional
1599     * completion of either source
1600     */
1601 jsr166 1.54 public void testRunAfterBoth_exceptionalCompletion() {
1602 jsr166 1.34 for (ExecutionMode m : ExecutionMode.values())
1603 jsr166 1.54 for (boolean createIncomplete : new boolean[] { true, false })
1604     for (boolean fFirst : new boolean[] { true, false })
1605 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1606     {
1607 jsr166 1.33 final CompletableFuture<Integer> f = new CompletableFuture<>();
1608     final CompletableFuture<Integer> g = new CompletableFuture<>();
1609     final CFException ex = new CFException();
1610 jsr166 1.55 final Noop r = new Noop(m);
1611 jsr166 1.33
1612 jsr166 1.54 (fFirst ? f : g).complete(v1);
1613     if (!createIncomplete)
1614     (!fFirst ? f : g).completeExceptionally(ex);
1615 jsr166 1.34 final CompletableFuture<Void> h = m.runAfterBoth(f, g, r);
1616 jsr166 1.54 if (createIncomplete) {
1617     checkIncomplete(h);
1618     (!fFirst ? f : g).completeExceptionally(ex);
1619     }
1620 dl 1.5
1621 jsr166 1.33 checkCompletedWithWrappedCFException(h, ex);
1622 jsr166 1.62 r.assertNotInvoked();
1623 jsr166 1.54 checkCompletedNormally(fFirst ? f : g, v1);
1624     checkCompletedWithWrappedCFException(!fFirst ? f : g, ex);
1625 jsr166 1.47 }}
1626 dl 1.5
1627 jsr166 1.4 /**
1628 dl 1.5 * runAfterBoth result completes exceptionally if either source cancelled
1629 jsr166 1.4 */
1630 jsr166 1.54 public void testRunAfterBoth_sourceCancelled() {
1631 jsr166 1.34 for (ExecutionMode m : ExecutionMode.values())
1632 jsr166 1.33 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1633 jsr166 1.54 for (boolean createIncomplete : new boolean[] { true, false })
1634     for (boolean fFirst : new boolean[] { true, false })
1635 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1636     {
1637 jsr166 1.33 final CompletableFuture<Integer> f = new CompletableFuture<>();
1638     final CompletableFuture<Integer> g = new CompletableFuture<>();
1639 jsr166 1.55 final Noop r = new Noop(m);
1640 jsr166 1.33
1641    
1642 jsr166 1.54 (fFirst ? f : g).complete(v1);
1643     if (!createIncomplete)
1644     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1645 jsr166 1.34 final CompletableFuture<Void> h = m.runAfterBoth(f, g, r);
1646 jsr166 1.54 if (createIncomplete) {
1647     checkIncomplete(h);
1648     assertTrue((!fFirst ? f : g).cancel(mayInterruptIfRunning));
1649     }
1650 jsr166 1.33
1651     checkCompletedWithWrappedCancellationException(h);
1652 jsr166 1.54 checkCancelled(!fFirst ? f : g);
1653 jsr166 1.62 r.assertNotInvoked();
1654 jsr166 1.54 checkCompletedNormally(fFirst ? f : g, v1);
1655 jsr166 1.47 }}
1656 dl 1.5
1657     /**
1658 jsr166 1.61 * runAfterBoth result completes exceptionally if action does
1659     */
1660     public void testRunAfterBoth_actionFailed() {
1661     for (ExecutionMode m : ExecutionMode.values())
1662     for (boolean fFirst : new boolean[] { true, false })
1663     for (Integer v1 : new Integer[] { 1, null })
1664     for (Integer v2 : new Integer[] { 2, null })
1665     {
1666     final CompletableFuture<Integer> f = new CompletableFuture<>();
1667     final CompletableFuture<Integer> g = new CompletableFuture<>();
1668 jsr166 1.62 final FailingRunnable r1 = new FailingRunnable(m);
1669     final FailingRunnable r2 = new FailingRunnable(m);
1670 jsr166 1.61
1671 jsr166 1.62 CompletableFuture<Void> h1 = m.runAfterBoth(f, g, r1);
1672 jsr166 1.61 if (fFirst) {
1673     f.complete(v1);
1674     g.complete(v2);
1675     } else {
1676     g.complete(v2);
1677     f.complete(v1);
1678     }
1679 jsr166 1.62 CompletableFuture<Void> h2 = m.runAfterBoth(f, g, r2);
1680 jsr166 1.61
1681     checkCompletedWithWrappedCFException(h1);
1682     checkCompletedWithWrappedCFException(h2);
1683     checkCompletedNormally(f, v1);
1684     checkCompletedNormally(g, v2);
1685     }}
1686    
1687     /**
1688 dl 1.5 * applyToEither result completes normally after normal completion
1689     * of either source
1690     */
1691 jsr166 1.54 public void testApplyToEither_normalCompletion() {
1692 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1693     for (Integer v1 : new Integer[] { 1, null })
1694 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1695     {
1696 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1697     final CompletableFuture<Integer> g = new CompletableFuture<>();
1698 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1699     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1700 jsr166 1.54
1701 jsr166 1.62 final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1702     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1703     checkIncomplete(h0);
1704     checkIncomplete(h1);
1705     rs[0].assertNotInvoked();
1706     rs[1].assertNotInvoked();
1707     f.complete(v1);
1708     checkCompletedNormally(h0, inc(v1));
1709     checkCompletedNormally(h1, inc(v1));
1710     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1711     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1712     checkCompletedNormally(h2, inc(v1));
1713     checkCompletedNormally(h3, inc(v1));
1714     g.complete(v2);
1715 jsr166 1.39
1716 jsr166 1.62 // unspecified behavior - both source completions available
1717     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1718     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1719     rs[4].assertValue(h4.join());
1720     rs[5].assertValue(h5.join());
1721     assertTrue(Objects.equals(inc(v1), h4.join()) ||
1722     Objects.equals(inc(v2), h4.join()));
1723     assertTrue(Objects.equals(inc(v1), h5.join()) ||
1724     Objects.equals(inc(v2), h5.join()));
1725 jsr166 1.39
1726     checkCompletedNormally(f, v1);
1727     checkCompletedNormally(g, v2);
1728 jsr166 1.62 checkCompletedNormally(h0, inc(v1));
1729     checkCompletedNormally(h1, inc(v1));
1730     checkCompletedNormally(h2, inc(v1));
1731     checkCompletedNormally(h3, inc(v1));
1732     for (int i = 0; i < 4; i++) rs[i].assertValue(inc(v1));
1733 jsr166 1.47 }}
1734 dl 1.5
1735     /**
1736     * applyToEither result completes exceptionally after exceptional
1737     * completion of either source
1738     */
1739 jsr166 1.62 public void testApplyToEither_exceptionalCompletion() {
1740 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1741 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1742     {
1743 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1744     final CompletableFuture<Integer> g = new CompletableFuture<>();
1745 jsr166 1.54 final CFException ex = new CFException();
1746 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1747     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1748    
1749     final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1750     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1751     checkIncomplete(h0);
1752     checkIncomplete(h1);
1753     rs[0].assertNotInvoked();
1754     rs[1].assertNotInvoked();
1755     f.completeExceptionally(ex);
1756     checkCompletedWithWrappedCFException(h0, ex);
1757     checkCompletedWithWrappedCFException(h1, ex);
1758     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1759     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1760     checkCompletedWithWrappedCFException(h2, ex);
1761     checkCompletedWithWrappedCFException(h3, ex);
1762     g.complete(v1);
1763 jsr166 1.54
1764 jsr166 1.62 // unspecified behavior - both source completions available
1765     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1766     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1767     try {
1768     assertEquals(inc(v1), h4.join());
1769     rs[4].assertInvoked();
1770     } catch (CompletionException ok) {
1771     checkCompletedWithWrappedCFException(h4, ex);
1772     rs[4].assertNotInvoked();
1773     }
1774     try {
1775     assertEquals(inc(v1), h5.join());
1776     rs[5].assertInvoked();
1777     } catch (CompletionException ok) {
1778     checkCompletedWithWrappedCFException(h5, ex);
1779     rs[5].assertNotInvoked();
1780 jsr166 1.54 }
1781 jsr166 1.39
1782 jsr166 1.62 checkCompletedWithWrappedCFException(f, ex);
1783     checkCompletedNormally(g, v1);
1784     checkCompletedWithWrappedCFException(h0, ex);
1785     checkCompletedWithWrappedCFException(h1, ex);
1786     checkCompletedWithWrappedCFException(h2, ex);
1787     checkCompletedWithWrappedCFException(h3, ex);
1788     checkCompletedWithWrappedCFException(h4, ex);
1789     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1790 jsr166 1.47 }}
1791 jsr166 1.39
1792 jsr166 1.62 /**
1793     * applyToEither result completes exceptionally if either source cancelled
1794     */
1795     public void testApplyToEither_sourceCancelled() {
1796 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1797 jsr166 1.62 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1798 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1799     {
1800 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1801     final CompletableFuture<Integer> g = new CompletableFuture<>();
1802 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1803     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1804    
1805     final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1806     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1807     checkIncomplete(h0);
1808     checkIncomplete(h1);
1809     rs[0].assertNotInvoked();
1810     rs[1].assertNotInvoked();
1811     f.cancel(mayInterruptIfRunning);
1812     checkCompletedWithWrappedCancellationException(h0);
1813     checkCompletedWithWrappedCancellationException(h1);
1814     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1815     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1816     checkCompletedWithWrappedCancellationException(h2);
1817     checkCompletedWithWrappedCancellationException(h3);
1818     g.complete(v1);
1819 jsr166 1.39
1820 jsr166 1.62 // unspecified behavior - both source completions available
1821     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1822     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1823 jsr166 1.39 try {
1824 jsr166 1.62 assertEquals(inc(v1), h4.join());
1825     rs[4].assertInvoked();
1826 jsr166 1.39 } catch (CompletionException ok) {
1827 jsr166 1.62 checkCompletedWithWrappedCancellationException(h4);
1828     rs[4].assertNotInvoked();
1829 jsr166 1.39 }
1830     try {
1831 jsr166 1.62 assertEquals(inc(v1), h5.join());
1832     rs[5].assertInvoked();
1833 jsr166 1.39 } catch (CompletionException ok) {
1834 jsr166 1.62 checkCompletedWithWrappedCancellationException(h5);
1835     rs[5].assertNotInvoked();
1836 jsr166 1.39 }
1837 dl 1.5
1838 jsr166 1.62 checkCancelled(f);
1839     checkCompletedNormally(g, v1);
1840     checkCompletedWithWrappedCancellationException(h0);
1841     checkCompletedWithWrappedCancellationException(h1);
1842     checkCompletedWithWrappedCancellationException(h2);
1843     checkCompletedWithWrappedCancellationException(h3);
1844     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1845 jsr166 1.47 }}
1846 dl 1.5
1847     /**
1848     * applyToEither result completes exceptionally if action does
1849     */
1850 jsr166 1.62 public void testApplyToEither_actionFailed() {
1851 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1852     for (Integer v1 : new Integer[] { 1, null })
1853 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1854     {
1855 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1856     final CompletableFuture<Integer> g = new CompletableFuture<>();
1857 jsr166 1.62 final FailingFunction[] rs = new FailingFunction[6];
1858     for (int i = 0; i < rs.length; i++) rs[i] = new FailingFunction(m);
1859 jsr166 1.39
1860 jsr166 1.62 final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1861     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1862 jsr166 1.39 f.complete(v1);
1863 jsr166 1.62 final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1864     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1865     checkCompletedWithWrappedCFException(h0);
1866     checkCompletedWithWrappedCFException(h1);
1867     checkCompletedWithWrappedCFException(h2);
1868     checkCompletedWithWrappedCFException(h3);
1869 jsr166 1.63 for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
1870    
1871     g.complete(v2);
1872    
1873     // unspecified behavior - both source completions available
1874     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1875     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1876    
1877 jsr166 1.62 checkCompletedWithWrappedCFException(h4);
1878 jsr166 1.63 assertTrue(Objects.equals(v1, rs[4].value) ||
1879     Objects.equals(v2, rs[4].value));
1880 jsr166 1.62 checkCompletedWithWrappedCFException(h5);
1881 jsr166 1.63 assertTrue(Objects.equals(v1, rs[5].value) ||
1882     Objects.equals(v2, rs[5].value));
1883    
1884     checkCompletedNormally(f, v1);
1885     checkCompletedNormally(g, v2);
1886 jsr166 1.47 }}
1887 dl 1.5
1888     /**
1889     * acceptEither result completes normally after normal completion
1890     * of either source
1891     */
1892 jsr166 1.63 public void testAcceptEither_normalCompletion() {
1893 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
1894     for (Integer v1 : new Integer[] { 1, null })
1895 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1896     {
1897 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
1898     final CompletableFuture<Integer> g = new CompletableFuture<>();
1899 jsr166 1.63 final IncAction[] rs = new IncAction[6];
1900     for (int i = 0; i < rs.length; i++) rs[i] = new IncAction(m);
1901 jsr166 1.40
1902 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
1903     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
1904     checkIncomplete(h0);
1905     checkIncomplete(h1);
1906     rs[0].assertNotInvoked();
1907     rs[1].assertNotInvoked();
1908 jsr166 1.40 f.complete(v1);
1909 jsr166 1.63 checkCompletedNormally(h0, null);
1910     checkCompletedNormally(h1, null);
1911     rs[0].assertValue(inc(v1));
1912     rs[1].assertValue(inc(v1));
1913     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
1914     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
1915     checkCompletedNormally(h2, null);
1916     checkCompletedNormally(h3, null);
1917     rs[2].assertValue(inc(v1));
1918     rs[3].assertValue(inc(v1));
1919 jsr166 1.40 g.complete(v2);
1920    
1921 jsr166 1.63 // unspecified behavior - both source completions available
1922     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
1923     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
1924     checkCompletedNormally(h4, null);
1925     checkCompletedNormally(h5, null);
1926     assertTrue(Objects.equals(inc(v1), rs[4].value) ||
1927     Objects.equals(inc(v2), rs[4].value));
1928     assertTrue(Objects.equals(inc(v1), rs[5].value) ||
1929     Objects.equals(inc(v2), rs[5].value));
1930 jsr166 1.40
1931     checkCompletedNormally(f, v1);
1932     checkCompletedNormally(g, v2);
1933 jsr166 1.63 checkCompletedNormally(h0, null);
1934     checkCompletedNormally(h1, null);
1935     checkCompletedNormally(h2, null);
1936     checkCompletedNormally(h3, null);
1937     for (int i = 0; i < 4; i++) rs[i].assertValue(inc(v1));
1938 jsr166 1.47 }}
1939 dl 1.5
1940     /**
1941     * acceptEither result completes exceptionally after exceptional
1942     * completion of either source
1943     */
1944 jsr166 1.63 public void testAcceptEither_exceptionalCompletion() {
1945 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
1946 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1947     {
1948 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
1949     final CompletableFuture<Integer> g = new CompletableFuture<>();
1950     final CFException ex = new CFException();
1951 jsr166 1.63 final IncAction[] rs = new IncAction[6];
1952     for (int i = 0; i < rs.length; i++) rs[i] = new IncAction(m);
1953 jsr166 1.40
1954 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
1955     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
1956     checkIncomplete(h0);
1957     checkIncomplete(h1);
1958     rs[0].assertNotInvoked();
1959     rs[1].assertNotInvoked();
1960 jsr166 1.40 f.completeExceptionally(ex);
1961 jsr166 1.63 checkCompletedWithWrappedCFException(h0, ex);
1962     checkCompletedWithWrappedCFException(h1, ex);
1963     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
1964     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
1965     checkCompletedWithWrappedCFException(h2, ex);
1966     checkCompletedWithWrappedCFException(h3, ex);
1967    
1968 jsr166 1.40 g.complete(v1);
1969    
1970 jsr166 1.63 // unspecified behavior - both source completions available
1971     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
1972     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
1973 jsr166 1.40 try {
1974 jsr166 1.63 assertNull(h4.join());
1975     rs[4].assertValue(inc(v1));
1976 jsr166 1.40 } catch (CompletionException ok) {
1977 jsr166 1.63 checkCompletedWithWrappedCFException(h4, ex);
1978     rs[4].assertNotInvoked();
1979 jsr166 1.40 }
1980     try {
1981 jsr166 1.63 assertNull(h5.join());
1982     rs[5].assertValue(inc(v1));
1983 jsr166 1.40 } catch (CompletionException ok) {
1984 jsr166 1.63 checkCompletedWithWrappedCFException(h5, ex);
1985     rs[5].assertNotInvoked();
1986 jsr166 1.40 }
1987 dl 1.5
1988 jsr166 1.40 checkCompletedWithWrappedCFException(f, ex);
1989     checkCompletedNormally(g, v1);
1990 jsr166 1.63 checkCompletedWithWrappedCFException(h0, ex);
1991     checkCompletedWithWrappedCFException(h1, ex);
1992     checkCompletedWithWrappedCFException(h2, ex);
1993     checkCompletedWithWrappedCFException(h3, ex);
1994     checkCompletedWithWrappedCFException(h4, ex);
1995     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1996 jsr166 1.47 }}
1997 dl 1.5
1998     /**
1999     * acceptEither result completes exceptionally if either source cancelled
2000     */
2001 jsr166 1.63 public void testAcceptEither_sourceCancelled() {
2002 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2003     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2004 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2005     {
2006 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2007     final CompletableFuture<Integer> g = new CompletableFuture<>();
2008 jsr166 1.63 final IncAction[] rs = new IncAction[6];
2009     for (int i = 0; i < rs.length; i++) rs[i] = new IncAction(m);
2010    
2011     final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
2012     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
2013     checkIncomplete(h0);
2014     checkIncomplete(h1);
2015     rs[0].assertNotInvoked();
2016     rs[1].assertNotInvoked();
2017     f.cancel(mayInterruptIfRunning);
2018     checkCompletedWithWrappedCancellationException(h0);
2019     checkCompletedWithWrappedCancellationException(h1);
2020     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2021     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2022     checkCompletedWithWrappedCancellationException(h2);
2023     checkCompletedWithWrappedCancellationException(h3);
2024 jsr166 1.40
2025     g.complete(v1);
2026    
2027 jsr166 1.63 // unspecified behavior - both source completions available
2028     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
2029     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
2030     try {
2031     assertNull(h4.join());
2032     rs[4].assertValue(inc(v1));
2033     } catch (CompletionException ok) {
2034     checkCompletedWithWrappedCancellationException(h4);
2035     rs[4].assertNotInvoked();
2036     }
2037     try {
2038     assertNull(h5.join());
2039     rs[5].assertValue(inc(v1));
2040     } catch (CompletionException ok) {
2041     checkCompletedWithWrappedCancellationException(h5);
2042     rs[5].assertNotInvoked();
2043     }
2044    
2045 jsr166 1.40 checkCancelled(f);
2046     checkCompletedNormally(g, v1);
2047 jsr166 1.63 checkCompletedWithWrappedCancellationException(h0);
2048     checkCompletedWithWrappedCancellationException(h1);
2049     checkCompletedWithWrappedCancellationException(h2);
2050     checkCompletedWithWrappedCancellationException(h3);
2051     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
2052 jsr166 1.47 }}
2053 jsr166 1.40
2054 jsr166 1.63 /**
2055     * acceptEither result completes exceptionally if action does
2056     */
2057     public void testAcceptEither_actionFailed() {
2058 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2059 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2060 jsr166 1.63 for (Integer v2 : new Integer[] { 2, null })
2061 jsr166 1.47 {
2062 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2063     final CompletableFuture<Integer> g = new CompletableFuture<>();
2064 jsr166 1.63 final FailingConsumer[] rs = new FailingConsumer[6];
2065     for (int i = 0; i < rs.length; i++) rs[i] = new FailingConsumer(m);
2066 jsr166 1.40
2067 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
2068     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
2069 jsr166 1.40 f.complete(v1);
2070 jsr166 1.63 final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2071     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2072     checkCompletedWithWrappedCFException(h0);
2073     checkCompletedWithWrappedCFException(h1);
2074     checkCompletedWithWrappedCFException(h2);
2075     checkCompletedWithWrappedCFException(h3);
2076     for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
2077 jsr166 1.40
2078 jsr166 1.63 g.complete(v2);
2079 jsr166 1.40
2080 jsr166 1.63 // unspecified behavior - both source completions available
2081     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
2082     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
2083 jsr166 1.40
2084 jsr166 1.63 checkCompletedWithWrappedCFException(h4);
2085     assertTrue(Objects.equals(v1, rs[4].value) ||
2086     Objects.equals(v2, rs[4].value));
2087     checkCompletedWithWrappedCFException(h5);
2088     assertTrue(Objects.equals(v1, rs[5].value) ||
2089     Objects.equals(v2, rs[5].value));
2090 jsr166 1.40
2091     checkCompletedNormally(f, v1);
2092 jsr166 1.63 checkCompletedNormally(g, v2);
2093 jsr166 1.47 }}
2094 dl 1.5
2095     /**
2096     * runAfterEither result completes normally after normal completion
2097     * of either source
2098     */
2099 jsr166 1.41 public void testRunAfterEither_normalCompletion1() {
2100     for (ExecutionMode m : ExecutionMode.values())
2101     for (Integer v1 : new Integer[] { 1, null })
2102 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2103     {
2104 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2105     final CompletableFuture<Integer> g = new CompletableFuture<>();
2106 jsr166 1.55 final Noop r = new Noop(m);
2107 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2108    
2109     f.complete(v1);
2110     checkCompletedNormally(h, null);
2111 jsr166 1.62 r.assertInvoked();
2112 jsr166 1.41 g.complete(v2);
2113    
2114     checkCompletedNormally(f, v1);
2115     checkCompletedNormally(g, v2);
2116     checkCompletedNormally(h, null);
2117 jsr166 1.62 r.assertInvoked();
2118 jsr166 1.47 }}
2119 jsr166 1.41
2120     public void testRunAfterEither_normalCompletion2() {
2121     for (ExecutionMode m : ExecutionMode.values())
2122     for (Integer v1 : new Integer[] { 1, null })
2123 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2124     {
2125 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2126     final CompletableFuture<Integer> g = new CompletableFuture<>();
2127 jsr166 1.55 final Noop r = new Noop(m);
2128 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2129    
2130     g.complete(v2);
2131     checkCompletedNormally(h, null);
2132 jsr166 1.62 r.assertInvoked();
2133 jsr166 1.41 f.complete(v1);
2134    
2135     checkCompletedNormally(f, v1);
2136     checkCompletedNormally(g, v2);
2137     checkCompletedNormally(h, null);
2138 jsr166 1.62 r.assertInvoked();
2139 jsr166 1.47 }}
2140    
2141 jsr166 1.41 public void testRunAfterEither_normalCompletion3() {
2142     for (ExecutionMode m : ExecutionMode.values())
2143     for (Integer v1 : new Integer[] { 1, null })
2144 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2145     {
2146 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2147     final CompletableFuture<Integer> g = new CompletableFuture<>();
2148 jsr166 1.55 final Noop r = new Noop(m);
2149 jsr166 1.41
2150     f.complete(v1);
2151     g.complete(v2);
2152     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2153 dl 1.5
2154 jsr166 1.41 checkCompletedNormally(h, null);
2155     checkCompletedNormally(f, v1);
2156     checkCompletedNormally(g, v2);
2157 jsr166 1.62 r.assertInvoked();
2158 jsr166 1.47 }}
2159 dl 1.5
2160     /**
2161     * runAfterEither result completes exceptionally after exceptional
2162     * completion of either source
2163     */
2164 jsr166 1.41 public void testRunAfterEither_exceptionalCompletion1() {
2165     for (ExecutionMode m : ExecutionMode.values())
2166 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2167     {
2168 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2169     final CompletableFuture<Integer> g = new CompletableFuture<>();
2170 jsr166 1.55 final Noop r = new Noop(m);
2171 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2172     final CFException ex = new CFException();
2173    
2174     f.completeExceptionally(ex);
2175     checkCompletedWithWrappedCFException(h, ex);
2176     g.complete(v1);
2177    
2178 jsr166 1.62 r.assertNotInvoked();
2179 jsr166 1.41 checkCompletedNormally(g, v1);
2180     checkCompletedWithWrappedCFException(f, ex);
2181     checkCompletedWithWrappedCFException(h, ex);
2182 jsr166 1.47 }}
2183 jsr166 1.41
2184     public void testRunAfterEither_exceptionalCompletion2() {
2185     for (ExecutionMode m : ExecutionMode.values())
2186 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2187     {
2188 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2189     final CompletableFuture<Integer> g = new CompletableFuture<>();
2190 jsr166 1.55 final Noop r = new Noop(m);
2191 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2192     final CFException ex = new CFException();
2193    
2194     g.completeExceptionally(ex);
2195     checkCompletedWithWrappedCFException(h, ex);
2196     f.complete(v1);
2197    
2198 jsr166 1.62 r.assertNotInvoked();
2199 jsr166 1.41 checkCompletedNormally(f, v1);
2200     checkCompletedWithWrappedCFException(g, ex);
2201     checkCompletedWithWrappedCFException(h, ex);
2202 jsr166 1.47 }}
2203 jsr166 1.41
2204     public void testRunAfterEither_exceptionalCompletion3() {
2205     for (ExecutionMode m : ExecutionMode.values())
2206 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2207     {
2208 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2209     final CompletableFuture<Integer> g = new CompletableFuture<>();
2210 jsr166 1.55 final Noop r = new Noop(m);
2211 jsr166 1.41 final CFException ex = new CFException();
2212    
2213     g.completeExceptionally(ex);
2214     f.complete(v1);
2215     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2216    
2217     // unspecified behavior
2218     Integer v;
2219     try {
2220 jsr166 1.46 assertNull(h.join());
2221 jsr166 1.62 r.assertInvoked();
2222 jsr166 1.41 } catch (CompletionException ok) {
2223     checkCompletedWithWrappedCFException(h, ex);
2224 jsr166 1.62 r.assertNotInvoked();
2225 jsr166 1.41 }
2226    
2227     checkCompletedWithWrappedCFException(g, ex);
2228     checkCompletedNormally(f, v1);
2229 jsr166 1.47 }}
2230 jsr166 1.41
2231     public void testRunAfterEither_exceptionalCompletion4() {
2232     for (ExecutionMode m : ExecutionMode.values())
2233 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2234     {
2235 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2236     final CompletableFuture<Integer> g = new CompletableFuture<>();
2237 jsr166 1.55 final Noop r = new Noop(m);
2238 jsr166 1.41 final CFException ex = new CFException();
2239    
2240     f.completeExceptionally(ex);
2241     g.complete(v1);
2242     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2243    
2244     // unspecified behavior
2245     Integer v;
2246     try {
2247 jsr166 1.46 assertNull(h.join());
2248 jsr166 1.62 r.assertInvoked();
2249 jsr166 1.41 } catch (CompletionException ok) {
2250     checkCompletedWithWrappedCFException(h, ex);
2251 jsr166 1.62 r.assertNotInvoked();
2252 jsr166 1.41 }
2253 dl 1.5
2254 jsr166 1.41 checkCompletedWithWrappedCFException(f, ex);
2255     checkCompletedNormally(g, v1);
2256 jsr166 1.47 }}
2257 dl 1.5
2258     /**
2259     * runAfterEither result completes exceptionally if action does
2260     */
2261 jsr166 1.41 public void testRunAfterEither_actionFailed1() {
2262     for (ExecutionMode m : ExecutionMode.values())
2263     for (Integer v1 : new Integer[] { 1, null })
2264 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2265     {
2266 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2267     final CompletableFuture<Integer> g = new CompletableFuture<>();
2268 jsr166 1.56 final FailingRunnable r = new FailingRunnable(m);
2269 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2270    
2271     f.complete(v1);
2272     checkCompletedWithWrappedCFException(h);
2273     g.complete(v2);
2274     checkCompletedNormally(f, v1);
2275     checkCompletedNormally(g, v2);
2276 jsr166 1.47 }}
2277 jsr166 1.41
2278     public void testRunAfterEither_actionFailed2() {
2279     for (ExecutionMode m : ExecutionMode.values())
2280     for (Integer v1 : new Integer[] { 1, null })
2281 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2282     {
2283 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2284     final CompletableFuture<Integer> g = new CompletableFuture<>();
2285 jsr166 1.56 final FailingRunnable r = new FailingRunnable(m);
2286 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2287    
2288     g.complete(v2);
2289     checkCompletedWithWrappedCFException(h);
2290     f.complete(v1);
2291     checkCompletedNormally(f, v1);
2292     checkCompletedNormally(g, v2);
2293 jsr166 1.47 }}
2294 dl 1.5
2295     /**
2296     * runAfterEither result completes exceptionally if either source cancelled
2297     */
2298 jsr166 1.41 public void testRunAfterEither_sourceCancelled1() {
2299     for (ExecutionMode m : ExecutionMode.values())
2300     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2301 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2302     {
2303 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2304     final CompletableFuture<Integer> g = new CompletableFuture<>();
2305 jsr166 1.55 final Noop r = new Noop(m);
2306 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2307    
2308     assertTrue(f.cancel(mayInterruptIfRunning));
2309     checkCompletedWithWrappedCancellationException(h);
2310     g.complete(v1);
2311    
2312     checkCancelled(f);
2313 jsr166 1.62 r.assertNotInvoked();
2314 jsr166 1.41 checkCompletedNormally(g, v1);
2315     checkCompletedWithWrappedCancellationException(h);
2316 jsr166 1.47 }}
2317 jsr166 1.41
2318     public void testRunAfterEither_sourceCancelled2() {
2319     for (ExecutionMode m : ExecutionMode.values())
2320     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2321 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2322     {
2323 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2324     final CompletableFuture<Integer> g = new CompletableFuture<>();
2325 jsr166 1.55 final Noop r = new Noop(m);
2326 jsr166 1.41 final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2327    
2328     assertTrue(g.cancel(mayInterruptIfRunning));
2329     checkCompletedWithWrappedCancellationException(h);
2330     f.complete(v1);
2331    
2332     checkCancelled(g);
2333 jsr166 1.62 r.assertNotInvoked();
2334 jsr166 1.41 checkCompletedNormally(f, v1);
2335     checkCompletedWithWrappedCancellationException(h);
2336 jsr166 1.47 }}
2337 jsr166 1.41
2338     public void testRunAfterEither_sourceCancelled3() {
2339     for (ExecutionMode m : ExecutionMode.values())
2340     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2341 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2342     {
2343 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2344     final CompletableFuture<Integer> g = new CompletableFuture<>();
2345 jsr166 1.55 final Noop r = new Noop(m);
2346 jsr166 1.41
2347     assertTrue(g.cancel(mayInterruptIfRunning));
2348     f.complete(v1);
2349     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2350    
2351     // unspecified behavior
2352     Integer v;
2353     try {
2354 jsr166 1.46 assertNull(h.join());
2355 jsr166 1.62 r.assertInvoked();
2356 jsr166 1.41 } catch (CompletionException ok) {
2357     checkCompletedWithWrappedCancellationException(h);
2358 jsr166 1.62 r.assertNotInvoked();
2359 jsr166 1.41 }
2360    
2361     checkCancelled(g);
2362     checkCompletedNormally(f, v1);
2363 jsr166 1.47 }}
2364 jsr166 1.41
2365     public void testRunAfterEither_sourceCancelled4() {
2366     for (ExecutionMode m : ExecutionMode.values())
2367     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2368 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2369     {
2370 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2371     final CompletableFuture<Integer> g = new CompletableFuture<>();
2372 jsr166 1.55 final Noop r = new Noop(m);
2373 jsr166 1.41
2374     assertTrue(f.cancel(mayInterruptIfRunning));
2375     g.complete(v1);
2376     final CompletableFuture<Void> h = m.runAfterEither(f, g, r);
2377    
2378     // unspecified behavior
2379     Integer v;
2380     try {
2381 jsr166 1.46 assertNull(h.join());
2382 jsr166 1.62 r.assertInvoked();
2383 jsr166 1.41 } catch (CompletionException ok) {
2384     checkCompletedWithWrappedCancellationException(h);
2385 jsr166 1.62 r.assertNotInvoked();
2386 jsr166 1.41 }
2387    
2388     checkCancelled(f);
2389     checkCompletedNormally(g, v1);
2390 jsr166 1.47 }}
2391 dl 1.5
2392     /**
2393     * thenCompose result completes normally after normal completion of source
2394     */
2395 jsr166 1.48 public void testThenCompose_normalCompletion() {
2396 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2397 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2398 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2399     {
2400 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2401 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2402 jsr166 1.48 if (!createIncomplete) f.complete(v1);
2403 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2404 jsr166 1.48 if (createIncomplete) f.complete(v1);
2405 jsr166 1.21
2406 jsr166 1.44 checkCompletedNormally(g, inc(v1));
2407     checkCompletedNormally(f, v1);
2408 jsr166 1.62 r.assertInvoked();
2409 jsr166 1.47 }}
2410 dl 1.5
2411     /**
2412     * thenCompose result completes exceptionally after exceptional
2413     * completion of source
2414     */
2415 jsr166 1.48 public void testThenCompose_exceptionalCompletion() {
2416 jsr166 1.47 for (ExecutionMode m : ExecutionMode.values())
2417 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2418 jsr166 1.47 {
2419 jsr166 1.44 final CFException ex = new CFException();
2420 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2421 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2422 jsr166 1.48 if (!createIncomplete) f.completeExceptionally(ex);
2423 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2424 jsr166 1.48 if (createIncomplete) f.completeExceptionally(ex);
2425 jsr166 1.21
2426 jsr166 1.44 checkCompletedWithWrappedCFException(g, ex);
2427     checkCompletedWithWrappedCFException(f, ex);
2428 jsr166 1.62 r.assertNotInvoked();
2429 jsr166 1.47 }}
2430 dl 1.5
2431     /**
2432     * thenCompose result completes exceptionally if action does
2433     */
2434 jsr166 1.48 public void testThenCompose_actionFailed() {
2435 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2436 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2437 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2438     {
2439 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2440     final FailingCompletableFutureFunction r
2441 jsr166 1.56 = new FailingCompletableFutureFunction(m);
2442 jsr166 1.48 if (!createIncomplete) f.complete(v1);
2443 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2444 jsr166 1.48 if (createIncomplete) f.complete(v1);
2445 jsr166 1.44
2446 dl 1.5 checkCompletedWithWrappedCFException(g);
2447 jsr166 1.44 checkCompletedNormally(f, v1);
2448 jsr166 1.47 }}
2449 dl 1.5
2450     /**
2451     * thenCompose result completes exceptionally if source cancelled
2452     */
2453 jsr166 1.48 public void testThenCompose_sourceCancelled() {
2454 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2455 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2456 jsr166 1.47 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2457     {
2458 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2459 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2460 jsr166 1.48 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2461 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2462 jsr166 1.50 if (createIncomplete) {
2463     checkIncomplete(g);
2464     assertTrue(f.cancel(mayInterruptIfRunning));
2465     }
2466 jsr166 1.44
2467 dl 1.5 checkCompletedWithWrappedCancellationException(g);
2468 jsr166 1.44 checkCancelled(f);
2469 jsr166 1.47 }}
2470 dl 1.5
2471 jsr166 1.6 // other static methods
2472 dl 1.5
2473     /**
2474     * allOf(no component futures) returns a future completed normally
2475     * with the value null
2476     */
2477     public void testAllOf_empty() throws Exception {
2478 jsr166 1.24 CompletableFuture<Void> f = CompletableFuture.allOf();
2479 dl 1.5 checkCompletedNormally(f, null);
2480     }
2481    
2482     /**
2483 jsr166 1.25 * allOf returns a future completed normally with the value null
2484     * when all components complete normally
2485 dl 1.5 */
2486 jsr166 1.25 public void testAllOf_normal() throws Exception {
2487 dl 1.5 for (int k = 1; k < 20; ++k) {
2488 jsr166 1.59 CompletableFuture<Integer>[] fs
2489     = (CompletableFuture<Integer>[]) new CompletableFuture[k];
2490 jsr166 1.6 for (int i = 0; i < k; ++i)
2491 jsr166 1.22 fs[i] = new CompletableFuture<>();
2492 dl 1.9 CompletableFuture<Void> f = CompletableFuture.allOf(fs);
2493 dl 1.5 for (int i = 0; i < k; ++i) {
2494     checkIncomplete(f);
2495 jsr166 1.24 checkIncomplete(CompletableFuture.allOf(fs));
2496 dl 1.5 fs[i].complete(one);
2497     }
2498 dl 1.9 checkCompletedNormally(f, null);
2499 jsr166 1.24 checkCompletedNormally(CompletableFuture.allOf(fs), null);
2500 dl 1.5 }
2501     }
2502    
2503 jsr166 1.59 public void testAllOf_backwards() throws Exception {
2504     for (int k = 1; k < 20; ++k) {
2505     CompletableFuture<Integer>[] fs
2506     = (CompletableFuture<Integer>[]) new CompletableFuture[k];
2507     for (int i = 0; i < k; ++i)
2508     fs[i] = new CompletableFuture<>();
2509     CompletableFuture<Void> f = CompletableFuture.allOf(fs);
2510     for (int i = k - 1; i >= 0; i--) {
2511     checkIncomplete(f);
2512     checkIncomplete(CompletableFuture.allOf(fs));
2513     fs[i].complete(one);
2514     }
2515     checkCompletedNormally(f, null);
2516     checkCompletedNormally(CompletableFuture.allOf(fs), null);
2517     }
2518     }
2519    
2520 dl 1.5 /**
2521     * anyOf(no component futures) returns an incomplete future
2522     */
2523     public void testAnyOf_empty() throws Exception {
2524 jsr166 1.24 CompletableFuture<Object> f = CompletableFuture.anyOf();
2525 dl 1.5 checkIncomplete(f);
2526     }
2527    
2528     /**
2529 jsr166 1.25 * anyOf returns a future completed normally with a value when
2530     * a component future does
2531 dl 1.5 */
2532 jsr166 1.24 public void testAnyOf_normal() throws Exception {
2533     for (int k = 0; k < 10; ++k) {
2534 dl 1.5 CompletableFuture[] fs = new CompletableFuture[k];
2535 jsr166 1.6 for (int i = 0; i < k; ++i)
2536 jsr166 1.22 fs[i] = new CompletableFuture<>();
2537 dl 1.9 CompletableFuture<Object> f = CompletableFuture.anyOf(fs);
2538 dl 1.5 checkIncomplete(f);
2539     for (int i = 0; i < k; ++i) {
2540     fs[i].complete(one);
2541 dl 1.9 checkCompletedNormally(f, one);
2542 jsr166 1.24 checkCompletedNormally(CompletableFuture.anyOf(fs), one);
2543     }
2544     }
2545     }
2546    
2547     /**
2548     * anyOf result completes exceptionally when any component does.
2549     */
2550     public void testAnyOf_exceptional() throws Exception {
2551     for (int k = 0; k < 10; ++k) {
2552     CompletableFuture[] fs = new CompletableFuture[k];
2553     for (int i = 0; i < k; ++i)
2554     fs[i] = new CompletableFuture<>();
2555     CompletableFuture<Object> f = CompletableFuture.anyOf(fs);
2556     checkIncomplete(f);
2557     for (int i = 0; i < k; ++i) {
2558     fs[i].completeExceptionally(new CFException());
2559     checkCompletedWithWrappedCFException(f);
2560     checkCompletedWithWrappedCFException(CompletableFuture.anyOf(fs));
2561 dl 1.5 }
2562     }
2563     }
2564    
2565     /**
2566     * Completion methods throw NullPointerException with null arguments
2567     */
2568     public void testNPE() {
2569 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
2570     CompletableFuture<Integer> g = new CompletableFuture<>();
2571 jsr166 1.14 CompletableFuture<Integer> nullFuture = (CompletableFuture<Integer>)null;
2572     CompletableFuture<?> h;
2573 jsr166 1.17 ThreadExecutor exec = new ThreadExecutor();
2574 jsr166 1.14
2575     Runnable[] throwingActions = {
2576 jsr166 1.31 () -> CompletableFuture.supplyAsync(null),
2577     () -> CompletableFuture.supplyAsync(null, exec),
2578 jsr166 1.58 () -> CompletableFuture.supplyAsync(new IntegerSupplier(ExecutionMode.DEFAULT, 42), null),
2579 jsr166 1.31
2580     () -> CompletableFuture.runAsync(null),
2581     () -> CompletableFuture.runAsync(null, exec),
2582     () -> CompletableFuture.runAsync(() -> {}, null),
2583    
2584     () -> f.completeExceptionally(null),
2585    
2586     () -> f.thenApply(null),
2587     () -> f.thenApplyAsync(null),
2588     () -> f.thenApplyAsync((x) -> x, null),
2589     () -> f.thenApplyAsync(null, exec),
2590    
2591     () -> f.thenAccept(null),
2592     () -> f.thenAcceptAsync(null),
2593     () -> f.thenAcceptAsync((x) -> {} , null),
2594     () -> f.thenAcceptAsync(null, exec),
2595    
2596     () -> f.thenRun(null),
2597     () -> f.thenRunAsync(null),
2598     () -> f.thenRunAsync(() -> {} , null),
2599     () -> f.thenRunAsync(null, exec),
2600    
2601     () -> f.thenCombine(g, null),
2602     () -> f.thenCombineAsync(g, null),
2603     () -> f.thenCombineAsync(g, null, exec),
2604     () -> f.thenCombine(nullFuture, (x, y) -> x),
2605     () -> f.thenCombineAsync(nullFuture, (x, y) -> x),
2606     () -> f.thenCombineAsync(nullFuture, (x, y) -> x, exec),
2607     () -> f.thenCombineAsync(g, (x, y) -> x, null),
2608    
2609     () -> f.thenAcceptBoth(g, null),
2610     () -> f.thenAcceptBothAsync(g, null),
2611     () -> f.thenAcceptBothAsync(g, null, exec),
2612     () -> f.thenAcceptBoth(nullFuture, (x, y) -> {}),
2613     () -> f.thenAcceptBothAsync(nullFuture, (x, y) -> {}),
2614     () -> f.thenAcceptBothAsync(nullFuture, (x, y) -> {}, exec),
2615     () -> f.thenAcceptBothAsync(g, (x, y) -> {}, null),
2616    
2617     () -> f.runAfterBoth(g, null),
2618     () -> f.runAfterBothAsync(g, null),
2619     () -> f.runAfterBothAsync(g, null, exec),
2620     () -> f.runAfterBoth(nullFuture, () -> {}),
2621     () -> f.runAfterBothAsync(nullFuture, () -> {}),
2622     () -> f.runAfterBothAsync(nullFuture, () -> {}, exec),
2623     () -> f.runAfterBothAsync(g, () -> {}, null),
2624    
2625     () -> f.applyToEither(g, null),
2626     () -> f.applyToEitherAsync(g, null),
2627     () -> f.applyToEitherAsync(g, null, exec),
2628     () -> f.applyToEither(nullFuture, (x) -> x),
2629     () -> f.applyToEitherAsync(nullFuture, (x) -> x),
2630     () -> f.applyToEitherAsync(nullFuture, (x) -> x, exec),
2631     () -> f.applyToEitherAsync(g, (x) -> x, null),
2632    
2633     () -> f.acceptEither(g, null),
2634     () -> f.acceptEitherAsync(g, null),
2635     () -> f.acceptEitherAsync(g, null, exec),
2636     () -> f.acceptEither(nullFuture, (x) -> {}),
2637     () -> f.acceptEitherAsync(nullFuture, (x) -> {}),
2638     () -> f.acceptEitherAsync(nullFuture, (x) -> {}, exec),
2639     () -> f.acceptEitherAsync(g, (x) -> {}, null),
2640    
2641     () -> f.runAfterEither(g, null),
2642     () -> f.runAfterEitherAsync(g, null),
2643     () -> f.runAfterEitherAsync(g, null, exec),
2644     () -> f.runAfterEither(nullFuture, () -> {}),
2645     () -> f.runAfterEitherAsync(nullFuture, () -> {}),
2646     () -> f.runAfterEitherAsync(nullFuture, () -> {}, exec),
2647     () -> f.runAfterEitherAsync(g, () -> {}, null),
2648    
2649     () -> f.thenCompose(null),
2650     () -> f.thenComposeAsync(null),
2651 jsr166 1.56 () -> f.thenComposeAsync(new CompletableFutureInc(ExecutionMode.EXECUTOR), null),
2652 jsr166 1.31 () -> f.thenComposeAsync(null, exec),
2653    
2654     () -> f.exceptionally(null),
2655    
2656     () -> f.handle(null),
2657    
2658     () -> CompletableFuture.allOf((CompletableFuture<?>)null),
2659     () -> CompletableFuture.allOf((CompletableFuture<?>[])null),
2660     () -> CompletableFuture.allOf(f, null),
2661     () -> CompletableFuture.allOf(null, f),
2662    
2663     () -> CompletableFuture.anyOf((CompletableFuture<?>)null),
2664     () -> CompletableFuture.anyOf((CompletableFuture<?>[])null),
2665     () -> CompletableFuture.anyOf(f, null),
2666     () -> CompletableFuture.anyOf(null, f),
2667 jsr166 1.32
2668     () -> f.obtrudeException(null),
2669 jsr166 1.14 };
2670 dl 1.5
2671 jsr166 1.14 assertThrows(NullPointerException.class, throwingActions);
2672 jsr166 1.17 assertEquals(0, exec.count.get());
2673 dl 1.5 }
2674    
2675 dl 1.26 /**
2676     * toCompletableFuture returns this CompletableFuture.
2677     */
2678     public void testToCompletableFuture() {
2679     CompletableFuture<Integer> f = new CompletableFuture<>();
2680     assertSame(f, f.toCompletableFuture());
2681     }
2682    
2683     /**
2684     * whenComplete action executes on normal completion, propagating
2685     * source result.
2686     */
2687 jsr166 1.42 public void testWhenComplete_normalCompletion1() {
2688 jsr166 1.46 for (ExecutionMode m : ExecutionMode.values())
2689 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2690 jsr166 1.46 for (Integer v1 : new Integer[] { 1, null })
2691     {
2692     final AtomicInteger a = new AtomicInteger(0);
2693 jsr166 1.42 final CompletableFuture<Integer> f = new CompletableFuture<>();
2694 jsr166 1.44 if (!createIncomplete) f.complete(v1);
2695 jsr166 1.46 final CompletableFuture<Integer> g = m.whenComplete
2696     (f,
2697     (Integer x, Throwable t) -> {
2698     threadAssertSame(x, v1);
2699     threadAssertNull(t);
2700     a.getAndIncrement();
2701     });
2702 jsr166 1.44 if (createIncomplete) f.complete(v1);
2703 jsr166 1.46
2704     checkCompletedNormally(g, v1);
2705 jsr166 1.42 checkCompletedNormally(f, v1);
2706 jsr166 1.46 assertEquals(1, a.get());
2707     }}
2708 dl 1.26
2709     /**
2710     * whenComplete action executes on exceptional completion, propagating
2711     * source result.
2712     */
2713 jsr166 1.42 public void testWhenComplete_exceptionalCompletion() {
2714 jsr166 1.46 for (ExecutionMode m : ExecutionMode.values())
2715 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2716 jsr166 1.46 for (Integer v1 : new Integer[] { 1, null })
2717     {
2718     final AtomicInteger a = new AtomicInteger(0);
2719 jsr166 1.42 final CFException ex = new CFException();
2720     final CompletableFuture<Integer> f = new CompletableFuture<>();
2721 jsr166 1.44 if (!createIncomplete) f.completeExceptionally(ex);
2722 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2723     (f,
2724     (Integer x, Throwable t) -> {
2725     threadAssertNull(x);
2726     threadAssertSame(t, ex);
2727     a.getAndIncrement();
2728     });
2729 jsr166 1.44 if (createIncomplete) f.completeExceptionally(ex);
2730 jsr166 1.42 checkCompletedWithWrappedCFException(f, ex);
2731     checkCompletedWithWrappedCFException(g, ex);
2732 jsr166 1.46 assertEquals(1, a.get());
2733     }}
2734    
2735     /**
2736     * whenComplete action executes on cancelled source, propagating
2737     * CancellationException.
2738     */
2739     public void testWhenComplete_sourceCancelled() {
2740     for (ExecutionMode m : ExecutionMode.values())
2741     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2742     for (boolean createIncomplete : new boolean[] { true, false })
2743     {
2744     final AtomicInteger a = new AtomicInteger(0);
2745     final CompletableFuture<Integer> f = new CompletableFuture<>();
2746     if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2747     final CompletableFuture<Integer> g = m.whenComplete
2748     (f,
2749     (Integer x, Throwable t) -> {
2750     threadAssertNull(x);
2751     threadAssertTrue(t instanceof CancellationException);
2752     a.getAndIncrement();
2753     });
2754     if (createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2755    
2756     //try { g.join(); } catch (Throwable t) { throw new Error(t); }
2757     checkCompletedWithWrappedCancellationException(g);
2758     checkCancelled(f);
2759     assertEquals(1, a.get());
2760     }}
2761 dl 1.26
2762     /**
2763     * If a whenComplete action throws an exception when triggered by
2764     * a normal completion, it completes exceptionally
2765     */
2766 jsr166 1.42 public void testWhenComplete_actionFailed() {
2767 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2768 jsr166 1.42 for (ExecutionMode m : ExecutionMode.values())
2769 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2770     {
2771 jsr166 1.46 final AtomicInteger a = new AtomicInteger(0);
2772 jsr166 1.42 final CFException ex = new CFException();
2773     final CompletableFuture<Integer> f = new CompletableFuture<>();
2774 jsr166 1.44 if (!createIncomplete) f.complete(v1);
2775 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2776     (f,
2777     (Integer x, Throwable t) -> {
2778     threadAssertSame(x, v1);
2779     threadAssertNull(t);
2780 jsr166 1.46 a.getAndIncrement();
2781 jsr166 1.42 throw ex;
2782     });
2783 jsr166 1.44 if (createIncomplete) f.complete(v1);
2784 jsr166 1.42 checkCompletedNormally(f, v1);
2785     checkCompletedWithWrappedCFException(g, ex);
2786 jsr166 1.46 assertEquals(1, a.get());
2787 jsr166 1.47 }}
2788 dl 1.26
2789     /**
2790 jsr166 1.42 * If a whenComplete action throws an exception when triggered by
2791     * a source completion that also throws an exception, the source
2792     * exception takes precedence.
2793 dl 1.26 */
2794 jsr166 1.42 public void testWhenComplete_actionFailedSourceFailed() {
2795 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2796 jsr166 1.42 for (ExecutionMode m : ExecutionMode.values())
2797 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2798     {
2799 jsr166 1.46 final AtomicInteger a = new AtomicInteger(0);
2800 jsr166 1.42 final CFException ex1 = new CFException();
2801     final CFException ex2 = new CFException();
2802     final CompletableFuture<Integer> f = new CompletableFuture<>();
2803 jsr166 1.44
2804     if (!createIncomplete) f.completeExceptionally(ex1);
2805 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2806     (f,
2807     (Integer x, Throwable t) -> {
2808     threadAssertSame(t, ex1);
2809     threadAssertNull(x);
2810 jsr166 1.46 a.getAndIncrement();
2811 jsr166 1.42 throw ex2;
2812     });
2813 jsr166 1.44 if (createIncomplete) f.completeExceptionally(ex1);
2814    
2815 jsr166 1.42 checkCompletedWithWrappedCFException(f, ex1);
2816     checkCompletedWithWrappedCFException(g, ex1);
2817 jsr166 1.46 assertEquals(1, a.get());
2818 jsr166 1.47 }}
2819 dl 1.26
2820 jsr166 1.1 }