/** * Equivalent to {@code andThen("andThen", consumer)}. * @see #andThen(String, Consumer8) */ default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> andThen(final Consumer8<T1, T2, T3, T4, T5, T6, T7, T8> consumer) { return cast(andThen("andThen: " + _taskDescriptor.getDescription(consumer.getClass().getName()), tuple -> consumer.accept(tuple._1(), tuple._2(), tuple._3(), tuple._4(), tuple._5(), tuple._6(), tuple._7(), tuple._8()))); }
/** * Equivalent to {@code flatMap("flatMap", f)}. * @see #flatMap(String, Function8) */ default <R> Task<R> flatMap(final Function8<T1, T2, T3, T4, T5, T6, T7, T8, Task<R>> f) { return flatMap("flatMap: " + _taskDescriptor.getDescription(f.getClass().getName()), tuple -> f.apply(tuple._1(), tuple._2(), tuple._3(), tuple._4(), tuple._5(), tuple._6(), tuple._7(), tuple._8())); }
/** * Equivalent to {@code map("map", f)}. * @see #map(String, Function8) */ default <R> Task<R> map(final Function8<T1, T2, T3, T4, T5, T6, T7, T8, R> f) { return map("map: " + _taskDescriptor.getDescription(f.getClass().getName()), tuple -> f.apply(tuple._1(), tuple._2(), tuple._3(), tuple._4(), tuple._5(), tuple._6(), tuple._7(), tuple._8())); }
/** * {@inheritDoc} */ @Override default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> recover(final String desc, final Function1<Throwable, Tuple8<T1, T2, T3, T4, T5, T6, T7, T8>> f) { return cast(Task.super.recover(desc, f)); }
@Test public void testPar8AndThenDsc() { AtomicInteger value = new AtomicInteger(); Task<?> task = Task.par(Task.value(1), Task.value(2), Task.value(3), Task.value(4), Task.value(5), Task.value(6), Task.value(7), Task.value(8)) .andThen("test", (a, b, c, d, e, f, g, h) -> value.set(a + b + c + d + e + f + g + h)); runAndWait("TestTaskFactoryMethods.testPar8AndThenDsc", task); assertEquals(value.get(), 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8); assertEquals(countTasks(task.getTrace()), 2 + 1 + 8); }
/** * {@inheritDoc} */ @Override default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> recoverWith(final String desc, final Function1<Throwable, Task<Tuple8<T1, T2, T3, T4, T5, T6, T7, T8>>> f) { return cast(Task.super.recoverWith(desc, f)); }
@Test public void testPar8AndThen() { AtomicInteger value = new AtomicInteger(); Task<?> task = Task.par(Task.value(1), Task.value(2), Task.value(3), Task.value(4), Task.value(5), Task.value(6), Task.value(7), Task.value(8)) .andThen((a, b, c, d, e, f, g, h) -> value.set(a + b + c + d + e + f + g + h)); runAndWait("TestTaskFactoryMethods.testPar8AndThen", task); assertEquals(value.get(), 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8); assertEquals(countTasks(task.getTrace()), 2 + 1 + 8); }
/** * {@inheritDoc} */ @Override public default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> onFailure(final Consumer1<Throwable> consumer) { return cast(Task.super.onFailure(consumer)); };
return flatMap(desc, tuple -> f.apply(tuple._1(), tuple._2(), tuple._3(), tuple._4(), tuple._5(), tuple._6(), tuple._7(), tuple._8()));
@Test public void testPar8() { Task<Integer> task = Task.par(Task.value(1), Task.value(2), Task.value(3), Task.value(4), Task.value(5), Task.value(6), Task.value(7), Task.value(8)) .map((a, b, c, d, e, f, g, h) -> a + b + c + d + e + f + g + h); runAndWait("TestTaskFactoryMethods.testPar8", task); assertEquals((int)task.get(), 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8); assertEquals(countTasks(task.getTrace()), 2 + 1 + 8); }
/** * Equivalent to {@code andThen("andThen", consumer)}. * @see #andThen(String, Consumer8) */ default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> andThen(final Consumer8<T1, T2, T3, T4, T5, T6, T7, T8> consumer) { return cast(andThen("andThen: " + _taskDescriptor.getDescription(consumer.getClass().getName()), tuple -> consumer.accept(tuple._1(), tuple._2(), tuple._3(), tuple._4(), tuple._5(), tuple._6(), tuple._7(), tuple._8()))); }
/** * {@inheritDoc} */ @Override default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> recoverWith(final Function1<Throwable, Task<Tuple8<T1, T2, T3, T4, T5, T6, T7, T8>>> f) { return cast(Task.super.recoverWith(f)); }
@Test public void testPar8FlatMap() { Task<Integer> task = Task.par(Task.value(1), Task.value(2), Task.value(3), Task.value(4), Task.value(5), Task.value(6), Task.value(7), Task.value(8)) .flatMap((a, b, c, d, e, f, g, h) -> Task.value(a + b + c + d + e + f + g + h)); runAndWait("TestTaskFactoryMethods.testPar8FlatMap", task); assertEquals((int)task.get(), 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8); assertEquals(countTasks(task.getTrace()), 2 + 3 + 8); }
@Test public void testPar8Dsc() { Task<Integer> task = Task.par(Task.value(1), Task.value(2), Task.value(3), Task.value(4), Task.value(5), Task.value(6), Task.value(7), Task.value(8)) .map("test", (a, b, c, d, e, f, g, h) -> a + b + c + d + e + f + g + h); runAndWait("TestTaskFactoryMethods.testPar8Dsc", task); assertEquals((int)task.get(), 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8); assertEquals(countTasks(task.getTrace()), 2 + 1 + 8); }
/** * {@inheritDoc} */ @Override default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> recover(final Function1<Throwable, Tuple8<T1, T2, T3, T4, T5, T6, T7, T8>> f) { return cast(Task.super.recover(f)); }
@Test public void testPar8FlatMapDsc() { Task<Integer> task = Task.par(Task.value(1), Task.value(2), Task.value(3), Task.value(4), Task.value(5), Task.value(6), Task.value(7), Task.value(8)) .flatMap("test", (a, b, c, d, e, f, g, h) -> Task.value(a + b + c + d + e + f + g + h)); runAndWait("TestTaskFactoryMethods.testPar8FlatMapDsc", task); assertEquals((int)task.get(), 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8); assertEquals(countTasks(task.getTrace()), 2 + 3 + 8); }
return map(desc, tuple -> f.apply(tuple._1(), tuple._2(), tuple._3(), tuple._4(), tuple._5(), tuple._6(), tuple._7(), tuple._8()));
/** * {@inheritDoc} */ @Override public default Tuple8Task<T1, T2, T3, T4, T5, T6, T7, T8> onFailure(final String desc, final Consumer1<Throwable> consumer) { return cast(Task.super.onFailure(desc, consumer)); };