From 6cd6a27d4480eff91258ef8258b5af1901acde65 Mon Sep 17 00:00:00 2001 From: Brentley Jones Date: Tue, 8 Mar 2022 12:38:09 -0600 Subject: [PATCH] Remote: Fix crashes with InterruptedException when using http cache. (#14999) Also cancels tasks submitted during `afterCommand` if interrupted. Fixes #14787. Closes #14992. PiperOrigin-RevId: 433205726 (cherry picked from commit a73aa12be65454ac8cfb5a8f3e056c420402f997) Co-authored-by: Chi Wang --- .../build/lib/remote/http/HttpCacheClient.java | 18 +++++++++++++++++- .../build/lib/runtime/BlockWaitingModule.java | 1 + 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/src/main/java/com/google/devtools/build/lib/remote/http/HttpCacheClient.java b/src/main/java/com/google/devtools/build/lib/remote/http/HttpCacheClient.java index 3cbf6cf47ff836..21b471e9636dfa 100644 --- a/src/main/java/com/google/devtools/build/lib/remote/http/HttpCacheClient.java +++ b/src/main/java/com/google/devtools/build/lib/remote/http/HttpCacheClient.java @@ -733,7 +733,23 @@ public void close() { } isClosed = true; - channelPool.close(); + + // Clear interrupted status to prevent failure to close, indicated with #14787 + boolean wasInterrupted = Thread.interrupted(); + try { + channelPool.close(); + } catch (RuntimeException e) { + if (e.getCause() instanceof InterruptedException) { + Thread.currentThread().interrupt(); + } else { + throw e; + } + } finally { + if (wasInterrupted) { + Thread.currentThread().interrupt(); + } + } + eventLoop.shutdownGracefully(); } } diff --git a/src/main/java/com/google/devtools/build/lib/runtime/BlockWaitingModule.java b/src/main/java/com/google/devtools/build/lib/runtime/BlockWaitingModule.java index 6d5b74a8f51e88..408cf73886c2cf 100644 --- a/src/main/java/com/google/devtools/build/lib/runtime/BlockWaitingModule.java +++ b/src/main/java/com/google/devtools/build/lib/runtime/BlockWaitingModule.java @@ -51,6 +51,7 @@ public void afterCommand() throws AbruptExitException { try { executorService.awaitTermination(Long.MAX_VALUE, SECONDS); } catch (InterruptedException e) { + executorService.shutdownNow(); Thread.currentThread().interrupt(); }