From 25f2447fb2b336f5c966267c0f2fe202ef0e0cee Mon Sep 17 00:00:00 2001 From: Kashif Faraz Date: Mon, 30 Sep 2024 20:36:56 +0530 Subject: [PATCH] Add test for exceptions in FutureUtils.transformAsync. (#17106) (#17197) Adds an additional test case to FutureUtilsTest. Co-authored-by: Gian Merlino --- .../druid/common/guava/FutureUtilsTest.java | 26 +++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/processing/src/test/java/org/apache/druid/common/guava/FutureUtilsTest.java b/processing/src/test/java/org/apache/druid/common/guava/FutureUtilsTest.java index 52be34e78f9..9c261c7935f 100644 --- a/processing/src/test/java/org/apache/druid/common/guava/FutureUtilsTest.java +++ b/processing/src/test/java/org/apache/druid/common/guava/FutureUtilsTest.java @@ -243,6 +243,32 @@ public class FutureUtilsTest ); } + @Test + public void test_transformAsync_exceptionInFunction() + { + final ListenableFuture f = FutureUtils.transformAsync( + Futures.immediateFuture("x"), + s -> { + throw new ISE("error!"); + } + ); + + final ExecutionException e = Assert.assertThrows( + ExecutionException.class, + f::get + ); + + MatcherAssert.assertThat( + e, + ThrowableCauseMatcher.hasCause(CoreMatchers.instanceOf(ISE.class)) + ); + + MatcherAssert.assertThat( + e, + ThrowableCauseMatcher.hasCause(ThrowableMessageMatcher.hasMessage(CoreMatchers.containsString("error!"))) + ); + } + @Test public void test_coalesce_allOk() throws Exception {