ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/CompletableFutureTest.java
Revision: 1.65
Committed: Fri Jun 6 17:41:02 2014 UTC (9 years, 11 months ago) by jsr166
Branch: MAIN
Changes since 1.64: +124 -225 lines
Log Message:
improve tests for runAfterEither

File Contents

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