[NO ISSUE][OTH] Catch All Interrupts on Request Cancellation
- user model changes: no
- storage format changes: no
- interface changes: no
Details:
- Catch all exceptions that could be caused by an interrupt
during request cancellation.
Change-Id: Ib2595ce8a80d8df324e5d97591639d3f9efe1b9d
Reviewed-on: https://asterix-gerrit.ics.uci.edu/3250
Sonar-Qube: Jenkins <jenkins@fulliautomatix.ics.uci.edu>
Integration-Tests: Jenkins <jenkins@fulliautomatix.ics.uci.edu>
Tested-by: Jenkins <jenkins@fulliautomatix.ics.uci.edu>
Contrib: Jenkins <jenkins@fulliautomatix.ics.uci.edu>
Reviewed-by: Michael Blow <mblow@apache.org>
diff --git a/asterixdb/asterix-app/src/main/java/org/apache/asterix/app/translator/QueryTranslator.java b/asterixdb/asterix-app/src/main/java/org/apache/asterix/app/translator/QueryTranslator.java
index c49fcdd..0996c6c 100644
--- a/asterixdb/asterix-app/src/main/java/org/apache/asterix/app/translator/QueryTranslator.java
+++ b/asterixdb/asterix-app/src/main/java/org/apache/asterix/app/translator/QueryTranslator.java
@@ -66,6 +66,7 @@
import org.apache.asterix.common.exceptions.AsterixException;
import org.apache.asterix.common.exceptions.CompilationException;
import org.apache.asterix.common.exceptions.ErrorCode;
+import org.apache.asterix.common.exceptions.ExceptionUtils;
import org.apache.asterix.common.exceptions.MetadataException;
import org.apache.asterix.common.exceptions.RuntimeDataException;
import org.apache.asterix.common.functions.FunctionSignature;
@@ -2624,9 +2625,12 @@
hcc.waitForCompletion(jobId);
printer.print(jobId);
}
- } catch (InterruptedException e) {
- Thread.currentThread().interrupt();
- throw new RuntimeDataException(ErrorCode.REQUEST_CANCELLED, clientRequest.getId());
+ } catch (Exception e) {
+ if (ExceptionUtils.getRootCause(e) instanceof InterruptedException) {
+ Thread.currentThread().interrupt();
+ throw new RuntimeDataException(ErrorCode.REQUEST_CANCELLED, clientRequest.getId());
+ }
+ throw e;
} finally {
// complete async jobs after their job completes
if (ResultDelivery.ASYNC == resultDelivery) {