ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/CompletableFutureTest.java
Revision: 1.66
Committed: Fri Jun 6 19:19:04 2014 UTC (9 years, 11 months ago) by jsr166
Branch: MAIN
Changes since 1.65: +61 -4 lines
Log Message:
improve tests for applyToEither

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 jsr166 1.66 rs[4].assertValue(inc(v1));
1769 jsr166 1.62 } catch (CompletionException ok) {
1770     checkCompletedWithWrappedCFException(h4, ex);
1771     rs[4].assertNotInvoked();
1772     }
1773     try {
1774     assertEquals(inc(v1), h5.join());
1775 jsr166 1.66 rs[5].assertValue(inc(v1));
1776 jsr166 1.62 } 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.66 public void testApplyToEither_exceptionalCompletion2() {
1792     for (ExecutionMode m : ExecutionMode.values())
1793     for (boolean fFirst : new boolean[] { true, false })
1794     for (Integer v1 : new Integer[] { 1, null })
1795     {
1796     final CompletableFuture<Integer> f = new CompletableFuture<>();
1797     final CompletableFuture<Integer> g = new CompletableFuture<>();
1798     final CFException ex = new CFException();
1799     final IncFunction[] rs = new IncFunction[6];
1800     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1801    
1802     final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1803     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1804     if (fFirst) {
1805     f.complete(v1);
1806     g.completeExceptionally(ex);
1807     } else {
1808     g.completeExceptionally(ex);
1809     f.complete(v1);
1810     }
1811     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1812     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1813    
1814     // unspecified behavior - both source completions available
1815     try {
1816     assertEquals(inc(v1), h0.join());
1817     rs[0].assertValue(inc(v1));
1818     } catch (CompletionException ok) {
1819     checkCompletedWithWrappedCFException(h0, ex);
1820     rs[0].assertNotInvoked();
1821     }
1822     try {
1823     assertEquals(inc(v1), h1.join());
1824     rs[1].assertValue(inc(v1));
1825     } catch (CompletionException ok) {
1826     checkCompletedWithWrappedCFException(h1, ex);
1827     rs[1].assertNotInvoked();
1828     }
1829     try {
1830     assertEquals(inc(v1), h2.join());
1831     rs[2].assertValue(inc(v1));
1832     } catch (CompletionException ok) {
1833     checkCompletedWithWrappedCFException(h2, ex);
1834     rs[2].assertNotInvoked();
1835     }
1836     try {
1837     assertEquals(inc(v1), h3.join());
1838     rs[3].assertValue(inc(v1));
1839     } catch (CompletionException ok) {
1840     checkCompletedWithWrappedCFException(h3, ex);
1841     rs[3].assertNotInvoked();
1842     }
1843    
1844     checkCompletedNormally(f, v1);
1845     checkCompletedWithWrappedCFException(g, ex);
1846     }}
1847    
1848 jsr166 1.62 /**
1849     * applyToEither result completes exceptionally if either source cancelled
1850     */
1851     public void testApplyToEither_sourceCancelled() {
1852 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1853 jsr166 1.62 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
1854 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
1855     {
1856 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1857     final CompletableFuture<Integer> g = new CompletableFuture<>();
1858 jsr166 1.62 final IncFunction[] rs = new IncFunction[6];
1859     for (int i = 0; i < rs.length; i++) rs[i] = new IncFunction(m);
1860    
1861     final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1862     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1863     checkIncomplete(h0);
1864     checkIncomplete(h1);
1865     rs[0].assertNotInvoked();
1866     rs[1].assertNotInvoked();
1867     f.cancel(mayInterruptIfRunning);
1868     checkCompletedWithWrappedCancellationException(h0);
1869     checkCompletedWithWrappedCancellationException(h1);
1870     final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1871     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1872     checkCompletedWithWrappedCancellationException(h2);
1873     checkCompletedWithWrappedCancellationException(h3);
1874     g.complete(v1);
1875 jsr166 1.39
1876 jsr166 1.62 // unspecified behavior - both source completions available
1877     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1878     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1879 jsr166 1.39 try {
1880 jsr166 1.62 assertEquals(inc(v1), h4.join());
1881 jsr166 1.66 rs[4].assertValue(inc(v1));
1882 jsr166 1.39 } catch (CompletionException ok) {
1883 jsr166 1.62 checkCompletedWithWrappedCancellationException(h4);
1884     rs[4].assertNotInvoked();
1885 jsr166 1.39 }
1886     try {
1887 jsr166 1.62 assertEquals(inc(v1), h5.join());
1888 jsr166 1.66 rs[5].assertValue(inc(v1));
1889 jsr166 1.39 } catch (CompletionException ok) {
1890 jsr166 1.62 checkCompletedWithWrappedCancellationException(h5);
1891     rs[5].assertNotInvoked();
1892 jsr166 1.39 }
1893 dl 1.5
1894 jsr166 1.62 checkCancelled(f);
1895     checkCompletedNormally(g, v1);
1896     checkCompletedWithWrappedCancellationException(h0);
1897     checkCompletedWithWrappedCancellationException(h1);
1898     checkCompletedWithWrappedCancellationException(h2);
1899     checkCompletedWithWrappedCancellationException(h3);
1900     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
1901 jsr166 1.47 }}
1902 dl 1.5
1903     /**
1904     * applyToEither result completes exceptionally if action does
1905     */
1906 jsr166 1.62 public void testApplyToEither_actionFailed() {
1907 jsr166 1.39 for (ExecutionMode m : ExecutionMode.values())
1908     for (Integer v1 : new Integer[] { 1, null })
1909 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1910     {
1911 jsr166 1.39 final CompletableFuture<Integer> f = new CompletableFuture<>();
1912     final CompletableFuture<Integer> g = new CompletableFuture<>();
1913 jsr166 1.62 final FailingFunction[] rs = new FailingFunction[6];
1914     for (int i = 0; i < rs.length; i++) rs[i] = new FailingFunction(m);
1915 jsr166 1.39
1916 jsr166 1.62 final CompletableFuture<Integer> h0 = m.applyToEither(f, g, rs[0]);
1917     final CompletableFuture<Integer> h1 = m.applyToEither(g, f, rs[1]);
1918 jsr166 1.39 f.complete(v1);
1919 jsr166 1.62 final CompletableFuture<Integer> h2 = m.applyToEither(f, g, rs[2]);
1920     final CompletableFuture<Integer> h3 = m.applyToEither(g, f, rs[3]);
1921     checkCompletedWithWrappedCFException(h0);
1922     checkCompletedWithWrappedCFException(h1);
1923     checkCompletedWithWrappedCFException(h2);
1924     checkCompletedWithWrappedCFException(h3);
1925 jsr166 1.63 for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
1926    
1927     g.complete(v2);
1928    
1929     // unspecified behavior - both source completions available
1930     final CompletableFuture<Integer> h4 = m.applyToEither(f, g, rs[4]);
1931     final CompletableFuture<Integer> h5 = m.applyToEither(g, f, rs[5]);
1932    
1933 jsr166 1.62 checkCompletedWithWrappedCFException(h4);
1934 jsr166 1.63 assertTrue(Objects.equals(v1, rs[4].value) ||
1935     Objects.equals(v2, rs[4].value));
1936 jsr166 1.62 checkCompletedWithWrappedCFException(h5);
1937 jsr166 1.63 assertTrue(Objects.equals(v1, rs[5].value) ||
1938     Objects.equals(v2, rs[5].value));
1939    
1940     checkCompletedNormally(f, v1);
1941     checkCompletedNormally(g, v2);
1942 jsr166 1.47 }}
1943 dl 1.5
1944     /**
1945     * acceptEither result completes normally after normal completion
1946     * of either source
1947     */
1948 jsr166 1.63 public void testAcceptEither_normalCompletion() {
1949 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
1950     for (Integer v1 : new Integer[] { 1, null })
1951 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
1952     {
1953 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
1954     final CompletableFuture<Integer> g = new CompletableFuture<>();
1955 jsr166 1.64 final NoopConsumer[] rs = new NoopConsumer[6];
1956     for (int i = 0; i < rs.length; i++) rs[i] = new NoopConsumer(m);
1957 jsr166 1.40
1958 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
1959     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
1960     checkIncomplete(h0);
1961     checkIncomplete(h1);
1962     rs[0].assertNotInvoked();
1963     rs[1].assertNotInvoked();
1964 jsr166 1.40 f.complete(v1);
1965 jsr166 1.63 checkCompletedNormally(h0, null);
1966     checkCompletedNormally(h1, null);
1967 jsr166 1.64 rs[0].assertValue(v1);
1968     rs[1].assertValue(v1);
1969 jsr166 1.63 final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
1970     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
1971     checkCompletedNormally(h2, null);
1972     checkCompletedNormally(h3, null);
1973 jsr166 1.64 rs[2].assertValue(v1);
1974     rs[3].assertValue(v1);
1975 jsr166 1.40 g.complete(v2);
1976    
1977 jsr166 1.63 // unspecified behavior - both source completions available
1978     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
1979     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
1980     checkCompletedNormally(h4, null);
1981     checkCompletedNormally(h5, null);
1982 jsr166 1.64 assertTrue(Objects.equals(v1, rs[4].value) ||
1983     Objects.equals(v2, rs[4].value));
1984     assertTrue(Objects.equals(v1, rs[5].value) ||
1985     Objects.equals(v2, rs[5].value));
1986 jsr166 1.40
1987     checkCompletedNormally(f, v1);
1988     checkCompletedNormally(g, v2);
1989 jsr166 1.63 checkCompletedNormally(h0, null);
1990     checkCompletedNormally(h1, null);
1991     checkCompletedNormally(h2, null);
1992     checkCompletedNormally(h3, null);
1993 jsr166 1.64 for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
1994 jsr166 1.47 }}
1995 dl 1.5
1996     /**
1997     * acceptEither result completes exceptionally after exceptional
1998     * completion of either source
1999     */
2000 jsr166 1.63 public void testAcceptEither_exceptionalCompletion() {
2001 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2002 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2003     {
2004 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2005     final CompletableFuture<Integer> g = new CompletableFuture<>();
2006     final CFException ex = new CFException();
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.40
2010 jsr166 1.63 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 jsr166 1.40 f.completeExceptionally(ex);
2017 jsr166 1.63 checkCompletedWithWrappedCFException(h0, ex);
2018     checkCompletedWithWrappedCFException(h1, ex);
2019     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2020     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2021     checkCompletedWithWrappedCFException(h2, ex);
2022     checkCompletedWithWrappedCFException(h3, ex);
2023    
2024 jsr166 1.40 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 jsr166 1.40 try {
2030 jsr166 1.63 assertNull(h4.join());
2031 jsr166 1.64 rs[4].assertValue(v1);
2032 jsr166 1.40 } catch (CompletionException ok) {
2033 jsr166 1.63 checkCompletedWithWrappedCFException(h4, ex);
2034     rs[4].assertNotInvoked();
2035 jsr166 1.40 }
2036     try {
2037 jsr166 1.63 assertNull(h5.join());
2038 jsr166 1.64 rs[5].assertValue(v1);
2039 jsr166 1.40 } catch (CompletionException ok) {
2040 jsr166 1.63 checkCompletedWithWrappedCFException(h5, ex);
2041     rs[5].assertNotInvoked();
2042 jsr166 1.40 }
2043 dl 1.5
2044 jsr166 1.40 checkCompletedWithWrappedCFException(f, ex);
2045     checkCompletedNormally(g, v1);
2046 jsr166 1.63 checkCompletedWithWrappedCFException(h0, ex);
2047     checkCompletedWithWrappedCFException(h1, ex);
2048     checkCompletedWithWrappedCFException(h2, ex);
2049     checkCompletedWithWrappedCFException(h3, ex);
2050     checkCompletedWithWrappedCFException(h4, ex);
2051     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
2052 jsr166 1.47 }}
2053 dl 1.5
2054     /**
2055     * acceptEither result completes exceptionally if either source cancelled
2056     */
2057 jsr166 1.63 public void testAcceptEither_sourceCancelled() {
2058 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2059     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2060 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2061     {
2062 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2063     final CompletableFuture<Integer> g = new CompletableFuture<>();
2064 jsr166 1.64 final NoopConsumer[] rs = new NoopConsumer[6];
2065     for (int i = 0; i < rs.length; i++) rs[i] = new NoopConsumer(m);
2066 jsr166 1.63
2067     final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
2068     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
2069     checkIncomplete(h0);
2070     checkIncomplete(h1);
2071     rs[0].assertNotInvoked();
2072     rs[1].assertNotInvoked();
2073     f.cancel(mayInterruptIfRunning);
2074     checkCompletedWithWrappedCancellationException(h0);
2075     checkCompletedWithWrappedCancellationException(h1);
2076     final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2077     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2078     checkCompletedWithWrappedCancellationException(h2);
2079     checkCompletedWithWrappedCancellationException(h3);
2080 jsr166 1.40
2081     g.complete(v1);
2082    
2083 jsr166 1.63 // unspecified behavior - both source completions available
2084     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
2085     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
2086     try {
2087     assertNull(h4.join());
2088 jsr166 1.64 rs[4].assertValue(v1);
2089 jsr166 1.63 } catch (CompletionException ok) {
2090     checkCompletedWithWrappedCancellationException(h4);
2091     rs[4].assertNotInvoked();
2092     }
2093     try {
2094     assertNull(h5.join());
2095 jsr166 1.64 rs[5].assertValue(v1);
2096 jsr166 1.63 } catch (CompletionException ok) {
2097     checkCompletedWithWrappedCancellationException(h5);
2098     rs[5].assertNotInvoked();
2099     }
2100    
2101 jsr166 1.40 checkCancelled(f);
2102     checkCompletedNormally(g, v1);
2103 jsr166 1.63 checkCompletedWithWrappedCancellationException(h0);
2104     checkCompletedWithWrappedCancellationException(h1);
2105     checkCompletedWithWrappedCancellationException(h2);
2106     checkCompletedWithWrappedCancellationException(h3);
2107     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
2108 jsr166 1.47 }}
2109 jsr166 1.40
2110 jsr166 1.63 /**
2111     * acceptEither result completes exceptionally if action does
2112     */
2113     public void testAcceptEither_actionFailed() {
2114 jsr166 1.40 for (ExecutionMode m : ExecutionMode.values())
2115 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2116 jsr166 1.63 for (Integer v2 : new Integer[] { 2, null })
2117 jsr166 1.47 {
2118 jsr166 1.40 final CompletableFuture<Integer> f = new CompletableFuture<>();
2119     final CompletableFuture<Integer> g = new CompletableFuture<>();
2120 jsr166 1.63 final FailingConsumer[] rs = new FailingConsumer[6];
2121     for (int i = 0; i < rs.length; i++) rs[i] = new FailingConsumer(m);
2122 jsr166 1.40
2123 jsr166 1.63 final CompletableFuture<Void> h0 = m.acceptEither(f, g, rs[0]);
2124     final CompletableFuture<Void> h1 = m.acceptEither(g, f, rs[1]);
2125 jsr166 1.40 f.complete(v1);
2126 jsr166 1.63 final CompletableFuture<Void> h2 = m.acceptEither(f, g, rs[2]);
2127     final CompletableFuture<Void> h3 = m.acceptEither(g, f, rs[3]);
2128     checkCompletedWithWrappedCFException(h0);
2129     checkCompletedWithWrappedCFException(h1);
2130     checkCompletedWithWrappedCFException(h2);
2131     checkCompletedWithWrappedCFException(h3);
2132     for (int i = 0; i < 4; i++) rs[i].assertValue(v1);
2133 jsr166 1.40
2134 jsr166 1.63 g.complete(v2);
2135 jsr166 1.40
2136 jsr166 1.63 // unspecified behavior - both source completions available
2137     final CompletableFuture<Void> h4 = m.acceptEither(f, g, rs[4]);
2138     final CompletableFuture<Void> h5 = m.acceptEither(g, f, rs[5]);
2139 jsr166 1.40
2140 jsr166 1.63 checkCompletedWithWrappedCFException(h4);
2141     assertTrue(Objects.equals(v1, rs[4].value) ||
2142     Objects.equals(v2, rs[4].value));
2143     checkCompletedWithWrappedCFException(h5);
2144     assertTrue(Objects.equals(v1, rs[5].value) ||
2145     Objects.equals(v2, rs[5].value));
2146 jsr166 1.40
2147     checkCompletedNormally(f, v1);
2148 jsr166 1.63 checkCompletedNormally(g, v2);
2149 jsr166 1.47 }}
2150 dl 1.5
2151     /**
2152     * runAfterEither result completes normally after normal completion
2153     * of either source
2154     */
2155 jsr166 1.65 public void testRunAfterEither_normalCompletion() {
2156 jsr166 1.41 for (ExecutionMode m : ExecutionMode.values())
2157     for (Integer v1 : new Integer[] { 1, null })
2158 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2159     {
2160 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2161     final CompletableFuture<Integer> g = new CompletableFuture<>();
2162 jsr166 1.65 final Noop[] rs = new Noop[6];
2163     for (int i = 0; i < rs.length; i++) rs[i] = new Noop(m);
2164 jsr166 1.41
2165 jsr166 1.65 final CompletableFuture<Void> h0 = m.runAfterEither(f, g, rs[0]);
2166     final CompletableFuture<Void> h1 = m.runAfterEither(g, f, rs[1]);
2167     checkIncomplete(h0);
2168     checkIncomplete(h1);
2169     rs[0].assertNotInvoked();
2170     rs[1].assertNotInvoked();
2171 jsr166 1.41 f.complete(v1);
2172 jsr166 1.65 checkCompletedNormally(h0, null);
2173     checkCompletedNormally(h1, null);
2174     rs[0].assertInvoked();
2175     rs[1].assertInvoked();
2176     final CompletableFuture<Void> h2 = m.runAfterEither(f, g, rs[2]);
2177     final CompletableFuture<Void> h3 = m.runAfterEither(g, f, rs[3]);
2178     checkCompletedNormally(h2, null);
2179     checkCompletedNormally(h3, null);
2180     rs[2].assertInvoked();
2181     rs[3].assertInvoked();
2182 jsr166 1.41
2183     g.complete(v2);
2184    
2185 jsr166 1.65 final CompletableFuture<Void> h4 = m.runAfterEither(f, g, rs[4]);
2186     final CompletableFuture<Void> h5 = m.runAfterEither(g, f, rs[5]);
2187 jsr166 1.47
2188 jsr166 1.41 checkCompletedNormally(f, v1);
2189     checkCompletedNormally(g, v2);
2190 jsr166 1.65 checkCompletedNormally(h0, null);
2191     checkCompletedNormally(h1, null);
2192     checkCompletedNormally(h2, null);
2193     checkCompletedNormally(h3, null);
2194     checkCompletedNormally(h4, null);
2195     checkCompletedNormally(h5, null);
2196     for (int i = 0; i < 6; i++) rs[i].assertInvoked();
2197 jsr166 1.47 }}
2198 dl 1.5
2199     /**
2200     * runAfterEither result completes exceptionally after exceptional
2201     * completion of either source
2202     */
2203 jsr166 1.65 public void testRunAfterEither_exceptionalCompletion() {
2204 jsr166 1.41 for (ExecutionMode m : ExecutionMode.values())
2205 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2206     {
2207 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2208     final CompletableFuture<Integer> g = new CompletableFuture<>();
2209     final CFException ex = new CFException();
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 jsr166 1.41 f.completeExceptionally(ex);
2220 jsr166 1.65 checkCompletedWithWrappedCFException(h0, ex);
2221     checkCompletedWithWrappedCFException(h1, ex);
2222     final CompletableFuture<Void> h2 = m.runAfterEither(f, g, rs[2]);
2223     final CompletableFuture<Void> h3 = m.runAfterEither(g, f, rs[3]);
2224     checkCompletedWithWrappedCFException(h2, ex);
2225     checkCompletedWithWrappedCFException(h3, ex);
2226    
2227 jsr166 1.41 g.complete(v1);
2228    
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     try {
2233     assertNull(h4.join());
2234     rs[4].assertInvoked();
2235     } catch (CompletionException ok) {
2236     checkCompletedWithWrappedCFException(h4, ex);
2237     rs[4].assertNotInvoked();
2238     }
2239     try {
2240     assertNull(h5.join());
2241     rs[5].assertInvoked();
2242     } catch (CompletionException ok) {
2243     checkCompletedWithWrappedCFException(h5, ex);
2244     rs[5].assertNotInvoked();
2245     }
2246    
2247     checkCompletedWithWrappedCFException(f, ex);
2248 jsr166 1.41 checkCompletedNormally(g, v1);
2249 jsr166 1.65 checkCompletedWithWrappedCFException(h0, ex);
2250     checkCompletedWithWrappedCFException(h1, ex);
2251     checkCompletedWithWrappedCFException(h2, ex);
2252     checkCompletedWithWrappedCFException(h3, ex);
2253     checkCompletedWithWrappedCFException(h4, ex);
2254     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
2255 jsr166 1.47 }}
2256 jsr166 1.41
2257 jsr166 1.65 /**
2258     * runAfterEither result completes exceptionally if either source cancelled
2259     */
2260     public void testRunAfterEither_sourceCancelled() {
2261 jsr166 1.41 for (ExecutionMode m : ExecutionMode.values())
2262 jsr166 1.65 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2263 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2264     {
2265 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2266     final CompletableFuture<Integer> g = new CompletableFuture<>();
2267 jsr166 1.65 final Noop[] rs = new Noop[6];
2268     for (int i = 0; i < rs.length; i++) rs[i] = new Noop(m);
2269 jsr166 1.41
2270 jsr166 1.65 final CompletableFuture<Void> h0 = m.runAfterEither(f, g, rs[0]);
2271     final CompletableFuture<Void> h1 = m.runAfterEither(g, f, rs[1]);
2272     checkIncomplete(h0);
2273     checkIncomplete(h1);
2274     rs[0].assertNotInvoked();
2275     rs[1].assertNotInvoked();
2276     f.cancel(mayInterruptIfRunning);
2277     checkCompletedWithWrappedCancellationException(h0);
2278     checkCompletedWithWrappedCancellationException(h1);
2279     final CompletableFuture<Void> h2 = m.runAfterEither(f, g, rs[2]);
2280     final CompletableFuture<Void> h3 = m.runAfterEither(g, f, rs[3]);
2281     checkCompletedWithWrappedCancellationException(h2);
2282     checkCompletedWithWrappedCancellationException(h3);
2283 jsr166 1.41
2284 jsr166 1.65 g.complete(v1);
2285 jsr166 1.41
2286 jsr166 1.65 // unspecified behavior - both source completions available
2287     final CompletableFuture<Void> h4 = m.runAfterEither(f, g, rs[4]);
2288     final CompletableFuture<Void> h5 = m.runAfterEither(g, f, rs[5]);
2289 jsr166 1.41 try {
2290 jsr166 1.65 assertNull(h4.join());
2291     rs[4].assertInvoked();
2292 jsr166 1.41 } catch (CompletionException ok) {
2293 jsr166 1.65 checkCompletedWithWrappedCancellationException(h4);
2294     rs[4].assertNotInvoked();
2295 jsr166 1.41 }
2296     try {
2297 jsr166 1.65 assertNull(h5.join());
2298     rs[5].assertInvoked();
2299 jsr166 1.41 } catch (CompletionException ok) {
2300 jsr166 1.65 checkCompletedWithWrappedCancellationException(h5);
2301     rs[5].assertNotInvoked();
2302 jsr166 1.41 }
2303 dl 1.5
2304 jsr166 1.65 checkCancelled(f);
2305 jsr166 1.41 checkCompletedNormally(g, v1);
2306 jsr166 1.65 checkCompletedWithWrappedCancellationException(h0);
2307     checkCompletedWithWrappedCancellationException(h1);
2308     checkCompletedWithWrappedCancellationException(h2);
2309     checkCompletedWithWrappedCancellationException(h3);
2310     for (int i = 0; i < 4; i++) rs[i].assertNotInvoked();
2311 jsr166 1.47 }}
2312 dl 1.5
2313     /**
2314     * runAfterEither result completes exceptionally if action does
2315     */
2316 jsr166 1.65 public void testRunAfterEither_actionFailed() {
2317 jsr166 1.41 for (ExecutionMode m : ExecutionMode.values())
2318     for (Integer v1 : new Integer[] { 1, null })
2319 jsr166 1.47 for (Integer v2 : new Integer[] { 2, null })
2320     {
2321 jsr166 1.41 final CompletableFuture<Integer> f = new CompletableFuture<>();
2322     final CompletableFuture<Integer> g = new CompletableFuture<>();
2323 jsr166 1.65 final FailingRunnable[] rs = new FailingRunnable[6];
2324     for (int i = 0; i < rs.length; i++) rs[i] = new FailingRunnable(m);
2325 jsr166 1.41
2326 jsr166 1.65 final CompletableFuture<Void> h0 = m.runAfterEither(f, g, rs[0]);
2327     final CompletableFuture<Void> h1 = m.runAfterEither(g, f, rs[1]);
2328 jsr166 1.41 f.complete(v1);
2329 jsr166 1.65 final CompletableFuture<Void> h2 = m.runAfterEither(f, g, rs[2]);
2330     final CompletableFuture<Void> h3 = m.runAfterEither(g, f, rs[3]);
2331     checkCompletedWithWrappedCFException(h0);
2332     checkCompletedWithWrappedCFException(h1);
2333     checkCompletedWithWrappedCFException(h2);
2334     checkCompletedWithWrappedCFException(h3);
2335     for (int i = 0; i < 4; i++) rs[i].assertInvoked();
2336 jsr166 1.41 g.complete(v2);
2337 jsr166 1.65 final CompletableFuture<Void> h4 = m.runAfterEither(f, g, rs[4]);
2338     final CompletableFuture<Void> h5 = m.runAfterEither(g, f, rs[5]);
2339     checkCompletedWithWrappedCFException(h4);
2340     checkCompletedWithWrappedCFException(h5);
2341 jsr166 1.41
2342     checkCompletedNormally(f, v1);
2343     checkCompletedNormally(g, v2);
2344 jsr166 1.65 for (int i = 0; i < 6; i++) rs[i].assertInvoked();
2345 jsr166 1.47 }}
2346 dl 1.5
2347     /**
2348     * thenCompose result completes normally after normal completion of source
2349     */
2350 jsr166 1.48 public void testThenCompose_normalCompletion() {
2351 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2352 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2353 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2354     {
2355 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2356 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2357 jsr166 1.48 if (!createIncomplete) f.complete(v1);
2358 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2359 jsr166 1.48 if (createIncomplete) f.complete(v1);
2360 jsr166 1.21
2361 jsr166 1.44 checkCompletedNormally(g, inc(v1));
2362     checkCompletedNormally(f, v1);
2363 jsr166 1.62 r.assertInvoked();
2364 jsr166 1.47 }}
2365 dl 1.5
2366     /**
2367     * thenCompose result completes exceptionally after exceptional
2368     * completion of source
2369     */
2370 jsr166 1.48 public void testThenCompose_exceptionalCompletion() {
2371 jsr166 1.47 for (ExecutionMode m : ExecutionMode.values())
2372 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2373 jsr166 1.47 {
2374 jsr166 1.44 final CFException ex = new CFException();
2375 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2376 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2377 jsr166 1.48 if (!createIncomplete) f.completeExceptionally(ex);
2378 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2379 jsr166 1.48 if (createIncomplete) f.completeExceptionally(ex);
2380 jsr166 1.21
2381 jsr166 1.44 checkCompletedWithWrappedCFException(g, ex);
2382     checkCompletedWithWrappedCFException(f, ex);
2383 jsr166 1.62 r.assertNotInvoked();
2384 jsr166 1.47 }}
2385 dl 1.5
2386     /**
2387     * thenCompose result completes exceptionally if action does
2388     */
2389 jsr166 1.48 public void testThenCompose_actionFailed() {
2390 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2391 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2392 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2393     {
2394 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2395     final FailingCompletableFutureFunction r
2396 jsr166 1.56 = new FailingCompletableFutureFunction(m);
2397 jsr166 1.48 if (!createIncomplete) f.complete(v1);
2398 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2399 jsr166 1.48 if (createIncomplete) f.complete(v1);
2400 jsr166 1.44
2401 dl 1.5 checkCompletedWithWrappedCFException(g);
2402 jsr166 1.44 checkCompletedNormally(f, v1);
2403 jsr166 1.47 }}
2404 dl 1.5
2405     /**
2406     * thenCompose result completes exceptionally if source cancelled
2407     */
2408 jsr166 1.48 public void testThenCompose_sourceCancelled() {
2409 jsr166 1.44 for (ExecutionMode m : ExecutionMode.values())
2410 jsr166 1.48 for (boolean createIncomplete : new boolean[] { true, false })
2411 jsr166 1.47 for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2412     {
2413 jsr166 1.44 final CompletableFuture<Integer> f = new CompletableFuture<>();
2414 jsr166 1.56 final CompletableFutureInc r = new CompletableFutureInc(m);
2415 jsr166 1.48 if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2416 jsr166 1.56 final CompletableFuture<Integer> g = m.thenCompose(f, r);
2417 jsr166 1.50 if (createIncomplete) {
2418     checkIncomplete(g);
2419     assertTrue(f.cancel(mayInterruptIfRunning));
2420     }
2421 jsr166 1.44
2422 dl 1.5 checkCompletedWithWrappedCancellationException(g);
2423 jsr166 1.44 checkCancelled(f);
2424 jsr166 1.47 }}
2425 dl 1.5
2426 jsr166 1.6 // other static methods
2427 dl 1.5
2428     /**
2429     * allOf(no component futures) returns a future completed normally
2430     * with the value null
2431     */
2432     public void testAllOf_empty() throws Exception {
2433 jsr166 1.24 CompletableFuture<Void> f = CompletableFuture.allOf();
2434 dl 1.5 checkCompletedNormally(f, null);
2435     }
2436    
2437     /**
2438 jsr166 1.25 * allOf returns a future completed normally with the value null
2439     * when all components complete normally
2440 dl 1.5 */
2441 jsr166 1.25 public void testAllOf_normal() throws Exception {
2442 dl 1.5 for (int k = 1; k < 20; ++k) {
2443 jsr166 1.59 CompletableFuture<Integer>[] fs
2444     = (CompletableFuture<Integer>[]) new CompletableFuture[k];
2445 jsr166 1.6 for (int i = 0; i < k; ++i)
2446 jsr166 1.22 fs[i] = new CompletableFuture<>();
2447 dl 1.9 CompletableFuture<Void> f = CompletableFuture.allOf(fs);
2448 dl 1.5 for (int i = 0; i < k; ++i) {
2449     checkIncomplete(f);
2450 jsr166 1.24 checkIncomplete(CompletableFuture.allOf(fs));
2451 dl 1.5 fs[i].complete(one);
2452     }
2453 dl 1.9 checkCompletedNormally(f, null);
2454 jsr166 1.24 checkCompletedNormally(CompletableFuture.allOf(fs), null);
2455 dl 1.5 }
2456     }
2457    
2458 jsr166 1.59 public void testAllOf_backwards() throws Exception {
2459     for (int k = 1; k < 20; ++k) {
2460     CompletableFuture<Integer>[] fs
2461     = (CompletableFuture<Integer>[]) new CompletableFuture[k];
2462     for (int i = 0; i < k; ++i)
2463     fs[i] = new CompletableFuture<>();
2464     CompletableFuture<Void> f = CompletableFuture.allOf(fs);
2465     for (int i = k - 1; i >= 0; i--) {
2466     checkIncomplete(f);
2467     checkIncomplete(CompletableFuture.allOf(fs));
2468     fs[i].complete(one);
2469     }
2470     checkCompletedNormally(f, null);
2471     checkCompletedNormally(CompletableFuture.allOf(fs), null);
2472     }
2473     }
2474    
2475 dl 1.5 /**
2476     * anyOf(no component futures) returns an incomplete future
2477     */
2478     public void testAnyOf_empty() throws Exception {
2479 jsr166 1.24 CompletableFuture<Object> f = CompletableFuture.anyOf();
2480 dl 1.5 checkIncomplete(f);
2481     }
2482    
2483     /**
2484 jsr166 1.25 * anyOf returns a future completed normally with a value when
2485     * a component future does
2486 dl 1.5 */
2487 jsr166 1.24 public void testAnyOf_normal() throws Exception {
2488     for (int k = 0; k < 10; ++k) {
2489 dl 1.5 CompletableFuture[] fs = new CompletableFuture[k];
2490 jsr166 1.6 for (int i = 0; i < k; ++i)
2491 jsr166 1.22 fs[i] = new CompletableFuture<>();
2492 dl 1.9 CompletableFuture<Object> f = CompletableFuture.anyOf(fs);
2493 dl 1.5 checkIncomplete(f);
2494     for (int i = 0; i < k; ++i) {
2495     fs[i].complete(one);
2496 dl 1.9 checkCompletedNormally(f, one);
2497 jsr166 1.24 checkCompletedNormally(CompletableFuture.anyOf(fs), one);
2498     }
2499     }
2500     }
2501    
2502     /**
2503     * anyOf result completes exceptionally when any component does.
2504     */
2505     public void testAnyOf_exceptional() throws Exception {
2506     for (int k = 0; k < 10; ++k) {
2507     CompletableFuture[] fs = new CompletableFuture[k];
2508     for (int i = 0; i < k; ++i)
2509     fs[i] = new CompletableFuture<>();
2510     CompletableFuture<Object> f = CompletableFuture.anyOf(fs);
2511     checkIncomplete(f);
2512     for (int i = 0; i < k; ++i) {
2513     fs[i].completeExceptionally(new CFException());
2514     checkCompletedWithWrappedCFException(f);
2515     checkCompletedWithWrappedCFException(CompletableFuture.anyOf(fs));
2516 dl 1.5 }
2517     }
2518     }
2519    
2520     /**
2521     * Completion methods throw NullPointerException with null arguments
2522     */
2523     public void testNPE() {
2524 jsr166 1.22 CompletableFuture<Integer> f = new CompletableFuture<>();
2525     CompletableFuture<Integer> g = new CompletableFuture<>();
2526 jsr166 1.14 CompletableFuture<Integer> nullFuture = (CompletableFuture<Integer>)null;
2527     CompletableFuture<?> h;
2528 jsr166 1.17 ThreadExecutor exec = new ThreadExecutor();
2529 jsr166 1.14
2530     Runnable[] throwingActions = {
2531 jsr166 1.31 () -> CompletableFuture.supplyAsync(null),
2532     () -> CompletableFuture.supplyAsync(null, exec),
2533 jsr166 1.58 () -> CompletableFuture.supplyAsync(new IntegerSupplier(ExecutionMode.DEFAULT, 42), null),
2534 jsr166 1.31
2535     () -> CompletableFuture.runAsync(null),
2536     () -> CompletableFuture.runAsync(null, exec),
2537     () -> CompletableFuture.runAsync(() -> {}, null),
2538    
2539     () -> f.completeExceptionally(null),
2540    
2541     () -> f.thenApply(null),
2542     () -> f.thenApplyAsync(null),
2543     () -> f.thenApplyAsync((x) -> x, null),
2544     () -> f.thenApplyAsync(null, exec),
2545    
2546     () -> f.thenAccept(null),
2547     () -> f.thenAcceptAsync(null),
2548     () -> f.thenAcceptAsync((x) -> {} , null),
2549     () -> f.thenAcceptAsync(null, exec),
2550    
2551     () -> f.thenRun(null),
2552     () -> f.thenRunAsync(null),
2553     () -> f.thenRunAsync(() -> {} , null),
2554     () -> f.thenRunAsync(null, exec),
2555    
2556     () -> f.thenCombine(g, null),
2557     () -> f.thenCombineAsync(g, null),
2558     () -> f.thenCombineAsync(g, null, exec),
2559     () -> f.thenCombine(nullFuture, (x, y) -> x),
2560     () -> f.thenCombineAsync(nullFuture, (x, y) -> x),
2561     () -> f.thenCombineAsync(nullFuture, (x, y) -> x, exec),
2562     () -> f.thenCombineAsync(g, (x, y) -> x, null),
2563    
2564     () -> f.thenAcceptBoth(g, null),
2565     () -> f.thenAcceptBothAsync(g, null),
2566     () -> f.thenAcceptBothAsync(g, null, exec),
2567     () -> f.thenAcceptBoth(nullFuture, (x, y) -> {}),
2568     () -> f.thenAcceptBothAsync(nullFuture, (x, y) -> {}),
2569     () -> f.thenAcceptBothAsync(nullFuture, (x, y) -> {}, exec),
2570     () -> f.thenAcceptBothAsync(g, (x, y) -> {}, null),
2571    
2572     () -> f.runAfterBoth(g, null),
2573     () -> f.runAfterBothAsync(g, null),
2574     () -> f.runAfterBothAsync(g, null, exec),
2575     () -> f.runAfterBoth(nullFuture, () -> {}),
2576     () -> f.runAfterBothAsync(nullFuture, () -> {}),
2577     () -> f.runAfterBothAsync(nullFuture, () -> {}, exec),
2578     () -> f.runAfterBothAsync(g, () -> {}, null),
2579    
2580     () -> f.applyToEither(g, null),
2581     () -> f.applyToEitherAsync(g, null),
2582     () -> f.applyToEitherAsync(g, null, exec),
2583     () -> f.applyToEither(nullFuture, (x) -> x),
2584     () -> f.applyToEitherAsync(nullFuture, (x) -> x),
2585     () -> f.applyToEitherAsync(nullFuture, (x) -> x, exec),
2586     () -> f.applyToEitherAsync(g, (x) -> x, null),
2587    
2588     () -> f.acceptEither(g, null),
2589     () -> f.acceptEitherAsync(g, null),
2590     () -> f.acceptEitherAsync(g, null, exec),
2591     () -> f.acceptEither(nullFuture, (x) -> {}),
2592     () -> f.acceptEitherAsync(nullFuture, (x) -> {}),
2593     () -> f.acceptEitherAsync(nullFuture, (x) -> {}, exec),
2594     () -> f.acceptEitherAsync(g, (x) -> {}, null),
2595    
2596     () -> f.runAfterEither(g, null),
2597     () -> f.runAfterEitherAsync(g, null),
2598     () -> f.runAfterEitherAsync(g, null, exec),
2599     () -> f.runAfterEither(nullFuture, () -> {}),
2600     () -> f.runAfterEitherAsync(nullFuture, () -> {}),
2601     () -> f.runAfterEitherAsync(nullFuture, () -> {}, exec),
2602     () -> f.runAfterEitherAsync(g, () -> {}, null),
2603    
2604     () -> f.thenCompose(null),
2605     () -> f.thenComposeAsync(null),
2606 jsr166 1.56 () -> f.thenComposeAsync(new CompletableFutureInc(ExecutionMode.EXECUTOR), null),
2607 jsr166 1.31 () -> f.thenComposeAsync(null, exec),
2608    
2609     () -> f.exceptionally(null),
2610    
2611     () -> f.handle(null),
2612    
2613     () -> CompletableFuture.allOf((CompletableFuture<?>)null),
2614     () -> CompletableFuture.allOf((CompletableFuture<?>[])null),
2615     () -> CompletableFuture.allOf(f, null),
2616     () -> CompletableFuture.allOf(null, f),
2617    
2618     () -> CompletableFuture.anyOf((CompletableFuture<?>)null),
2619     () -> CompletableFuture.anyOf((CompletableFuture<?>[])null),
2620     () -> CompletableFuture.anyOf(f, null),
2621     () -> CompletableFuture.anyOf(null, f),
2622 jsr166 1.32
2623     () -> f.obtrudeException(null),
2624 jsr166 1.14 };
2625 dl 1.5
2626 jsr166 1.14 assertThrows(NullPointerException.class, throwingActions);
2627 jsr166 1.17 assertEquals(0, exec.count.get());
2628 dl 1.5 }
2629    
2630 dl 1.26 /**
2631     * toCompletableFuture returns this CompletableFuture.
2632     */
2633     public void testToCompletableFuture() {
2634     CompletableFuture<Integer> f = new CompletableFuture<>();
2635     assertSame(f, f.toCompletableFuture());
2636     }
2637    
2638     /**
2639     * whenComplete action executes on normal completion, propagating
2640     * source result.
2641     */
2642 jsr166 1.42 public void testWhenComplete_normalCompletion1() {
2643 jsr166 1.46 for (ExecutionMode m : ExecutionMode.values())
2644 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2645 jsr166 1.46 for (Integer v1 : new Integer[] { 1, null })
2646     {
2647     final AtomicInteger a = new AtomicInteger(0);
2648 jsr166 1.42 final CompletableFuture<Integer> f = new CompletableFuture<>();
2649 jsr166 1.44 if (!createIncomplete) f.complete(v1);
2650 jsr166 1.46 final CompletableFuture<Integer> g = m.whenComplete
2651     (f,
2652     (Integer x, Throwable t) -> {
2653     threadAssertSame(x, v1);
2654     threadAssertNull(t);
2655     a.getAndIncrement();
2656     });
2657 jsr166 1.44 if (createIncomplete) f.complete(v1);
2658 jsr166 1.46
2659     checkCompletedNormally(g, v1);
2660 jsr166 1.42 checkCompletedNormally(f, v1);
2661 jsr166 1.46 assertEquals(1, a.get());
2662     }}
2663 dl 1.26
2664     /**
2665     * whenComplete action executes on exceptional completion, propagating
2666     * source result.
2667     */
2668 jsr166 1.42 public void testWhenComplete_exceptionalCompletion() {
2669 jsr166 1.46 for (ExecutionMode m : ExecutionMode.values())
2670 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2671 jsr166 1.46 for (Integer v1 : new Integer[] { 1, null })
2672     {
2673     final AtomicInteger a = new AtomicInteger(0);
2674 jsr166 1.42 final CFException ex = new CFException();
2675     final CompletableFuture<Integer> f = new CompletableFuture<>();
2676 jsr166 1.44 if (!createIncomplete) f.completeExceptionally(ex);
2677 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2678     (f,
2679     (Integer x, Throwable t) -> {
2680     threadAssertNull(x);
2681     threadAssertSame(t, ex);
2682     a.getAndIncrement();
2683     });
2684 jsr166 1.44 if (createIncomplete) f.completeExceptionally(ex);
2685 jsr166 1.42 checkCompletedWithWrappedCFException(f, ex);
2686     checkCompletedWithWrappedCFException(g, ex);
2687 jsr166 1.46 assertEquals(1, a.get());
2688     }}
2689    
2690     /**
2691     * whenComplete action executes on cancelled source, propagating
2692     * CancellationException.
2693     */
2694     public void testWhenComplete_sourceCancelled() {
2695     for (ExecutionMode m : ExecutionMode.values())
2696     for (boolean mayInterruptIfRunning : new boolean[] { true, false })
2697     for (boolean createIncomplete : new boolean[] { true, false })
2698     {
2699     final AtomicInteger a = new AtomicInteger(0);
2700     final CompletableFuture<Integer> f = new CompletableFuture<>();
2701     if (!createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2702     final CompletableFuture<Integer> g = m.whenComplete
2703     (f,
2704     (Integer x, Throwable t) -> {
2705     threadAssertNull(x);
2706     threadAssertTrue(t instanceof CancellationException);
2707     a.getAndIncrement();
2708     });
2709     if (createIncomplete) assertTrue(f.cancel(mayInterruptIfRunning));
2710    
2711     //try { g.join(); } catch (Throwable t) { throw new Error(t); }
2712     checkCompletedWithWrappedCancellationException(g);
2713     checkCancelled(f);
2714     assertEquals(1, a.get());
2715     }}
2716 dl 1.26
2717     /**
2718     * If a whenComplete action throws an exception when triggered by
2719     * a normal completion, it completes exceptionally
2720     */
2721 jsr166 1.42 public void testWhenComplete_actionFailed() {
2722 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2723 jsr166 1.42 for (ExecutionMode m : ExecutionMode.values())
2724 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2725     {
2726 jsr166 1.46 final AtomicInteger a = new AtomicInteger(0);
2727 jsr166 1.42 final CFException ex = new CFException();
2728     final CompletableFuture<Integer> f = new CompletableFuture<>();
2729 jsr166 1.44 if (!createIncomplete) f.complete(v1);
2730 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2731     (f,
2732     (Integer x, Throwable t) -> {
2733     threadAssertSame(x, v1);
2734     threadAssertNull(t);
2735 jsr166 1.46 a.getAndIncrement();
2736 jsr166 1.42 throw ex;
2737     });
2738 jsr166 1.44 if (createIncomplete) f.complete(v1);
2739 jsr166 1.42 checkCompletedNormally(f, v1);
2740     checkCompletedWithWrappedCFException(g, ex);
2741 jsr166 1.46 assertEquals(1, a.get());
2742 jsr166 1.47 }}
2743 dl 1.26
2744     /**
2745 jsr166 1.42 * If a whenComplete action throws an exception when triggered by
2746     * a source completion that also throws an exception, the source
2747     * exception takes precedence.
2748 dl 1.26 */
2749 jsr166 1.42 public void testWhenComplete_actionFailedSourceFailed() {
2750 jsr166 1.44 for (boolean createIncomplete : new boolean[] { true, false })
2751 jsr166 1.42 for (ExecutionMode m : ExecutionMode.values())
2752 jsr166 1.47 for (Integer v1 : new Integer[] { 1, null })
2753     {
2754 jsr166 1.46 final AtomicInteger a = new AtomicInteger(0);
2755 jsr166 1.42 final CFException ex1 = new CFException();
2756     final CFException ex2 = new CFException();
2757     final CompletableFuture<Integer> f = new CompletableFuture<>();
2758 jsr166 1.44
2759     if (!createIncomplete) f.completeExceptionally(ex1);
2760 jsr166 1.42 final CompletableFuture<Integer> g = m.whenComplete
2761     (f,
2762     (Integer x, Throwable t) -> {
2763     threadAssertSame(t, ex1);
2764     threadAssertNull(x);
2765 jsr166 1.46 a.getAndIncrement();
2766 jsr166 1.42 throw ex2;
2767     });
2768 jsr166 1.44 if (createIncomplete) f.completeExceptionally(ex1);
2769    
2770 jsr166 1.42 checkCompletedWithWrappedCFException(f, ex1);
2771     checkCompletedWithWrappedCFException(g, ex1);
2772 jsr166 1.46 assertEquals(1, a.get());
2773 jsr166 1.47 }}
2774 dl 1.26
2775 jsr166 1.1 }