From 484a6c0f01128bfb8c8e667bfa5f4ff8961e3eca Mon Sep 17 00:00:00 2001 From: Jian He Date: Mon, 29 Jun 2015 14:31:32 -0700 Subject: [PATCH] YARN-3770. SerializedException should also handle java.lang.Error on de-serialization. Contributed by Lavkesh Lahngir (cherry picked from commit 4672315e2d6abe1cee0210cf7d3e8ab114ba933c) --- hadoop-yarn-project/CHANGES.txt | 3 +++ .../records/impl/pb/SerializedExceptionPBImpl.java | 2 +- .../impl/pb/TestSerializedExceptionPBImpl.java | 12 ++++++++++-- 3 files changed, 14 insertions(+), 3 deletions(-) diff --git a/hadoop-yarn-project/CHANGES.txt b/hadoop-yarn-project/CHANGES.txt index 05be3780f15..9b0f23880a7 100644 --- a/hadoop-yarn-project/CHANGES.txt +++ b/hadoop-yarn-project/CHANGES.txt @@ -523,6 +523,9 @@ Release 2.8.0 - UNRELEASED YARN-3695. ServerProxy (NMProxy, etc.) shouldn't retry forever for non network exception. (Raju Bairishetti via jianhe) + YARN-3770. SerializedException should also handle java.lang.Error on + de-serialization. (Lavkesh Lahngir via jianhe) + Release 2.7.2 - UNRELEASED INCOMPATIBLE CHANGES diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/api/records/impl/pb/SerializedExceptionPBImpl.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/api/records/impl/pb/SerializedExceptionPBImpl.java index fd9e170dcdc..2ec232ee930 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/api/records/impl/pb/SerializedExceptionPBImpl.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/api/records/impl/pb/SerializedExceptionPBImpl.java @@ -101,7 +101,7 @@ public class SerializedExceptionPBImpl extends SerializedException { } else if (RuntimeException.class.isAssignableFrom(realClass)) { classType = RuntimeException.class; } else { - classType = Exception.class; + classType = Throwable.class; } return instantiateException(realClass.asSubclass(classType), getMessage(), cause == null ? null : cause.deSerialize()); diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/test/java/org/apache/hadoop/yarn/api/records/impl/pb/TestSerializedExceptionPBImpl.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/test/java/org/apache/hadoop/yarn/api/records/impl/pb/TestSerializedExceptionPBImpl.java index ac7e40ebb42..ecfa63e0329 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/test/java/org/apache/hadoop/yarn/api/records/impl/pb/TestSerializedExceptionPBImpl.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/test/java/org/apache/hadoop/yarn/api/records/impl/pb/TestSerializedExceptionPBImpl.java @@ -20,10 +20,9 @@ package org.apache.hadoop.yarn.api.records.impl.pb; import java.nio.channels.ClosedChannelException; -import org.junit.Assert; -import org.apache.hadoop.yarn.api.records.impl.pb.SerializedExceptionPBImpl; import org.apache.hadoop.yarn.exceptions.YarnRuntimeException; import org.apache.hadoop.yarn.proto.YarnProtos.SerializedExceptionProto; +import org.junit.Assert; import org.junit.Test; public class TestSerializedExceptionPBImpl { @@ -79,4 +78,13 @@ public class TestSerializedExceptionPBImpl { SerializedExceptionPBImpl pb3 = new SerializedExceptionPBImpl(); Assert.assertEquals(defaultProto.getTrace(), pb3.getRemoteTrace()); } + + @Test + public void testThrowableDeserialization() { + // java.lang.Error should also be serializable + Error ex = new Error(); + SerializedExceptionPBImpl pb = new SerializedExceptionPBImpl(); + pb.init(ex); + Assert.assertEquals(ex.getClass(), pb.deSerialize().getClass()); + } }