339 |
|
static final class IncAction implements Consumer<Integer> { |
340 |
|
int invocationCount = 0; |
341 |
|
Integer value; |
342 |
– |
public boolean ran() { return invocationCount == 1; } |
342 |
|
public void accept(Integer x) { |
343 |
|
invocationCount++; |
344 |
|
value = inc(x); |
347 |
|
static final class IncFunction implements Function<Integer,Integer> { |
348 |
|
int invocationCount = 0; |
349 |
|
Integer value; |
351 |
– |
public boolean ran() { return invocationCount == 1; } |
350 |
|
public Integer apply(Integer x) { |
351 |
|
invocationCount++; |
352 |
|
return value = inc(x); |
356 |
|
int invocationCount = 0; |
357 |
|
Integer value; |
358 |
|
// Check this action was invoked exactly once when result is computed. |
361 |
– |
public boolean ran() { return invocationCount == 1; } |
359 |
|
public void accept(Integer x, Integer y) { |
360 |
|
invocationCount++; |
361 |
|
value = subtract(x, y); |
365 |
|
int invocationCount = 0; |
366 |
|
Integer value; |
367 |
|
// Check this action was invoked exactly once when result is computed. |
371 |
– |
public boolean ran() { return invocationCount == 1; } |
368 |
|
public Integer apply(Integer x, Integer y) { |
369 |
|
invocationCount++; |
370 |
|
return value = subtract(x, y); |
371 |
|
} |
372 |
|
} |
373 |
|
static final class Noop implements Runnable { |
374 |
< |
boolean ran; |
375 |
< |
public void run() { ran = true; } |
374 |
> |
int invocationCount = 0; |
375 |
> |
public void run() { |
376 |
> |
invocationCount++; |
377 |
> |
} |
378 |
|
} |
379 |
|
|
380 |
|
static final class FailingSupplier implements Supplier<Integer> { |
381 |
< |
boolean ran; |
382 |
< |
public Integer get() { ran = true; throw new CFException(); } |
381 |
> |
int invocationCount = 0; |
382 |
> |
public Integer get() { |
383 |
> |
invocationCount++; |
384 |
> |
throw new CFException(); |
385 |
> |
} |
386 |
|
} |
387 |
|
static final class FailingConsumer implements Consumer<Integer> { |
388 |
< |
boolean ran; |
389 |
< |
public void accept(Integer x) { ran = true; throw new CFException(); } |
388 |
> |
int invocationCount = 0; |
389 |
> |
public void accept(Integer x) { |
390 |
> |
invocationCount++; |
391 |
> |
throw new CFException(); |
392 |
> |
} |
393 |
|
} |
394 |
|
static final class FailingBiConsumer implements BiConsumer<Integer, Integer> { |
395 |
< |
boolean ran; |
396 |
< |
public void accept(Integer x, Integer y) { ran = true; throw new CFException(); } |
395 |
> |
int invocationCount = 0; |
396 |
> |
public void accept(Integer x, Integer y) { |
397 |
> |
invocationCount++; |
398 |
> |
throw new CFException(); |
399 |
> |
} |
400 |
|
} |
401 |
|
static final class FailingFunction implements Function<Integer, Integer> { |
402 |
< |
boolean ran; |
403 |
< |
public Integer apply(Integer x) { ran = true; throw new CFException(); } |
402 |
> |
int invocationCount = 0; |
403 |
> |
public Integer apply(Integer x) { |
404 |
> |
invocationCount++; |
405 |
> |
throw new CFException(); |
406 |
> |
} |
407 |
|
} |
408 |
|
static final class FailingBiFunction implements BiFunction<Integer, Integer, Integer> { |
409 |
< |
boolean ran; |
410 |
< |
public Integer apply(Integer x, Integer y) { ran = true; throw new CFException(); } |
409 |
> |
int invocationCount = 0; |
410 |
> |
public Integer apply(Integer x, Integer y) { |
411 |
> |
invocationCount++; |
412 |
> |
throw new CFException(); |
413 |
> |
} |
414 |
|
} |
415 |
|
static final class FailingNoop implements Runnable { |
416 |
< |
boolean ran; |
417 |
< |
public void run() { ran = true; throw new CFException(); } |
416 |
> |
int invocationCount = 0; |
417 |
> |
public void run() { |
418 |
> |
invocationCount++; |
419 |
> |
throw new CFException(); |
420 |
> |
} |
421 |
|
} |
422 |
|
|
423 |
|
static final class CompletableFutureInc |
424 |
|
implements Function<Integer, CompletableFuture<Integer>> { |
425 |
< |
boolean ran; |
425 |
> |
int invocationCount = 0; |
426 |
|
public CompletableFuture<Integer> apply(Integer x) { |
427 |
< |
ran = true; |
427 |
> |
invocationCount++; |
428 |
|
CompletableFuture<Integer> f = new CompletableFuture<>(); |
429 |
< |
f.complete(Integer.valueOf(x.intValue() + 1)); |
429 |
> |
f.complete(inc(x)); |
430 |
|
return f; |
431 |
|
} |
432 |
|
} |
433 |
|
|
434 |
|
static final class FailingCompletableFutureFunction |
435 |
|
implements Function<Integer, CompletableFuture<Integer>> { |
436 |
< |
boolean ran; |
436 |
> |
int invocationCount = 0; |
437 |
|
public CompletableFuture<Integer> apply(Integer x) { |
438 |
< |
ran = true; throw new CFException(); |
438 |
> |
invocationCount++; |
439 |
> |
throw new CFException(); |
440 |
|
} |
441 |
|
} |
442 |
|
|
455 |
|
} |
456 |
|
|
457 |
|
static final class IntegerHandler implements BiFunction<Integer, Throwable, Integer> { |
458 |
< |
boolean ran; |
458 |
> |
int invocationCount = 0; |
459 |
|
public Integer apply(Integer x, Throwable t) { |
460 |
< |
ran = true; |
460 |
> |
invocationCount++; |
461 |
|
return (t == null) ? two : three; |
462 |
|
} |
463 |
|
} |
514 |
|
} |
515 |
|
}, |
516 |
|
|
500 |
– |
// /** Experimental way to do more testing */ |
501 |
– |
// REVERSE_DEFAULT { |
502 |
– |
// public <T,U> CompletableFuture<Void> runAfterBoth |
503 |
– |
// (CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) { |
504 |
– |
// return g.runAfterBoth(f, a); |
505 |
– |
// } |
506 |
– |
// public <T,U> CompletableFuture<Void> thenAcceptBoth |
507 |
– |
// (CompletableFuture<T> f, |
508 |
– |
// CompletionStage<? extends U> g, |
509 |
– |
// BiConsumer<? super T,? super U> a) { |
510 |
– |
// return DEFAULT.thenAcceptBoth(f, g, a); |
511 |
– |
// } |
512 |
– |
// }, |
513 |
– |
|
517 |
|
DEFAULT_ASYNC { |
518 |
|
public <T,U> CompletableFuture<Void> runAfterBoth |
519 |
|
(CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) { |
561 |
|
} |
562 |
|
}, |
563 |
|
|
561 |
– |
// REVERSE_DEFAULT_ASYNC { |
562 |
– |
// public <T,U> CompletableFuture<Void> runAfterBoth |
563 |
– |
// (CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) { |
564 |
– |
// return f.runAfterBothAsync(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 DEFAULT_ASYNC.thenAcceptBoth(f, g, a); |
571 |
– |
// } |
572 |
– |
// }, |
573 |
– |
|
564 |
|
EXECUTOR { |
565 |
|
public <T,U> CompletableFuture<Void> runAfterBoth |
566 |
|
(CompletableFuture<T> f, CompletableFuture<U> g, Runnable a) { |
669 |
|
f = new CompletableFuture<>(); |
670 |
|
f.completeExceptionally(new CFException()); |
671 |
|
g = f.handle(r = new IntegerHandler()); |
672 |
< |
assertTrue(r.ran); |
672 |
> |
assertEquals(1, r.invocationCount); |
673 |
> |
assertEquals(1, r.invocationCount); |
674 |
|
checkCompletedNormally(g, three); |
675 |
|
|
676 |
|
f = new CompletableFuture<>(); |
677 |
|
g = f.handle(r = new IntegerHandler()); |
678 |
< |
assertFalse(r.ran); |
678 |
> |
assertEquals(0, r.invocationCount); |
679 |
|
f.completeExceptionally(new CFException()); |
680 |
|
checkCompletedNormally(g, three); |
681 |
< |
assertTrue(r.ran); |
681 |
> |
assertEquals(1, r.invocationCount); |
682 |
|
|
683 |
|
f = new CompletableFuture<>(); |
684 |
|
f.complete(one); |
685 |
|
g = f.handle(r = new IntegerHandler()); |
686 |
< |
assertTrue(r.ran); |
686 |
> |
assertEquals(1, r.invocationCount); |
687 |
|
checkCompletedNormally(g, two); |
688 |
|
|
689 |
|
f = new CompletableFuture<>(); |
690 |
|
g = f.handle(r = new IntegerHandler()); |
691 |
< |
assertFalse(r.ran); |
691 |
> |
assertEquals(0, r.invocationCount); |
692 |
|
f.complete(one); |
693 |
< |
assertTrue(r.ran); |
693 |
> |
assertEquals(1, r.invocationCount); |
694 |
|
checkCompletedNormally(g, two); |
695 |
|
} |
696 |
|
|
701 |
|
Noop r = new Noop(); |
702 |
|
CompletableFuture<Void> f = CompletableFuture.runAsync(r); |
703 |
|
assertNull(f.join()); |
704 |
< |
assertTrue(r.ran); |
704 |
> |
assertEquals(1, r.invocationCount); |
705 |
|
checkCompletedNormally(f, null); |
706 |
|
} |
707 |
|
|
713 |
|
ThreadExecutor exec = new ThreadExecutor(); |
714 |
|
CompletableFuture<Void> f = CompletableFuture.runAsync(r, exec); |
715 |
|
assertNull(f.join()); |
716 |
< |
assertTrue(r.ran); |
716 |
> |
assertEquals(1, r.invocationCount); |
717 |
|
checkCompletedNormally(f, null); |
718 |
|
assertEquals(1, exec.count.get()); |
719 |
|
} |
725 |
|
FailingNoop r = new FailingNoop(); |
726 |
|
CompletableFuture<Void> f = CompletableFuture.runAsync(r); |
727 |
|
checkCompletedWithWrappedCFException(f); |
728 |
< |
assertTrue(r.ran); |
728 |
> |
assertEquals(1, r.invocationCount); |
729 |
|
} |
730 |
|
|
731 |
|
/** |
755 |
|
FailingSupplier r = new FailingSupplier(); |
756 |
|
CompletableFuture<Integer> f = CompletableFuture.supplyAsync(r); |
757 |
|
checkCompletedWithWrappedCFException(f); |
758 |
< |
assertTrue(r.ran); |
758 |
> |
assertEquals(1, r.invocationCount); |
759 |
|
} |
760 |
|
|
761 |
|
// seq completion methods |
772 |
|
g = f.thenRun(r = new Noop()); |
773 |
|
f.complete(null); |
774 |
|
checkCompletedNormally(g, null); |
775 |
< |
assertTrue(r.ran); |
775 |
> |
assertEquals(1, r.invocationCount); |
776 |
|
|
777 |
|
f = new CompletableFuture<>(); |
778 |
|
f.complete(null); |
779 |
|
g = f.thenRun(r = new Noop()); |
780 |
|
checkCompletedNormally(g, null); |
781 |
< |
assertTrue(r.ran); |
781 |
> |
assertEquals(1, r.invocationCount); |
782 |
|
} |
783 |
|
|
784 |
|
/** |
794 |
|
g = f.thenRun(r = new Noop()); |
795 |
|
f.completeExceptionally(new CFException()); |
796 |
|
checkCompletedWithWrappedCFException(g); |
797 |
< |
assertFalse(r.ran); |
797 |
> |
assertEquals(0, r.invocationCount); |
798 |
|
|
799 |
|
f = new CompletableFuture<>(); |
800 |
|
f.completeExceptionally(new CFException()); |
801 |
|
g = f.thenRun(r = new Noop()); |
802 |
|
checkCompletedWithWrappedCFException(g); |
803 |
< |
assertFalse(r.ran); |
803 |
> |
assertEquals(0, r.invocationCount); |
804 |
|
} |
805 |
|
|
806 |
|
/** |
915 |
|
CompletableFuture<Void> g = f.thenAccept(r); |
916 |
|
f.complete(one); |
917 |
|
checkCompletedWithWrappedCFException(g); |
918 |
< |
assertTrue(r.ran); |
918 |
> |
assertEquals(1, r.invocationCount); |
919 |
|
} |
920 |
|
|
921 |
|
/** |
934 |
|
* of sources |
935 |
|
*/ |
936 |
|
public void testThenCombine_normalCompletion1() { |
937 |
+ |
for (boolean createIncomplete : new boolean[] { true, false }) |
938 |
+ |
for (boolean fFirst : new boolean[] { true, false }) |
939 |
|
for (ExecutionMode m : ExecutionMode.values()) |
940 |
|
for (Integer v1 : new Integer[] { 1, null }) |
941 |
|
for (Integer v2 : new Integer[] { 2, null }) { |
943 |
|
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
944 |
|
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
945 |
|
final SubtractFunction r = new SubtractFunction(); |
946 |
< |
final CompletableFuture<Integer> h = m.thenCombine(f, g, r); |
947 |
< |
|
955 |
< |
f.complete(v1); |
956 |
< |
checkIncomplete(h); |
957 |
< |
assertFalse(r.ran()); |
958 |
< |
g.complete(v2); |
959 |
< |
|
960 |
< |
checkCompletedNormally(h, subtract(v1, v2)); |
961 |
< |
checkCompletedNormally(f, v1); |
962 |
< |
checkCompletedNormally(g, v2); |
963 |
< |
} |
964 |
< |
} |
965 |
< |
|
966 |
< |
public void testThenCombine_normalCompletion2() { |
967 |
< |
for (ExecutionMode m : ExecutionMode.values()) |
968 |
< |
for (Integer v1 : new Integer[] { 1, null }) |
969 |
< |
for (Integer v2 : new Integer[] { 2, null }) { |
970 |
< |
|
971 |
< |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
972 |
< |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
973 |
< |
final SubtractFunction r = new SubtractFunction(); |
974 |
< |
final CompletableFuture<Integer> h = m.thenCombine(f, g, r); |
975 |
< |
|
976 |
< |
g.complete(v2); |
977 |
< |
checkIncomplete(h); |
978 |
< |
assertFalse(r.ran()); |
979 |
< |
f.complete(v1); |
980 |
< |
|
981 |
< |
checkCompletedNormally(h, subtract(v1, v2)); |
982 |
< |
checkCompletedNormally(f, v1); |
983 |
< |
checkCompletedNormally(g, v2); |
984 |
< |
} |
985 |
< |
} |
986 |
< |
|
987 |
< |
public void testThenCombine_normalCompletion3() { |
988 |
< |
for (ExecutionMode m : ExecutionMode.values()) |
989 |
< |
for (Integer v1 : new Integer[] { 1, null }) |
990 |
< |
for (Integer v2 : new Integer[] { 2, null }) { |
991 |
< |
|
992 |
< |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
993 |
< |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
994 |
< |
final SubtractFunction r = new SubtractFunction(); |
995 |
< |
|
996 |
< |
g.complete(v2); |
997 |
< |
f.complete(v1); |
998 |
< |
final CompletableFuture<Integer> h = m.thenCombine(f, g, r); |
999 |
< |
|
1000 |
< |
checkCompletedNormally(h, subtract(v1, v2)); |
1001 |
< |
checkCompletedNormally(f, v1); |
1002 |
< |
checkCompletedNormally(g, v2); |
1003 |
< |
} |
1004 |
< |
} |
1005 |
< |
|
1006 |
< |
public void testThenCombine_normalCompletion4() { |
1007 |
< |
for (ExecutionMode m : ExecutionMode.values()) |
1008 |
< |
for (Integer v1 : new Integer[] { 1, null }) |
1009 |
< |
for (Integer v2 : new Integer[] { 2, null }) { |
1010 |
< |
|
1011 |
< |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
1012 |
< |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
1013 |
< |
final SubtractFunction r = new SubtractFunction(); |
946 |
> |
CompletableFuture<Integer> h = null; |
947 |
> |
if (createIncomplete) h = m.thenCombine(f, g, r); |
948 |
|
|
949 |
< |
f.complete(v1); |
950 |
< |
g.complete(v2); |
951 |
< |
final CompletableFuture<Integer> h = m.thenCombine(f, g, r); |
949 |
> |
if (fFirst) |
950 |
> |
f.complete(v1); |
951 |
> |
else |
952 |
> |
g.complete(v2); |
953 |
> |
if (createIncomplete) checkIncomplete(h); |
954 |
> |
assertEquals(0, r.invocationCount); |
955 |
> |
if (!fFirst) |
956 |
> |
f.complete(v1); |
957 |
> |
else |
958 |
> |
g.complete(v2); |
959 |
> |
if (!createIncomplete) h = m.thenCombine(f, g, r); |
960 |
|
|
961 |
|
checkCompletedNormally(h, subtract(v1, v2)); |
962 |
|
checkCompletedNormally(f, v1); |
963 |
|
checkCompletedNormally(g, v2); |
964 |
+ |
assertEquals(1, r.invocationCount); |
965 |
|
} |
966 |
|
} |
967 |
|
|
985 |
|
|
986 |
|
checkCompletedWithWrappedCFException(h, ex); |
987 |
|
checkCompletedWithWrappedCFException(f, ex); |
988 |
< |
assertFalse(r.ran()); |
988 |
> |
assertEquals(0, r.invocationCount); |
989 |
|
checkCompletedNormally(g, v1); |
990 |
|
} |
991 |
|
} |
1006 |
|
|
1007 |
|
checkCompletedWithWrappedCFException(h, ex); |
1008 |
|
checkCompletedWithWrappedCFException(g, ex); |
1009 |
< |
assertFalse(r.ran()); |
1009 |
> |
assertEquals(0, r.invocationCount); |
1010 |
|
checkCompletedNormally(f, v1); |
1011 |
|
} |
1012 |
|
} |
1026 |
|
|
1027 |
|
checkCompletedWithWrappedCFException(h, ex); |
1028 |
|
checkCompletedWithWrappedCFException(g, ex); |
1029 |
< |
assertFalse(r.ran()); |
1029 |
> |
assertEquals(0, r.invocationCount); |
1030 |
|
checkCompletedNormally(f, v1); |
1031 |
|
} |
1032 |
|
} |
1046 |
|
|
1047 |
|
checkCompletedWithWrappedCFException(h, ex); |
1048 |
|
checkCompletedWithWrappedCFException(f, ex); |
1049 |
< |
assertFalse(r.ran()); |
1049 |
> |
assertEquals(0, r.invocationCount); |
1050 |
|
checkCompletedNormally(g, v1); |
1051 |
|
} |
1052 |
|
} |
1113 |
|
|
1114 |
|
checkCompletedWithWrappedCancellationException(h); |
1115 |
|
checkCancelled(f); |
1116 |
< |
assertFalse(r.ran()); |
1116 |
> |
assertEquals(0, r.invocationCount); |
1117 |
|
checkCompletedNormally(g, v1); |
1118 |
|
} |
1119 |
|
} |
1134 |
|
|
1135 |
|
checkCompletedWithWrappedCancellationException(h); |
1136 |
|
checkCancelled(g); |
1137 |
< |
assertFalse(r.ran()); |
1137 |
> |
assertEquals(0, r.invocationCount); |
1138 |
|
checkCompletedNormally(f, v1); |
1139 |
|
} |
1140 |
|
} |
1154 |
|
|
1155 |
|
checkCompletedWithWrappedCancellationException(h); |
1156 |
|
checkCancelled(g); |
1157 |
< |
assertFalse(r.ran()); |
1157 |
> |
assertEquals(0, r.invocationCount); |
1158 |
|
checkCompletedNormally(f, v1); |
1159 |
|
} |
1160 |
|
} |
1174 |
|
|
1175 |
|
checkCompletedWithWrappedCancellationException(h); |
1176 |
|
checkCancelled(f); |
1177 |
< |
assertFalse(r.ran()); |
1177 |
> |
assertEquals(0, r.invocationCount); |
1178 |
|
checkCompletedNormally(g, v1); |
1179 |
|
} |
1180 |
|
} |
1195 |
|
|
1196 |
|
f.complete(v1); |
1197 |
|
checkIncomplete(h); |
1198 |
< |
assertFalse(r.ran()); |
1198 |
> |
assertEquals(0, r.invocationCount); |
1199 |
|
g.complete(v2); |
1200 |
|
|
1201 |
|
checkCompletedNormally(h, null); |
1217 |
|
|
1218 |
|
g.complete(v2); |
1219 |
|
checkIncomplete(h); |
1220 |
< |
assertFalse(r.ran()); |
1220 |
> |
assertEquals(0, r.invocationCount); |
1221 |
|
f.complete(v1); |
1222 |
|
|
1223 |
|
checkCompletedNormally(h, null); |
1287 |
|
|
1288 |
|
checkCompletedWithWrappedCFException(h, ex); |
1289 |
|
checkCompletedWithWrappedCFException(f, ex); |
1290 |
< |
assertFalse(r.ran()); |
1290 |
> |
assertEquals(0, r.invocationCount); |
1291 |
|
checkCompletedNormally(g, v1); |
1292 |
|
} |
1293 |
|
} |
1308 |
|
|
1309 |
|
checkCompletedWithWrappedCFException(h, ex); |
1310 |
|
checkCompletedWithWrappedCFException(g, ex); |
1311 |
< |
assertFalse(r.ran()); |
1311 |
> |
assertEquals(0, r.invocationCount); |
1312 |
|
checkCompletedNormally(f, v1); |
1313 |
|
} |
1314 |
|
} |
1328 |
|
|
1329 |
|
checkCompletedWithWrappedCFException(h, ex); |
1330 |
|
checkCompletedWithWrappedCFException(g, ex); |
1331 |
< |
assertFalse(r.ran()); |
1331 |
> |
assertEquals(0, r.invocationCount); |
1332 |
|
checkCompletedNormally(f, v1); |
1333 |
|
} |
1334 |
|
} |
1348 |
|
|
1349 |
|
checkCompletedWithWrappedCFException(h, ex); |
1350 |
|
checkCompletedWithWrappedCFException(f, ex); |
1351 |
< |
assertFalse(r.ran()); |
1351 |
> |
assertEquals(0, r.invocationCount); |
1352 |
|
checkCompletedNormally(g, v1); |
1353 |
|
} |
1354 |
|
} |
1415 |
|
|
1416 |
|
checkCompletedWithWrappedCancellationException(h); |
1417 |
|
checkCancelled(f); |
1418 |
< |
assertFalse(r.ran()); |
1418 |
> |
assertEquals(0, r.invocationCount); |
1419 |
|
checkCompletedNormally(g, v1); |
1420 |
|
} |
1421 |
|
} |
1436 |
|
|
1437 |
|
checkCompletedWithWrappedCancellationException(h); |
1438 |
|
checkCancelled(g); |
1439 |
< |
assertFalse(r.ran()); |
1439 |
> |
assertEquals(0, r.invocationCount); |
1440 |
|
checkCompletedNormally(f, v1); |
1441 |
|
} |
1442 |
|
} |
1456 |
|
|
1457 |
|
checkCompletedWithWrappedCancellationException(h); |
1458 |
|
checkCancelled(g); |
1459 |
< |
assertFalse(r.ran()); |
1459 |
> |
assertEquals(0, r.invocationCount); |
1460 |
|
checkCompletedNormally(f, v1); |
1461 |
|
} |
1462 |
|
} |
1476 |
|
|
1477 |
|
checkCompletedWithWrappedCancellationException(h); |
1478 |
|
checkCancelled(f); |
1479 |
< |
assertFalse(r.ran()); |
1479 |
> |
assertEquals(0, r.invocationCount); |
1480 |
|
checkCompletedNormally(g, v1); |
1481 |
|
} |
1482 |
|
} |
1497 |
|
|
1498 |
|
f.complete(v1); |
1499 |
|
checkIncomplete(h); |
1500 |
< |
assertFalse(r.ran); |
1500 |
> |
assertEquals(0, r.invocationCount); |
1501 |
|
g.complete(v2); |
1502 |
|
|
1503 |
|
checkCompletedNormally(h, null); |
1504 |
< |
assertTrue(r.ran); |
1504 |
> |
assertEquals(1, r.invocationCount); |
1505 |
|
checkCompletedNormally(f, v1); |
1506 |
|
checkCompletedNormally(g, v2); |
1507 |
|
} |
1519 |
|
|
1520 |
|
g.complete(v2); |
1521 |
|
checkIncomplete(h); |
1522 |
< |
assertFalse(r.ran); |
1522 |
> |
assertEquals(0, r.invocationCount); |
1523 |
|
f.complete(v1); |
1524 |
|
|
1525 |
|
checkCompletedNormally(h, null); |
1526 |
< |
assertTrue(r.ran); |
1526 |
> |
assertEquals(1, r.invocationCount); |
1527 |
|
checkCompletedNormally(f, v1); |
1528 |
|
checkCompletedNormally(g, v2); |
1529 |
|
} |
1543 |
|
final CompletableFuture<Void> h = m.runAfterBoth(f, g, r); |
1544 |
|
|
1545 |
|
checkCompletedNormally(h, null); |
1546 |
< |
assertTrue(r.ran); |
1546 |
> |
assertEquals(1, r.invocationCount); |
1547 |
|
checkCompletedNormally(f, v1); |
1548 |
|
checkCompletedNormally(g, v2); |
1549 |
|
} |
1563 |
|
final CompletableFuture<Void> h = m.runAfterBoth(f, g, r); |
1564 |
|
|
1565 |
|
checkCompletedNormally(h, null); |
1566 |
< |
assertTrue(r.ran); |
1566 |
> |
assertEquals(1, r.invocationCount); |
1567 |
|
checkCompletedNormally(f, v1); |
1568 |
|
checkCompletedNormally(g, v2); |
1569 |
|
} |
1589 |
|
|
1590 |
|
checkCompletedWithWrappedCFException(h, ex); |
1591 |
|
checkCompletedWithWrappedCFException(f, ex); |
1592 |
< |
assertFalse(r.ran); |
1592 |
> |
assertEquals(0, r.invocationCount); |
1593 |
|
checkCompletedNormally(g, v1); |
1594 |
|
} |
1595 |
|
} |
1610 |
|
|
1611 |
|
checkCompletedWithWrappedCFException(h, ex); |
1612 |
|
checkCompletedWithWrappedCFException(g, ex); |
1613 |
< |
assertFalse(r.ran); |
1613 |
> |
assertEquals(0, r.invocationCount); |
1614 |
|
checkCompletedNormally(f, v1); |
1615 |
|
} |
1616 |
|
} |
1630 |
|
|
1631 |
|
checkCompletedWithWrappedCFException(h, ex); |
1632 |
|
checkCompletedWithWrappedCFException(g, ex); |
1633 |
< |
assertFalse(r.ran); |
1633 |
> |
assertEquals(0, r.invocationCount); |
1634 |
|
checkCompletedNormally(f, v1); |
1635 |
|
} |
1636 |
|
} |
1650 |
|
|
1651 |
|
checkCompletedWithWrappedCFException(h, ex); |
1652 |
|
checkCompletedWithWrappedCFException(f, ex); |
1653 |
< |
assertFalse(r.ran); |
1653 |
> |
assertEquals(0, r.invocationCount); |
1654 |
|
checkCompletedNormally(g, v1); |
1655 |
|
} |
1656 |
|
} |
1717 |
|
|
1718 |
|
checkCompletedWithWrappedCancellationException(h); |
1719 |
|
checkCancelled(f); |
1720 |
< |
assertFalse(r.ran); |
1720 |
> |
assertEquals(0, r.invocationCount); |
1721 |
|
checkCompletedNormally(g, v1); |
1722 |
|
} |
1723 |
|
} |
1738 |
|
|
1739 |
|
checkCompletedWithWrappedCancellationException(h); |
1740 |
|
checkCancelled(g); |
1741 |
< |
assertFalse(r.ran); |
1741 |
> |
assertEquals(0, r.invocationCount); |
1742 |
|
checkCompletedNormally(f, v1); |
1743 |
|
} |
1744 |
|
} |
1758 |
|
|
1759 |
|
checkCompletedWithWrappedCancellationException(h); |
1760 |
|
checkCancelled(g); |
1761 |
< |
assertFalse(r.ran); |
1761 |
> |
assertEquals(0, r.invocationCount); |
1762 |
|
checkCompletedNormally(f, v1); |
1763 |
|
} |
1764 |
|
} |
1778 |
|
|
1779 |
|
checkCompletedWithWrappedCancellationException(h); |
1780 |
|
checkCancelled(f); |
1781 |
< |
assertFalse(r.ran); |
1781 |
> |
assertEquals(0, r.invocationCount); |
1782 |
|
checkCompletedNormally(g, v1); |
1783 |
|
} |
1784 |
|
} |
1845 |
|
// unspecified behavior |
1846 |
|
assertTrue(Objects.equals(h.join(), inc(v1)) || |
1847 |
|
Objects.equals(h.join(), inc(v2))); |
1848 |
+ |
assertEquals(1, r.invocationCount); |
1849 |
|
} |
1850 |
|
} |
1851 |
|
|
1867 |
|
checkCompletedWithWrappedCFException(h, ex); |
1868 |
|
g.complete(v1); |
1869 |
|
|
1870 |
< |
assertFalse(r.ran()); |
1870 |
> |
assertEquals(0, r.invocationCount); |
1871 |
|
checkCompletedNormally(g, v1); |
1872 |
|
checkCompletedWithWrappedCFException(f, ex); |
1873 |
|
checkCompletedWithWrappedCFException(h, ex); |
1888 |
|
checkCompletedWithWrappedCFException(h, ex); |
1889 |
|
f.complete(v1); |
1890 |
|
|
1891 |
< |
assertFalse(r.ran()); |
1891 |
> |
assertEquals(0, r.invocationCount); |
1892 |
|
checkCompletedNormally(f, v1); |
1893 |
|
checkCompletedWithWrappedCFException(g, ex); |
1894 |
|
checkCompletedWithWrappedCFException(h, ex); |
1912 |
|
Integer v; |
1913 |
|
try { |
1914 |
|
assertEquals(h.join(), inc(v1)); |
1915 |
< |
assertTrue(r.ran()); |
1915 |
> |
assertEquals(1, r.invocationCount); |
1916 |
|
} catch (CompletionException ok) { |
1917 |
|
checkCompletedWithWrappedCFException(h, ex); |
1918 |
< |
assertFalse(r.ran()); |
1918 |
> |
assertEquals(0, r.invocationCount); |
1919 |
|
} |
1920 |
|
|
1921 |
|
checkCompletedWithWrappedCFException(g, ex); |
1940 |
|
Integer v; |
1941 |
|
try { |
1942 |
|
assertEquals(h.join(), inc(v1)); |
1943 |
< |
assertTrue(r.ran()); |
1943 |
> |
assertEquals(1, r.invocationCount); |
1944 |
|
} catch (CompletionException ok) { |
1945 |
|
checkCompletedWithWrappedCFException(h, ex); |
1946 |
< |
assertFalse(r.ran()); |
1946 |
> |
assertEquals(0, r.invocationCount); |
1947 |
|
} |
1948 |
|
|
1949 |
|
checkCompletedWithWrappedCFException(f, ex); |
2006 |
– |
assertFalse(r.ran()); |
1950 |
|
checkCompletedNormally(g, v1); |
1951 |
|
} |
1952 |
|
} |
2008 |
|
g.complete(v1); |
2009 |
|
|
2010 |
|
checkCancelled(f); |
2011 |
< |
assertFalse(r.ran()); |
2011 |
> |
assertEquals(0, r.invocationCount); |
2012 |
|
checkCompletedNormally(g, v1); |
2013 |
|
checkCompletedWithWrappedCancellationException(h); |
2014 |
|
} |
2029 |
|
f.complete(v1); |
2030 |
|
|
2031 |
|
checkCancelled(g); |
2032 |
< |
assertFalse(r.ran()); |
2032 |
> |
assertEquals(0, r.invocationCount); |
2033 |
|
checkCompletedNormally(f, v1); |
2034 |
|
checkCompletedWithWrappedCancellationException(h); |
2035 |
|
} |
2052 |
|
Integer v; |
2053 |
|
try { |
2054 |
|
assertEquals(h.join(), inc(v1)); |
2055 |
< |
assertTrue(r.ran()); |
2055 |
> |
assertEquals(1, r.invocationCount); |
2056 |
|
} catch (CompletionException ok) { |
2057 |
|
checkCompletedWithWrappedCancellationException(h); |
2058 |
< |
assertFalse(r.ran()); |
2058 |
> |
assertEquals(0, r.invocationCount); |
2059 |
|
} |
2060 |
|
|
2061 |
|
checkCancelled(g); |
2080 |
|
Integer v; |
2081 |
|
try { |
2082 |
|
assertEquals(h.join(), inc(v1)); |
2083 |
< |
assertTrue(r.ran()); |
2083 |
> |
assertEquals(1, r.invocationCount); |
2084 |
|
} catch (CompletionException ok) { |
2085 |
|
checkCompletedWithWrappedCancellationException(h); |
2086 |
< |
assertFalse(r.ran()); |
2086 |
> |
assertEquals(0, r.invocationCount); |
2087 |
|
} |
2088 |
|
|
2089 |
|
checkCancelled(f); |
2177 |
|
checkCompletedWithWrappedCFException(h, ex); |
2178 |
|
g.complete(v1); |
2179 |
|
|
2180 |
< |
assertFalse(r.ran()); |
2180 |
> |
assertEquals(0, r.invocationCount); |
2181 |
|
checkCompletedNormally(g, v1); |
2182 |
|
checkCompletedWithWrappedCFException(f, ex); |
2183 |
|
checkCompletedWithWrappedCFException(h, ex); |
2198 |
|
checkCompletedWithWrappedCFException(h, ex); |
2199 |
|
f.complete(v1); |
2200 |
|
|
2201 |
< |
assertFalse(r.ran()); |
2201 |
> |
assertEquals(0, r.invocationCount); |
2202 |
|
checkCompletedNormally(f, v1); |
2203 |
|
checkCompletedWithWrappedCFException(g, ex); |
2204 |
|
checkCompletedWithWrappedCFException(h, ex); |
2222 |
|
Integer v; |
2223 |
|
try { |
2224 |
|
assertEquals(h.join(), null); |
2225 |
< |
assertTrue(r.ran()); |
2225 |
> |
assertEquals(1, r.invocationCount); |
2226 |
|
assertEquals(inc(v1), r.value); |
2227 |
|
} catch (CompletionException ok) { |
2228 |
|
checkCompletedWithWrappedCFException(h, ex); |
2229 |
< |
assertFalse(r.ran()); |
2229 |
> |
assertEquals(0, r.invocationCount); |
2230 |
|
} |
2231 |
|
|
2232 |
|
checkCompletedWithWrappedCFException(g, ex); |
2251 |
|
Integer v; |
2252 |
|
try { |
2253 |
|
assertEquals(h.join(), null); |
2254 |
< |
assertTrue(r.ran()); |
2254 |
> |
assertEquals(1, r.invocationCount); |
2255 |
|
assertEquals(inc(v1), r.value); |
2256 |
|
} catch (CompletionException ok) { |
2257 |
|
checkCompletedWithWrappedCFException(h, ex); |
2258 |
< |
assertFalse(r.ran()); |
2258 |
> |
assertEquals(0, r.invocationCount); |
2259 |
|
} |
2260 |
|
|
2261 |
|
checkCompletedWithWrappedCFException(f, ex); |
2319 |
– |
assertFalse(r.ran()); |
2262 |
|
checkCompletedNormally(g, v1); |
2263 |
|
} |
2264 |
|
} |
2320 |
|
g.complete(v1); |
2321 |
|
|
2322 |
|
checkCancelled(f); |
2323 |
< |
assertFalse(r.ran()); |
2323 |
> |
assertEquals(0, r.invocationCount); |
2324 |
|
checkCompletedNormally(g, v1); |
2325 |
|
checkCompletedWithWrappedCancellationException(h); |
2326 |
|
} |
2341 |
|
f.complete(v1); |
2342 |
|
|
2343 |
|
checkCancelled(g); |
2344 |
< |
assertFalse(r.ran()); |
2344 |
> |
assertEquals(0, r.invocationCount); |
2345 |
|
checkCompletedNormally(f, v1); |
2346 |
|
checkCompletedWithWrappedCancellationException(h); |
2347 |
|
} |
2364 |
|
Integer v; |
2365 |
|
try { |
2366 |
|
assertEquals(h.join(), null); |
2367 |
< |
assertTrue(r.ran()); |
2367 |
> |
assertEquals(1, r.invocationCount); |
2368 |
|
assertEquals(inc(v1), r.value); |
2369 |
|
} catch (CompletionException ok) { |
2370 |
|
checkCompletedWithWrappedCancellationException(h); |
2371 |
< |
assertFalse(r.ran()); |
2371 |
> |
assertEquals(0, r.invocationCount); |
2372 |
|
} |
2373 |
|
|
2374 |
|
checkCancelled(g); |
2393 |
|
Integer v; |
2394 |
|
try { |
2395 |
|
assertEquals(h.join(), null); |
2396 |
< |
assertTrue(r.ran()); |
2396 |
> |
assertEquals(1, r.invocationCount); |
2397 |
|
assertEquals(inc(v1), r.value); |
2398 |
|
} catch (CompletionException ok) { |
2399 |
|
checkCompletedWithWrappedCancellationException(h); |
2400 |
< |
assertFalse(r.ran()); |
2400 |
> |
assertEquals(0, r.invocationCount); |
2401 |
|
} |
2402 |
|
|
2403 |
|
checkCancelled(f); |
2409 |
|
* runAfterEither result completes normally after normal completion |
2410 |
|
* of either source |
2411 |
|
*/ |
2412 |
< |
public void testRunAfterEither() { |
2413 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2414 |
< |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2415 |
< |
Noop r = new Noop(); |
2474 |
< |
CompletableFuture<Void> g = f.runAfterEither(f2, r); |
2475 |
< |
f.complete(one); |
2476 |
< |
checkCompletedNormally(g, null); |
2477 |
< |
f2.complete(one); |
2478 |
< |
checkCompletedNormally(g, null); |
2479 |
< |
assertTrue(r.ran); |
2412 |
> |
public void testRunAfterEither_normalCompletion1() { |
2413 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2414 |
> |
for (Integer v1 : new Integer[] { 1, null }) |
2415 |
> |
for (Integer v2 : new Integer[] { 2, null }) { |
2416 |
|
|
2417 |
< |
r = new Noop(); |
2418 |
< |
f = new CompletableFuture<>(); |
2419 |
< |
f.complete(one); |
2420 |
< |
f2 = new CompletableFuture<>(); |
2421 |
< |
g = f.runAfterEither(f2, r); |
2422 |
< |
checkCompletedNormally(g, null); |
2423 |
< |
assertTrue(r.ran); |
2417 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2418 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2419 |
> |
final Noop r = new Noop(); |
2420 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2421 |
> |
|
2422 |
> |
f.complete(v1); |
2423 |
> |
checkCompletedNormally(h, null); |
2424 |
> |
assertEquals(1, r.invocationCount); |
2425 |
> |
g.complete(v2); |
2426 |
> |
|
2427 |
> |
checkCompletedNormally(f, v1); |
2428 |
> |
checkCompletedNormally(g, v2); |
2429 |
> |
checkCompletedNormally(h, null); |
2430 |
> |
assertEquals(1, r.invocationCount); |
2431 |
> |
} |
2432 |
> |
} |
2433 |
> |
|
2434 |
> |
public void testRunAfterEither_normalCompletion2() { |
2435 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2436 |
> |
for (Integer v1 : new Integer[] { 1, null }) |
2437 |
> |
for (Integer v2 : new Integer[] { 2, null }) { |
2438 |
> |
|
2439 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2440 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2441 |
> |
final Noop r = new Noop(); |
2442 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2443 |
> |
|
2444 |
> |
g.complete(v2); |
2445 |
> |
checkCompletedNormally(h, null); |
2446 |
> |
assertEquals(1, r.invocationCount); |
2447 |
> |
f.complete(v1); |
2448 |
> |
|
2449 |
> |
checkCompletedNormally(f, v1); |
2450 |
> |
checkCompletedNormally(g, v2); |
2451 |
> |
checkCompletedNormally(h, null); |
2452 |
> |
assertEquals(1, r.invocationCount); |
2453 |
> |
} |
2454 |
> |
} |
2455 |
> |
public void testRunAfterEither_normalCompletion3() { |
2456 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2457 |
> |
for (Integer v1 : new Integer[] { 1, null }) |
2458 |
> |
for (Integer v2 : new Integer[] { 2, null }) { |
2459 |
> |
|
2460 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2461 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2462 |
> |
final Noop r = new Noop(); |
2463 |
> |
|
2464 |
> |
f.complete(v1); |
2465 |
> |
g.complete(v2); |
2466 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2467 |
> |
|
2468 |
> |
checkCompletedNormally(h, null); |
2469 |
> |
checkCompletedNormally(f, v1); |
2470 |
> |
checkCompletedNormally(g, v2); |
2471 |
> |
assertEquals(1, r.invocationCount); |
2472 |
> |
} |
2473 |
|
} |
2474 |
|
|
2475 |
|
/** |
2476 |
|
* runAfterEither result completes exceptionally after exceptional |
2477 |
|
* completion of either source |
2478 |
|
*/ |
2479 |
< |
public void testRunAfterEither2() { |
2480 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2481 |
< |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2497 |
< |
Noop r = new Noop(); |
2498 |
< |
CompletableFuture<Void> g = f.runAfterEither(f2, r); |
2499 |
< |
f.completeExceptionally(new CFException()); |
2500 |
< |
f2.complete(one); |
2501 |
< |
checkCompletedWithWrappedCFException(g); |
2479 |
> |
public void testRunAfterEither_exceptionalCompletion1() { |
2480 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2481 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2482 |
|
|
2483 |
< |
r = new Noop(); |
2484 |
< |
f = new CompletableFuture<>(); |
2485 |
< |
f2 = new CompletableFuture<>(); |
2486 |
< |
f2.completeExceptionally(new CFException()); |
2487 |
< |
g = f.runAfterEither(f2, r); |
2488 |
< |
checkCompletedWithWrappedCFException(g); |
2483 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2484 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2485 |
> |
final Noop r = new Noop(); |
2486 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2487 |
> |
final CFException ex = new CFException(); |
2488 |
> |
|
2489 |
> |
f.completeExceptionally(ex); |
2490 |
> |
checkCompletedWithWrappedCFException(h, ex); |
2491 |
> |
g.complete(v1); |
2492 |
> |
|
2493 |
> |
assertEquals(0, r.invocationCount); |
2494 |
> |
checkCompletedNormally(g, v1); |
2495 |
> |
checkCompletedWithWrappedCFException(f, ex); |
2496 |
> |
checkCompletedWithWrappedCFException(h, ex); |
2497 |
> |
} |
2498 |
> |
} |
2499 |
> |
|
2500 |
> |
public void testRunAfterEither_exceptionalCompletion2() { |
2501 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2502 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2503 |
> |
|
2504 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2505 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2506 |
> |
final Noop r = new Noop(); |
2507 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2508 |
> |
final CFException ex = new CFException(); |
2509 |
> |
|
2510 |
> |
g.completeExceptionally(ex); |
2511 |
> |
checkCompletedWithWrappedCFException(h, ex); |
2512 |
> |
f.complete(v1); |
2513 |
> |
|
2514 |
> |
assertEquals(0, r.invocationCount); |
2515 |
> |
checkCompletedNormally(f, v1); |
2516 |
> |
checkCompletedWithWrappedCFException(g, ex); |
2517 |
> |
checkCompletedWithWrappedCFException(h, ex); |
2518 |
> |
} |
2519 |
> |
} |
2520 |
> |
|
2521 |
> |
public void testRunAfterEither_exceptionalCompletion3() { |
2522 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2523 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2524 |
> |
|
2525 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2526 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2527 |
> |
final Noop r = new Noop(); |
2528 |
> |
final CFException ex = new CFException(); |
2529 |
> |
|
2530 |
> |
g.completeExceptionally(ex); |
2531 |
> |
f.complete(v1); |
2532 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2533 |
> |
|
2534 |
> |
// unspecified behavior |
2535 |
> |
Integer v; |
2536 |
> |
try { |
2537 |
> |
assertEquals(h.join(), null); |
2538 |
> |
assertEquals(1, r.invocationCount); |
2539 |
> |
} catch (CompletionException ok) { |
2540 |
> |
checkCompletedWithWrappedCFException(h, ex); |
2541 |
> |
assertEquals(0, r.invocationCount); |
2542 |
> |
} |
2543 |
> |
|
2544 |
> |
checkCompletedWithWrappedCFException(g, ex); |
2545 |
> |
checkCompletedNormally(f, v1); |
2546 |
> |
} |
2547 |
> |
} |
2548 |
> |
|
2549 |
> |
public void testRunAfterEither_exceptionalCompletion4() { |
2550 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2551 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2552 |
> |
|
2553 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2554 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2555 |
> |
final Noop r = new Noop(); |
2556 |
> |
final CFException ex = new CFException(); |
2557 |
> |
|
2558 |
> |
f.completeExceptionally(ex); |
2559 |
> |
g.complete(v1); |
2560 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2561 |
> |
|
2562 |
> |
// unspecified behavior |
2563 |
> |
Integer v; |
2564 |
> |
try { |
2565 |
> |
assertEquals(h.join(), null); |
2566 |
> |
assertEquals(1, r.invocationCount); |
2567 |
> |
} catch (CompletionException ok) { |
2568 |
> |
checkCompletedWithWrappedCFException(h, ex); |
2569 |
> |
assertEquals(0, r.invocationCount); |
2570 |
> |
} |
2571 |
> |
|
2572 |
> |
checkCompletedWithWrappedCFException(f, ex); |
2573 |
> |
checkCompletedNormally(g, v1); |
2574 |
> |
} |
2575 |
|
} |
2576 |
|
|
2577 |
|
/** |
2578 |
|
* runAfterEither result completes exceptionally if action does |
2579 |
|
*/ |
2580 |
< |
public void testRunAfterEither3() { |
2581 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2582 |
< |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2583 |
< |
FailingNoop r = new FailingNoop(); |
2584 |
< |
CompletableFuture<Void> g = f.runAfterEither(f2, r); |
2585 |
< |
f2.complete(two); |
2586 |
< |
checkCompletedWithWrappedCFException(g); |
2580 |
> |
public void testRunAfterEither_actionFailed1() { |
2581 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2582 |
> |
for (Integer v1 : new Integer[] { 1, null }) |
2583 |
> |
for (Integer v2 : new Integer[] { 2, null }) { |
2584 |
> |
|
2585 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2586 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2587 |
> |
final FailingNoop r = new FailingNoop(); |
2588 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2589 |
> |
|
2590 |
> |
f.complete(v1); |
2591 |
> |
checkCompletedWithWrappedCFException(h); |
2592 |
> |
g.complete(v2); |
2593 |
> |
checkCompletedNormally(f, v1); |
2594 |
> |
checkCompletedNormally(g, v2); |
2595 |
> |
} |
2596 |
> |
} |
2597 |
> |
|
2598 |
> |
public void testRunAfterEither_actionFailed2() { |
2599 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2600 |
> |
for (Integer v1 : new Integer[] { 1, null }) |
2601 |
> |
for (Integer v2 : new Integer[] { 2, null }) { |
2602 |
> |
|
2603 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2604 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2605 |
> |
final FailingNoop r = new FailingNoop(); |
2606 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2607 |
> |
|
2608 |
> |
g.complete(v2); |
2609 |
> |
checkCompletedWithWrappedCFException(h); |
2610 |
> |
f.complete(v1); |
2611 |
> |
checkCompletedNormally(f, v1); |
2612 |
> |
checkCompletedNormally(g, v2); |
2613 |
> |
} |
2614 |
|
} |
2615 |
|
|
2616 |
|
/** |
2617 |
|
* runAfterEither result completes exceptionally if either source cancelled |
2618 |
|
*/ |
2619 |
< |
public void testRunAfterEither4() { |
2620 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2621 |
< |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2622 |
< |
Noop r = new Noop(); |
2623 |
< |
CompletableFuture<Void> g = f.runAfterEither(f2, r); |
2624 |
< |
assertTrue(f.cancel(true)); |
2625 |
< |
checkCompletedWithWrappedCancellationException(g); |
2626 |
< |
f = new CompletableFuture<>(); |
2627 |
< |
f2 = new CompletableFuture<>(); |
2628 |
< |
assertTrue(f2.cancel(true)); |
2629 |
< |
checkCompletedWithWrappedCancellationException(g); |
2619 |
> |
public void testRunAfterEither_sourceCancelled1() { |
2620 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2621 |
> |
for (boolean mayInterruptIfRunning : new boolean[] { true, false }) |
2622 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2623 |
> |
|
2624 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2625 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2626 |
> |
final Noop r = new Noop(); |
2627 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2628 |
> |
|
2629 |
> |
assertTrue(f.cancel(mayInterruptIfRunning)); |
2630 |
> |
checkCompletedWithWrappedCancellationException(h); |
2631 |
> |
g.complete(v1); |
2632 |
> |
|
2633 |
> |
checkCancelled(f); |
2634 |
> |
assertEquals(0, r.invocationCount); |
2635 |
> |
checkCompletedNormally(g, v1); |
2636 |
> |
checkCompletedWithWrappedCancellationException(h); |
2637 |
> |
} |
2638 |
> |
} |
2639 |
> |
|
2640 |
> |
public void testRunAfterEither_sourceCancelled2() { |
2641 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2642 |
> |
for (boolean mayInterruptIfRunning : new boolean[] { true, false }) |
2643 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2644 |
> |
|
2645 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2646 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2647 |
> |
final Noop r = new Noop(); |
2648 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2649 |
> |
|
2650 |
> |
assertTrue(g.cancel(mayInterruptIfRunning)); |
2651 |
> |
checkCompletedWithWrappedCancellationException(h); |
2652 |
> |
f.complete(v1); |
2653 |
> |
|
2654 |
> |
checkCancelled(g); |
2655 |
> |
assertEquals(0, r.invocationCount); |
2656 |
> |
checkCompletedNormally(f, v1); |
2657 |
> |
checkCompletedWithWrappedCancellationException(h); |
2658 |
> |
} |
2659 |
> |
} |
2660 |
> |
|
2661 |
> |
public void testRunAfterEither_sourceCancelled3() { |
2662 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2663 |
> |
for (boolean mayInterruptIfRunning : new boolean[] { true, false }) |
2664 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2665 |
> |
|
2666 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2667 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2668 |
> |
final Noop r = new Noop(); |
2669 |
> |
|
2670 |
> |
assertTrue(g.cancel(mayInterruptIfRunning)); |
2671 |
> |
f.complete(v1); |
2672 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2673 |
> |
|
2674 |
> |
// unspecified behavior |
2675 |
> |
Integer v; |
2676 |
> |
try { |
2677 |
> |
assertEquals(h.join(), null); |
2678 |
> |
assertEquals(1, r.invocationCount); |
2679 |
> |
} catch (CompletionException ok) { |
2680 |
> |
checkCompletedWithWrappedCancellationException(h); |
2681 |
> |
assertEquals(0, r.invocationCount); |
2682 |
> |
} |
2683 |
> |
|
2684 |
> |
checkCancelled(g); |
2685 |
> |
checkCompletedNormally(f, v1); |
2686 |
> |
} |
2687 |
> |
} |
2688 |
> |
|
2689 |
> |
public void testRunAfterEither_sourceCancelled4() { |
2690 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2691 |
> |
for (boolean mayInterruptIfRunning : new boolean[] { true, false }) |
2692 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2693 |
> |
|
2694 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2695 |
> |
final CompletableFuture<Integer> g = new CompletableFuture<>(); |
2696 |
> |
final Noop r = new Noop(); |
2697 |
> |
|
2698 |
> |
assertTrue(f.cancel(mayInterruptIfRunning)); |
2699 |
> |
g.complete(v1); |
2700 |
> |
final CompletableFuture<Void> h = m.runAfterEither(f, g, r); |
2701 |
> |
|
2702 |
> |
// unspecified behavior |
2703 |
> |
Integer v; |
2704 |
> |
try { |
2705 |
> |
assertEquals(h.join(), null); |
2706 |
> |
assertEquals(1, r.invocationCount); |
2707 |
> |
} catch (CompletionException ok) { |
2708 |
> |
checkCompletedWithWrappedCancellationException(h); |
2709 |
> |
assertEquals(0, r.invocationCount); |
2710 |
> |
} |
2711 |
> |
|
2712 |
> |
checkCancelled(f); |
2713 |
> |
checkCompletedNormally(g, v1); |
2714 |
> |
} |
2715 |
|
} |
2716 |
|
|
2717 |
|
/** |
2718 |
|
* thenCompose result completes normally after normal completion of source |
2719 |
|
*/ |
2720 |
< |
public void testThenCompose() { |
2721 |
< |
CompletableFuture<Integer> f, g; |
2722 |
< |
CompletableFutureInc r; |
2720 |
> |
public void testThenCompose_normalCompletion1() { |
2721 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2722 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2723 |
|
|
2724 |
< |
f = new CompletableFuture<>(); |
2725 |
< |
g = f.thenCompose(r = new CompletableFutureInc()); |
2726 |
< |
f.complete(one); |
2727 |
< |
checkCompletedNormally(g, two); |
2728 |
< |
assertTrue(r.ran); |
2724 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2725 |
> |
final CompletableFutureInc r = new CompletableFutureInc(); |
2726 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2727 |
> |
f.complete(v1); |
2728 |
> |
checkCompletedNormally(g, inc(v1)); |
2729 |
> |
checkCompletedNormally(f, v1); |
2730 |
> |
assertEquals(1, r.invocationCount); |
2731 |
> |
} |
2732 |
> |
} |
2733 |
|
|
2734 |
< |
f = new CompletableFuture<>(); |
2735 |
< |
f.complete(one); |
2736 |
< |
g = f.thenCompose(r = new CompletableFutureInc()); |
2737 |
< |
checkCompletedNormally(g, two); |
2738 |
< |
assertTrue(r.ran); |
2734 |
> |
public void testThenCompose_normalCompletion2() { |
2735 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2736 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2737 |
> |
|
2738 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2739 |
> |
final CompletableFutureInc r = new CompletableFutureInc(); |
2740 |
> |
f.complete(v1); |
2741 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2742 |
> |
checkCompletedNormally(g, inc(v1)); |
2743 |
> |
checkCompletedNormally(f, v1); |
2744 |
> |
assertEquals(1, r.invocationCount); |
2745 |
> |
} |
2746 |
|
} |
2747 |
|
|
2748 |
|
/** |
2749 |
|
* thenCompose result completes exceptionally after exceptional |
2750 |
|
* completion of source |
2751 |
|
*/ |
2752 |
< |
public void testThenCompose2() { |
2753 |
< |
CompletableFuture<Integer> f, g; |
2565 |
< |
CompletableFutureInc r; |
2752 |
> |
public void testThenCompose_exceptionalCompletion1() { |
2753 |
> |
for (ExecutionMode m : ExecutionMode.values()) { |
2754 |
|
|
2755 |
< |
f = new CompletableFuture<>(); |
2756 |
< |
g = f.thenCompose(r = new CompletableFutureInc()); |
2757 |
< |
f.completeExceptionally(new CFException()); |
2758 |
< |
checkCompletedWithWrappedCFException(g); |
2755 |
> |
final CFException ex = new CFException(); |
2756 |
> |
final CompletableFutureInc r = new CompletableFutureInc(); |
2757 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2758 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2759 |
> |
f.completeExceptionally(ex); |
2760 |
> |
checkCompletedWithWrappedCFException(g, ex); |
2761 |
> |
checkCompletedWithWrappedCFException(f, ex); |
2762 |
> |
} |
2763 |
> |
} |
2764 |
|
|
2765 |
< |
f = new CompletableFuture<>(); |
2766 |
< |
f.completeExceptionally(new CFException()); |
2767 |
< |
g = f.thenCompose(r = new CompletableFutureInc()); |
2768 |
< |
checkCompletedWithWrappedCFException(g); |
2765 |
> |
public void testThenCompose_exceptionalCompletion2() { |
2766 |
> |
for (ExecutionMode m : ExecutionMode.values()) { |
2767 |
> |
|
2768 |
> |
final CFException ex = new CFException(); |
2769 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2770 |
> |
f.completeExceptionally(ex); |
2771 |
> |
final CompletableFutureInc r = new CompletableFutureInc(); |
2772 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2773 |
> |
checkCompletedWithWrappedCFException(g, ex); |
2774 |
> |
checkCompletedWithWrappedCFException(f, ex); |
2775 |
> |
} |
2776 |
|
} |
2777 |
|
|
2778 |
|
/** |
2779 |
|
* thenCompose result completes exceptionally if action does |
2780 |
|
*/ |
2781 |
< |
public void testThenCompose3() { |
2782 |
< |
CompletableFuture<Integer> f, g; |
2783 |
< |
FailingCompletableFutureFunction r; |
2781 |
> |
public void testThenCompose_actionFailed1() { |
2782 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2783 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2784 |
|
|
2785 |
< |
f = new CompletableFuture<>(); |
2786 |
< |
g = f.thenCompose(r = new FailingCompletableFutureFunction()); |
2787 |
< |
f.complete(one); |
2785 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2786 |
> |
final FailingCompletableFutureFunction r |
2787 |
> |
= new FailingCompletableFutureFunction(); |
2788 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2789 |
> |
f.complete(v1); |
2790 |
|
checkCompletedWithWrappedCFException(g); |
2791 |
+ |
checkCompletedNormally(f, v1); |
2792 |
+ |
} |
2793 |
+ |
} |
2794 |
|
|
2795 |
< |
f = new CompletableFuture<>(); |
2796 |
< |
f.complete(one); |
2797 |
< |
g = f.thenCompose(r = new FailingCompletableFutureFunction()); |
2795 |
> |
public void testThenCompose_actionFailed2() { |
2796 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2797 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
2798 |
> |
|
2799 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2800 |
> |
f.complete(v1); |
2801 |
> |
final FailingCompletableFutureFunction r |
2802 |
> |
= new FailingCompletableFutureFunction(); |
2803 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2804 |
|
checkCompletedWithWrappedCFException(g); |
2805 |
+ |
checkCompletedNormally(f, v1); |
2806 |
+ |
} |
2807 |
|
} |
2808 |
|
|
2809 |
|
/** |
2810 |
|
* thenCompose result completes exceptionally if source cancelled |
2811 |
|
*/ |
2812 |
< |
public void testThenCompose4() { |
2813 |
< |
CompletableFuture<Integer> f, g; |
2814 |
< |
CompletableFutureInc r; |
2812 |
> |
public void testThenCompose_sourceCancelled1() { |
2813 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2814 |
> |
for (boolean mayInterruptIfRunning : new boolean[] { true, false }) { |
2815 |
|
|
2816 |
< |
f = new CompletableFuture<>(); |
2817 |
< |
g = f.thenCompose(r = new CompletableFutureInc()); |
2818 |
< |
assertTrue(f.cancel(true)); |
2816 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2817 |
> |
final CompletableFutureInc r = new CompletableFutureInc(); |
2818 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2819 |
> |
assertTrue(f.cancel(mayInterruptIfRunning)); |
2820 |
|
checkCompletedWithWrappedCancellationException(g); |
2821 |
+ |
checkCancelled(f); |
2822 |
+ |
} |
2823 |
+ |
} |
2824 |
|
|
2825 |
< |
f = new CompletableFuture<>(); |
2826 |
< |
assertTrue(f.cancel(true)); |
2827 |
< |
g = f.thenCompose(r = new CompletableFutureInc()); |
2825 |
> |
public void testThenCompose_sourceCancelled2() { |
2826 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
2827 |
> |
for (boolean mayInterruptIfRunning : new boolean[] { true, false }) { |
2828 |
> |
|
2829 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
2830 |
> |
assertTrue(f.cancel(mayInterruptIfRunning)); |
2831 |
> |
final CompletableFutureInc r = new CompletableFutureInc(); |
2832 |
> |
final CompletableFuture<Integer> g = f.thenCompose(r); |
2833 |
|
checkCompletedWithWrappedCancellationException(g); |
2834 |
+ |
checkCancelled(f); |
2835 |
+ |
} |
2836 |
|
} |
2837 |
|
|
2838 |
|
// asyncs |
2982 |
|
checkCompletedWithWrappedCancellationException(g); |
2983 |
|
} |
2984 |
|
|
2761 |
– |
/** |
2762 |
– |
* runAfterEitherAsync result completes normally after normal |
2763 |
– |
* completion of sources |
2764 |
– |
*/ |
2765 |
– |
public void testRunAfterEitherAsync() { |
2766 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2767 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2768 |
– |
Noop r = new Noop(); |
2769 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r); |
2770 |
– |
f.complete(one); |
2771 |
– |
checkCompletedNormally(g, null); |
2772 |
– |
assertTrue(r.ran); |
2773 |
– |
|
2774 |
– |
r = new Noop(); |
2775 |
– |
f = new CompletableFuture<>(); |
2776 |
– |
f.complete(one); |
2777 |
– |
f2 = new CompletableFuture<>(); |
2778 |
– |
g = f.runAfterEitherAsync(f2, r); |
2779 |
– |
checkCompletedNormally(g, null); |
2780 |
– |
assertTrue(r.ran); |
2781 |
– |
} |
2782 |
– |
|
2783 |
– |
/** |
2784 |
– |
* runAfterEitherAsync result completes exceptionally after exceptional |
2785 |
– |
* completion of source |
2786 |
– |
*/ |
2787 |
– |
public void testRunAfterEitherAsync2() { |
2788 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2789 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2790 |
– |
Noop r = new Noop(); |
2791 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r); |
2792 |
– |
f.completeExceptionally(new CFException()); |
2793 |
– |
checkCompletedWithWrappedCFException(g); |
2794 |
– |
|
2795 |
– |
r = new Noop(); |
2796 |
– |
f = new CompletableFuture<>(); |
2797 |
– |
f2 = new CompletableFuture<>(); |
2798 |
– |
f2.completeExceptionally(new CFException()); |
2799 |
– |
g = f.runAfterEitherAsync(f2, r); |
2800 |
– |
f.complete(one); |
2801 |
– |
checkCompletedWithWrappedCFException(g); |
2802 |
– |
} |
2803 |
– |
|
2804 |
– |
/** |
2805 |
– |
* runAfterEitherAsync result completes exceptionally if action does |
2806 |
– |
*/ |
2807 |
– |
public void testRunAfterEitherAsync3() { |
2808 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2809 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2810 |
– |
FailingNoop r = new FailingNoop(); |
2811 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r); |
2812 |
– |
f.complete(one); |
2813 |
– |
checkCompletedWithWrappedCFException(g); |
2814 |
– |
} |
2815 |
– |
|
2816 |
– |
/** |
2817 |
– |
* runAfterEitherAsync result completes exceptionally if either |
2818 |
– |
* source cancelled |
2819 |
– |
*/ |
2820 |
– |
public void testRunAfterEitherAsync4() { |
2821 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
2822 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
2823 |
– |
Noop r = new Noop(); |
2824 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r); |
2825 |
– |
assertTrue(f.cancel(true)); |
2826 |
– |
checkCompletedWithWrappedCancellationException(g); |
2827 |
– |
|
2828 |
– |
r = new Noop(); |
2829 |
– |
f = new CompletableFuture<>(); |
2830 |
– |
f2 = new CompletableFuture<>(); |
2831 |
– |
assertTrue(f2.cancel(true)); |
2832 |
– |
g = f.runAfterEitherAsync(f2, r); |
2833 |
– |
checkCompletedWithWrappedCancellationException(g); |
2834 |
– |
} |
2835 |
– |
|
2836 |
– |
/** |
2837 |
– |
* thenComposeAsync result completes normally after normal |
2838 |
– |
* completion of source |
2839 |
– |
*/ |
2840 |
– |
public void testThenComposeAsync() { |
2841 |
– |
CompletableFuture<Integer> f, g; |
2842 |
– |
CompletableFutureInc r; |
2843 |
– |
|
2844 |
– |
f = new CompletableFuture<>(); |
2845 |
– |
g = f.thenComposeAsync(r = new CompletableFutureInc()); |
2846 |
– |
f.complete(one); |
2847 |
– |
checkCompletedNormally(g, two); |
2848 |
– |
|
2849 |
– |
f = new CompletableFuture<>(); |
2850 |
– |
f.complete(one); |
2851 |
– |
g = f.thenComposeAsync(r = new CompletableFutureInc()); |
2852 |
– |
checkCompletedNormally(g, two); |
2853 |
– |
} |
2854 |
– |
|
2855 |
– |
/** |
2856 |
– |
* thenComposeAsync result completes exceptionally after |
2857 |
– |
* exceptional completion of source |
2858 |
– |
*/ |
2859 |
– |
public void testThenComposeAsync2() { |
2860 |
– |
CompletableFuture<Integer> f, g; |
2861 |
– |
CompletableFutureInc r; |
2862 |
– |
|
2863 |
– |
f = new CompletableFuture<>(); |
2864 |
– |
g = f.thenComposeAsync(r = new CompletableFutureInc()); |
2865 |
– |
f.completeExceptionally(new CFException()); |
2866 |
– |
checkCompletedWithWrappedCFException(g); |
2867 |
– |
assertFalse(r.ran); |
2868 |
– |
|
2869 |
– |
f = new CompletableFuture<>(); |
2870 |
– |
f.completeExceptionally(new CFException()); |
2871 |
– |
g = f.thenComposeAsync(r = new CompletableFutureInc()); |
2872 |
– |
checkCompletedWithWrappedCFException(g); |
2873 |
– |
assertFalse(r.ran); |
2874 |
– |
} |
2875 |
– |
|
2876 |
– |
/** |
2877 |
– |
* thenComposeAsync result completes exceptionally if action does |
2878 |
– |
*/ |
2879 |
– |
public void testThenComposeAsync3() { |
2880 |
– |
CompletableFuture<Integer> f, g; |
2881 |
– |
FailingCompletableFutureFunction r; |
2882 |
– |
|
2883 |
– |
f = new CompletableFuture<>(); |
2884 |
– |
g = f.thenComposeAsync(r = new FailingCompletableFutureFunction()); |
2885 |
– |
f.complete(one); |
2886 |
– |
checkCompletedWithWrappedCFException(g); |
2887 |
– |
|
2888 |
– |
f = new CompletableFuture<>(); |
2889 |
– |
f.complete(one); |
2890 |
– |
g = f.thenComposeAsync(r = new FailingCompletableFutureFunction()); |
2891 |
– |
checkCompletedWithWrappedCFException(g); |
2892 |
– |
} |
2893 |
– |
|
2894 |
– |
/** |
2895 |
– |
* thenComposeAsync result completes exceptionally if source cancelled |
2896 |
– |
*/ |
2897 |
– |
public void testThenComposeAsync4() { |
2898 |
– |
CompletableFuture<Integer> f, g; |
2899 |
– |
CompletableFutureInc r; |
2900 |
– |
|
2901 |
– |
f = new CompletableFuture<>(); |
2902 |
– |
g = f.thenComposeAsync(r = new CompletableFutureInc()); |
2903 |
– |
assertTrue(f.cancel(true)); |
2904 |
– |
checkCompletedWithWrappedCancellationException(g); |
2905 |
– |
|
2906 |
– |
f = new CompletableFuture<>(); |
2907 |
– |
assertTrue(f.cancel(true)); |
2908 |
– |
g = f.thenComposeAsync(r = new CompletableFutureInc()); |
2909 |
– |
checkCompletedWithWrappedCancellationException(g); |
2910 |
– |
} |
2911 |
– |
|
2985 |
|
// async with explicit executors |
2986 |
|
|
2987 |
|
/** |
3129 |
|
checkCompletedWithWrappedCancellationException(g); |
3130 |
|
} |
3131 |
|
|
3059 |
– |
/** |
3060 |
– |
* runAfterEitherAsync result completes normally after normal |
3061 |
– |
* completion of sources |
3062 |
– |
*/ |
3063 |
– |
public void testRunAfterEitherAsyncE() { |
3064 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3065 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
3066 |
– |
Noop r = new Noop(); |
3067 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3068 |
– |
f.complete(one); |
3069 |
– |
checkCompletedNormally(g, null); |
3070 |
– |
assertTrue(r.ran); |
3071 |
– |
|
3072 |
– |
r = new Noop(); |
3073 |
– |
f = new CompletableFuture<>(); |
3074 |
– |
f.complete(one); |
3075 |
– |
f2 = new CompletableFuture<>(); |
3076 |
– |
g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3077 |
– |
checkCompletedNormally(g, null); |
3078 |
– |
assertTrue(r.ran); |
3079 |
– |
} |
3080 |
– |
|
3081 |
– |
/** |
3082 |
– |
* runAfterEitherAsync result completes exceptionally after exceptional |
3083 |
– |
* completion of source |
3084 |
– |
*/ |
3085 |
– |
public void testRunAfterEitherAsync2E() { |
3086 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3087 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
3088 |
– |
Noop r = new Noop(); |
3089 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3090 |
– |
f.completeExceptionally(new CFException()); |
3091 |
– |
checkCompletedWithWrappedCFException(g); |
3092 |
– |
|
3093 |
– |
r = new Noop(); |
3094 |
– |
f = new CompletableFuture<>(); |
3095 |
– |
f2 = new CompletableFuture<>(); |
3096 |
– |
f2.completeExceptionally(new CFException()); |
3097 |
– |
g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3098 |
– |
f.complete(one); |
3099 |
– |
checkCompletedWithWrappedCFException(g); |
3100 |
– |
} |
3101 |
– |
|
3102 |
– |
/** |
3103 |
– |
* runAfterEitherAsync result completes exceptionally if action does |
3104 |
– |
*/ |
3105 |
– |
public void testRunAfterEitherAsync3E() { |
3106 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3107 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
3108 |
– |
FailingNoop r = new FailingNoop(); |
3109 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3110 |
– |
f.complete(one); |
3111 |
– |
checkCompletedWithWrappedCFException(g); |
3112 |
– |
} |
3113 |
– |
|
3114 |
– |
/** |
3115 |
– |
* runAfterEitherAsync result completes exceptionally if either |
3116 |
– |
* source cancelled |
3117 |
– |
*/ |
3118 |
– |
public void testRunAfterEitherAsync4E() { |
3119 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3120 |
– |
CompletableFuture<Integer> f2 = new CompletableFuture<>(); |
3121 |
– |
Noop r = new Noop(); |
3122 |
– |
CompletableFuture<Void> g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3123 |
– |
assertTrue(f.cancel(true)); |
3124 |
– |
checkCompletedWithWrappedCancellationException(g); |
3125 |
– |
|
3126 |
– |
r = new Noop(); |
3127 |
– |
f = new CompletableFuture<>(); |
3128 |
– |
f2 = new CompletableFuture<>(); |
3129 |
– |
assertTrue(f2.cancel(true)); |
3130 |
– |
g = f.runAfterEitherAsync(f2, r, new ThreadExecutor()); |
3131 |
– |
checkCompletedWithWrappedCancellationException(g); |
3132 |
– |
} |
3133 |
– |
|
3134 |
– |
/** |
3135 |
– |
* thenComposeAsync result completes normally after normal |
3136 |
– |
* completion of source |
3137 |
– |
*/ |
3138 |
– |
public void testThenComposeAsyncE() { |
3139 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3140 |
– |
CompletableFutureInc r = new CompletableFutureInc(); |
3141 |
– |
CompletableFuture<Integer> g = f.thenComposeAsync(r, new ThreadExecutor()); |
3142 |
– |
f.complete(one); |
3143 |
– |
checkCompletedNormally(g, two); |
3144 |
– |
} |
3145 |
– |
|
3146 |
– |
/** |
3147 |
– |
* thenComposeAsync result completes exceptionally after |
3148 |
– |
* exceptional completion of source |
3149 |
– |
*/ |
3150 |
– |
public void testThenComposeAsync2E() { |
3151 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3152 |
– |
CompletableFutureInc r = new CompletableFutureInc(); |
3153 |
– |
CompletableFuture<Integer> g = f.thenComposeAsync(r, new ThreadExecutor()); |
3154 |
– |
f.completeExceptionally(new CFException()); |
3155 |
– |
checkCompletedWithWrappedCFException(g); |
3156 |
– |
} |
3157 |
– |
|
3158 |
– |
/** |
3159 |
– |
* thenComposeAsync result completes exceptionally if action does |
3160 |
– |
*/ |
3161 |
– |
public void testThenComposeAsync3E() { |
3162 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3163 |
– |
FailingCompletableFutureFunction r = new FailingCompletableFutureFunction(); |
3164 |
– |
CompletableFuture<Integer> g = f.thenComposeAsync(r, new ThreadExecutor()); |
3165 |
– |
f.complete(one); |
3166 |
– |
checkCompletedWithWrappedCFException(g); |
3167 |
– |
} |
3168 |
– |
|
3169 |
– |
/** |
3170 |
– |
* thenComposeAsync result completes exceptionally if source cancelled |
3171 |
– |
*/ |
3172 |
– |
public void testThenComposeAsync4E() { |
3173 |
– |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3174 |
– |
CompletableFutureInc r = new CompletableFutureInc(); |
3175 |
– |
CompletableFuture<Integer> g = f.thenComposeAsync(r, new ThreadExecutor()); |
3176 |
– |
assertTrue(f.cancel(true)); |
3177 |
– |
checkCompletedWithWrappedCancellationException(g); |
3178 |
– |
} |
3179 |
– |
|
3132 |
|
// other static methods |
3133 |
|
|
3134 |
|
/** |
3327 |
|
* whenComplete action executes on normal completion, propagating |
3328 |
|
* source result. |
3329 |
|
*/ |
3330 |
< |
public void testWhenComplete1() { |
3330 |
> |
public void testWhenComplete_normalCompletion1() { |
3331 |
> |
for (boolean createIncomplete : new boolean[] { true, false }) |
3332 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
3333 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
3334 |
> |
|
3335 |
|
final AtomicInteger a = new AtomicInteger(); |
3336 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3337 |
< |
CompletableFuture<Integer> g = |
3338 |
< |
f.whenComplete((Integer x, Throwable t) -> a.getAndIncrement()); |
3339 |
< |
f.complete(three); |
3340 |
< |
checkCompletedNormally(f, three); |
3341 |
< |
checkCompletedNormally(g, three); |
3336 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
3337 |
> |
if (!createIncomplete) f.complete(v1); |
3338 |
> |
final CompletableFuture<Integer> g = |
3339 |
> |
m.whenComplete(f, |
3340 |
> |
(Integer x, Throwable t) -> { |
3341 |
> |
threadAssertSame(x, v1); |
3342 |
> |
threadAssertNull(t); |
3343 |
> |
a.getAndIncrement(); |
3344 |
> |
}); |
3345 |
> |
if (createIncomplete) f.complete(v1); |
3346 |
> |
checkCompletedNormally(f, v1); |
3347 |
> |
checkCompletedNormally(g, v1); |
3348 |
|
assertEquals(a.get(), 1); |
3349 |
+ |
} |
3350 |
|
} |
3351 |
|
|
3352 |
|
/** |
3353 |
|
* whenComplete action executes on exceptional completion, propagating |
3354 |
|
* source result. |
3355 |
|
*/ |
3356 |
< |
public void testWhenComplete2() { |
3356 |
> |
public void testWhenComplete_exceptionalCompletion() { |
3357 |
> |
for (boolean createIncomplete : new boolean[] { true, false }) |
3358 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
3359 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
3360 |
> |
|
3361 |
|
final AtomicInteger a = new AtomicInteger(); |
3362 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3363 |
< |
CompletableFuture<Integer> g = |
3364 |
< |
f.whenComplete((Integer x, Throwable t) -> a.getAndIncrement()); |
3365 |
< |
f.completeExceptionally(new CFException()); |
3366 |
< |
assertTrue(f.isCompletedExceptionally()); |
3367 |
< |
assertTrue(g.isCompletedExceptionally()); |
3362 |
> |
final CFException ex = new CFException(); |
3363 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
3364 |
> |
if (!createIncomplete) f.completeExceptionally(ex); |
3365 |
> |
final CompletableFuture<Integer> g = m.whenComplete |
3366 |
> |
(f, |
3367 |
> |
(Integer x, Throwable t) -> { |
3368 |
> |
threadAssertNull(x); |
3369 |
> |
threadAssertSame(t, ex); |
3370 |
> |
a.getAndIncrement(); |
3371 |
> |
}); |
3372 |
> |
if (createIncomplete) f.completeExceptionally(ex); |
3373 |
> |
checkCompletedWithWrappedCFException(f, ex); |
3374 |
> |
checkCompletedWithWrappedCFException(g, ex); |
3375 |
|
assertEquals(a.get(), 1); |
3376 |
+ |
} |
3377 |
|
} |
3378 |
|
|
3379 |
|
/** |
3380 |
|
* If a whenComplete action throws an exception when triggered by |
3381 |
|
* a normal completion, it completes exceptionally |
3382 |
|
*/ |
3383 |
< |
public void testWhenComplete3() { |
3384 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3385 |
< |
CompletableFuture<Integer> g = |
3386 |
< |
f.whenComplete((Integer x, Throwable t) -> |
3412 |
< |
{ throw new CFException(); } ); |
3413 |
< |
f.complete(three); |
3414 |
< |
checkCompletedNormally(f, three); |
3415 |
< |
assertTrue(g.isCompletedExceptionally()); |
3416 |
< |
checkCompletedWithWrappedCFException(g); |
3417 |
< |
} |
3418 |
< |
|
3419 |
< |
/** |
3420 |
< |
* whenCompleteAsync action executes on normal completion, propagating |
3421 |
< |
* source result. |
3422 |
< |
*/ |
3423 |
< |
public void testWhenCompleteAsync1() { |
3424 |
< |
final AtomicInteger a = new AtomicInteger(); |
3425 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3426 |
< |
CompletableFuture<Integer> g = |
3427 |
< |
f.whenCompleteAsync((Integer x, Throwable t) -> a.getAndIncrement()); |
3428 |
< |
f.complete(three); |
3429 |
< |
checkCompletedNormally(f, three); |
3430 |
< |
checkCompletedNormally(g, three); |
3431 |
< |
assertEquals(a.get(), 1); |
3432 |
< |
} |
3383 |
> |
public void testWhenComplete_actionFailed() { |
3384 |
> |
for (boolean createIncomplete : new boolean[] { true, false }) |
3385 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
3386 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
3387 |
|
|
3388 |
< |
/** |
3389 |
< |
* whenCompleteAsync action executes on exceptional completion, propagating |
3390 |
< |
* source result. |
3391 |
< |
*/ |
3392 |
< |
public void testWhenCompleteAsync2() { |
3393 |
< |
final AtomicInteger a = new AtomicInteger(); |
3394 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3395 |
< |
CompletableFuture<Integer> g = |
3396 |
< |
f.whenCompleteAsync((Integer x, Throwable t) -> a.getAndIncrement()); |
3397 |
< |
f.completeExceptionally(new CFException()); |
3398 |
< |
checkCompletedWithWrappedCFException(f); |
3399 |
< |
checkCompletedWithWrappedCFException(g); |
3388 |
> |
final CFException ex = new CFException(); |
3389 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
3390 |
> |
if (!createIncomplete) f.complete(v1); |
3391 |
> |
final CompletableFuture<Integer> g = m.whenComplete |
3392 |
> |
(f, |
3393 |
> |
(Integer x, Throwable t) -> { |
3394 |
> |
threadAssertSame(x, v1); |
3395 |
> |
threadAssertNull(t); |
3396 |
> |
throw ex; |
3397 |
> |
}); |
3398 |
> |
if (createIncomplete) f.complete(v1); |
3399 |
> |
checkCompletedNormally(f, v1); |
3400 |
> |
checkCompletedWithWrappedCFException(g, ex); |
3401 |
> |
} |
3402 |
|
} |
3403 |
|
|
3404 |
|
/** |
3405 |
< |
* If a whenCompleteAsync action throws an exception when |
3406 |
< |
* triggered by a normal completion, it completes exceptionally |
3405 |
> |
* If a whenComplete action throws an exception when triggered by |
3406 |
> |
* a source completion that also throws an exception, the source |
3407 |
> |
* exception takes precedence. |
3408 |
|
*/ |
3409 |
< |
public void testWhenCompleteAsync3() { |
3410 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3411 |
< |
CompletableFuture<Integer> g = |
3412 |
< |
f.whenCompleteAsync((Integer x, Throwable t) -> |
3456 |
< |
{ throw new CFException(); } ); |
3457 |
< |
f.complete(three); |
3458 |
< |
checkCompletedNormally(f, three); |
3459 |
< |
checkCompletedWithWrappedCFException(g); |
3460 |
< |
} |
3409 |
> |
public void testWhenComplete_actionFailedSourceFailed() { |
3410 |
> |
for (boolean createIncomplete : new boolean[] { true, false }) |
3411 |
> |
for (ExecutionMode m : ExecutionMode.values()) |
3412 |
> |
for (Integer v1 : new Integer[] { 1, null }) { |
3413 |
|
|
3414 |
< |
/** |
3415 |
< |
* whenCompleteAsync action executes on normal completion, propagating |
3416 |
< |
* source result. |
3465 |
< |
*/ |
3466 |
< |
public void testWhenCompleteAsync1e() { |
3467 |
< |
final AtomicInteger a = new AtomicInteger(); |
3468 |
< |
ThreadExecutor exec = new ThreadExecutor(); |
3469 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3470 |
< |
CompletableFuture<Integer> g = |
3471 |
< |
f.whenCompleteAsync((Integer x, Throwable t) -> a.getAndIncrement(), |
3472 |
< |
exec); |
3473 |
< |
f.complete(three); |
3474 |
< |
checkCompletedNormally(f, three); |
3475 |
< |
checkCompletedNormally(g, three); |
3476 |
< |
assertEquals(a.get(), 1); |
3477 |
< |
} |
3414 |
> |
final CFException ex1 = new CFException(); |
3415 |
> |
final CFException ex2 = new CFException(); |
3416 |
> |
final CompletableFuture<Integer> f = new CompletableFuture<>(); |
3417 |
|
|
3418 |
< |
/** |
3419 |
< |
* whenCompleteAsync action executes on exceptional completion, propagating |
3420 |
< |
* source result. |
3421 |
< |
*/ |
3422 |
< |
public void testWhenCompleteAsync2e() { |
3423 |
< |
final AtomicInteger a = new AtomicInteger(); |
3424 |
< |
ThreadExecutor exec = new ThreadExecutor(); |
3425 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3426 |
< |
CompletableFuture<Integer> g = |
3488 |
< |
f.whenCompleteAsync((Integer x, Throwable t) -> a.getAndIncrement(), |
3489 |
< |
exec); |
3490 |
< |
f.completeExceptionally(new CFException()); |
3491 |
< |
checkCompletedWithWrappedCFException(f); |
3492 |
< |
checkCompletedWithWrappedCFException(g); |
3493 |
< |
} |
3418 |
> |
if (!createIncomplete) f.completeExceptionally(ex1); |
3419 |
> |
final CompletableFuture<Integer> g = m.whenComplete |
3420 |
> |
(f, |
3421 |
> |
(Integer x, Throwable t) -> { |
3422 |
> |
threadAssertSame(t, ex1); |
3423 |
> |
threadAssertNull(x); |
3424 |
> |
throw ex2; |
3425 |
> |
}); |
3426 |
> |
if (createIncomplete) f.completeExceptionally(ex1); |
3427 |
|
|
3428 |
< |
/** |
3429 |
< |
* If a whenCompleteAsync action throws an exception when triggered |
3430 |
< |
* by a normal completion, it completes exceptionally |
3498 |
< |
*/ |
3499 |
< |
public void testWhenCompleteAsync3e() { |
3500 |
< |
ThreadExecutor exec = new ThreadExecutor(); |
3501 |
< |
CompletableFuture<Integer> f = new CompletableFuture<>(); |
3502 |
< |
CompletableFuture<Integer> g = |
3503 |
< |
f.whenCompleteAsync((Integer x, Throwable t) -> |
3504 |
< |
{ throw new CFException(); }, |
3505 |
< |
exec); |
3506 |
< |
f.complete(three); |
3507 |
< |
checkCompletedNormally(f, three); |
3508 |
< |
checkCompletedWithWrappedCFException(g); |
3428 |
> |
checkCompletedWithWrappedCFException(f, ex1); |
3429 |
> |
checkCompletedWithWrappedCFException(g, ex1); |
3430 |
> |
} |
3431 |
|
} |
3432 |
|
|
3433 |
|
/** |
3440 |
|
|
3441 |
|
f = new CompletableFuture<>(); |
3442 |
|
g = f.handleAsync(r = new IntegerHandler()); |
3443 |
< |
assertFalse(r.ran); |
3443 |
> |
assertEquals(0, r.invocationCount); |
3444 |
|
f.completeExceptionally(new CFException()); |
3445 |
|
checkCompletedWithWrappedCFException(f); |
3446 |
|
checkCompletedNormally(g, three); |
3447 |
< |
assertTrue(r.ran); |
3447 |
> |
assertEquals(1, r.invocationCount); |
3448 |
|
|
3449 |
|
f = new CompletableFuture<>(); |
3450 |
|
g = f.handleAsync(r = new IntegerHandler()); |
3451 |
< |
assertFalse(r.ran); |
3451 |
> |
assertEquals(0, r.invocationCount); |
3452 |
|
f.completeExceptionally(new CFException()); |
3453 |
|
checkCompletedWithWrappedCFException(f); |
3454 |
|
checkCompletedNormally(g, three); |
3455 |
< |
assertTrue(r.ran); |
3455 |
> |
assertEquals(1, r.invocationCount); |
3456 |
|
|
3457 |
|
f = new CompletableFuture<>(); |
3458 |
|
g = f.handleAsync(r = new IntegerHandler()); |
3459 |
< |
assertFalse(r.ran); |
3459 |
> |
assertEquals(0, r.invocationCount); |
3460 |
|
f.complete(one); |
3461 |
|
checkCompletedNormally(f, one); |
3462 |
|
checkCompletedNormally(g, two); |
3463 |
< |
assertTrue(r.ran); |
3463 |
> |
assertEquals(1, r.invocationCount); |
3464 |
|
|
3465 |
|
f = new CompletableFuture<>(); |
3466 |
|
g = f.handleAsync(r = new IntegerHandler()); |
3467 |
< |
assertFalse(r.ran); |
3467 |
> |
assertEquals(0, r.invocationCount); |
3468 |
|
f.complete(one); |
3469 |
|
checkCompletedNormally(f, one); |
3470 |
|
checkCompletedNormally(g, two); |
3471 |
< |
assertTrue(r.ran); |
3471 |
> |
assertEquals(1, r.invocationCount); |
3472 |
|
} |
3473 |
|
|
3474 |
|
/** |
3483 |
|
|
3484 |
|
f = new CompletableFuture<>(); |
3485 |
|
g = f.handleAsync(r = new IntegerHandler(), exec); |
3486 |
< |
assertFalse(r.ran); |
3486 |
> |
assertEquals(0, r.invocationCount); |
3487 |
|
f.completeExceptionally(new CFException()); |
3488 |
|
checkCompletedWithWrappedCFException(f); |
3489 |
|
checkCompletedNormally(g, three); |
3490 |
< |
assertTrue(r.ran); |
3490 |
> |
assertEquals(1, r.invocationCount); |
3491 |
|
|
3492 |
|
f = new CompletableFuture<>(); |
3493 |
|
g = f.handleAsync(r = new IntegerHandler(), exec); |
3494 |
< |
assertFalse(r.ran); |
3494 |
> |
assertEquals(0, r.invocationCount); |
3495 |
|
f.completeExceptionally(new CFException()); |
3496 |
|
checkCompletedWithWrappedCFException(f); |
3497 |
|
checkCompletedNormally(g, three); |
3498 |
< |
assertTrue(r.ran); |
3498 |
> |
assertEquals(1, r.invocationCount); |
3499 |
|
|
3500 |
|
f = new CompletableFuture<>(); |
3501 |
|
g = f.handleAsync(r = new IntegerHandler(), exec); |
3502 |
< |
assertFalse(r.ran); |
3502 |
> |
assertEquals(0, r.invocationCount); |
3503 |
|
f.complete(one); |
3504 |
|
checkCompletedNormally(f, one); |
3505 |
|
checkCompletedNormally(g, two); |
3506 |
< |
assertTrue(r.ran); |
3506 |
> |
assertEquals(1, r.invocationCount); |
3507 |
|
|
3508 |
|
f = new CompletableFuture<>(); |
3509 |
|
g = f.handleAsync(r = new IntegerHandler(), exec); |
3510 |
< |
assertFalse(r.ran); |
3510 |
> |
assertEquals(0, r.invocationCount); |
3511 |
|
f.complete(one); |
3512 |
|
checkCompletedNormally(f, one); |
3513 |
|
checkCompletedNormally(g, two); |
3514 |
< |
assertTrue(r.ran); |
3514 |
> |
assertEquals(1, r.invocationCount); |
3515 |
|
} |
3516 |
|
|
3517 |
|
} |