From e8a47a920f791677c9553c2a3b41cf4f36ea8d34 Mon Sep 17 00:00:00 2001 From: Martin Polden Date: Mon, 28 Oct 2024 12:52:59 +0100 Subject: [PATCH] Include the last exception thrown as cause of the timeout exception --- .../com/yahoo/vespa/config/server/TimeoutBudget.java | 11 ++++++++--- .../yahoo/vespa/config/server/deploy/Deployment.java | 8 ++++---- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/configserver/src/main/java/com/yahoo/vespa/config/server/TimeoutBudget.java b/configserver/src/main/java/com/yahoo/vespa/config/server/TimeoutBudget.java index 24eb18ff7ea5..af15545f9251 100644 --- a/configserver/src/main/java/com/yahoo/vespa/config/server/TimeoutBudget.java +++ b/configserver/src/main/java/com/yahoo/vespa/config/server/TimeoutBudget.java @@ -69,12 +69,17 @@ public String timesUsed() { } /** - * @param exceptionMessage exception message for the exception that will be thrown if there is no time left + * @param message exception message for the exception that will be thrown if there is no time left + * @param cause the last exception thrown while waiting for the operation to complete * @throws UncheckedTimeoutException if this has no time left */ - public void assertNotTimedOut(Supplier exceptionMessage) { + public void assertNotTimedOut(Supplier message, Exception cause) { if (hasTimeLeft()) return; - throw new UncheckedTimeoutException(exceptionMessage.get()); + throw new UncheckedTimeoutException(message.get(), cause); + } + + public void assertNotTimedOut(Supplier message) { + assertNotTimedOut(message, null); } private static class Measurement { diff --git a/configserver/src/main/java/com/yahoo/vespa/config/server/deploy/Deployment.java b/configserver/src/main/java/com/yahoo/vespa/config/server/deploy/Deployment.java index a9b3780bc870..aec6fd8f1fe5 100644 --- a/configserver/src/main/java/com/yahoo/vespa/config/server/deploy/Deployment.java +++ b/configserver/src/main/java/com/yahoo/vespa/config/server/deploy/Deployment.java @@ -7,10 +7,10 @@ import com.yahoo.config.provision.ActivationContext; import com.yahoo.config.provision.ApplicationId; import com.yahoo.config.provision.ApplicationLockException; +import com.yahoo.config.provision.ApplicationMutex; import com.yahoo.config.provision.ApplicationTransaction; import com.yahoo.config.provision.HostFilter; import com.yahoo.config.provision.HostSpec; -import com.yahoo.config.provision.ApplicationMutex; import com.yahoo.config.provision.Provisioner; import com.yahoo.config.provision.TransientException; import com.yahoo.transaction.NestedTransaction; @@ -26,6 +26,7 @@ import com.yahoo.vespa.config.server.session.Session; import com.yahoo.vespa.config.server.session.SessionRepository; import com.yahoo.vespa.config.server.tenant.Tenant; +import com.yahoo.yolean.Exceptions; import com.yahoo.yolean.concurrent.Memoized; import java.time.Clock; @@ -38,7 +39,6 @@ import java.util.logging.Level; import java.util.logging.Logger; -import static com.yahoo.vespa.config.server.application.ConfigConvergenceChecker.ServiceListResponse; import static com.yahoo.vespa.config.server.session.Session.Status.DELETE; import static java.util.stream.Collectors.groupingBy; import static java.util.stream.Collectors.joining; @@ -275,8 +275,8 @@ private static void waitForResourcesOrTimeout(PrepareParams params, Session sess while (true) { params.getTimeoutBudget().assertNotTimedOut( () -> "Timeout exceeded while waiting for application resources of '" + session.getApplicationId() + "'" + - Optional.ofNullable(lastException.get()).map(e -> ". Last exception: " + e.getMessage()).orElse("")); - + Optional.ofNullable(lastException.get()).map(e -> ". Last exception: " + Exceptions.toMessageString(e)).orElse(""), + lastException.get()); try (ApplicationMutex lock = provisioner.get().lock(session.getApplicationId())) { // Call to activate to make sure that everything is ready, but do not commit the transaction ApplicationTransaction transaction = new ApplicationTransaction(lock, new NestedTransaction());