YARN-3157. Refactor the exception handling in ConverterUtils#to*Id. Contributed by Bibin A Chundatt.

This commit is contained in:
Tsuyoshi Ozawa 2015-02-12 23:48:43 +09:00
parent ac8d52bf50
commit 7bc492adab
4 changed files with 30 additions and 0 deletions

View File

@ -269,6 +269,9 @@ Release 2.7.0 - UNRELEASED
YARN-1237. Description for yarn.nodemanager.aux-services in YARN-1237. Description for yarn.nodemanager.aux-services in
yarn-default.xml is misleading. (Brahma Reddy Battula via ozawa) yarn-default.xml is misleading. (Brahma Reddy Battula via ozawa)
YARN-3157. Refactor the exception handling in ConverterUtils#to*Id.
(Bibin A Chundatt via ozawa)
OPTIMIZATIONS OPTIMIZATIONS
YARN-2990. FairScheduler's delay-scheduling always waits for node-local and YARN-2990. FairScheduler's delay-scheduling always waits for node-local and

View File

@ -22,6 +22,8 @@ import com.google.common.base.Splitter;
import java.text.NumberFormat; import java.text.NumberFormat;
import java.util.Iterator; import java.util.Iterator;
import java.util.NoSuchElementException;
import org.apache.hadoop.classification.InterfaceAudience.Private; import org.apache.hadoop.classification.InterfaceAudience.Private;
import org.apache.hadoop.classification.InterfaceAudience.Public; import org.apache.hadoop.classification.InterfaceAudience.Public;
import org.apache.hadoop.classification.InterfaceStability.Stable; import org.apache.hadoop.classification.InterfaceStability.Stable;
@ -231,6 +233,9 @@ public abstract class ContainerId implements Comparable<ContainerId>{
} catch (NumberFormatException n) { } catch (NumberFormatException n) {
throw new IllegalArgumentException("Invalid ContainerId: " throw new IllegalArgumentException("Invalid ContainerId: "
+ containerIdStr, n); + containerIdStr, n);
} catch (NoSuchElementException e) {
throw new IllegalArgumentException("Invalid ContainerId: "
+ containerIdStr, e);
} }
} }

View File

@ -27,6 +27,7 @@ import java.util.HashMap;
import java.util.Iterator; import java.util.Iterator;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
import java.util.NoSuchElementException;
import org.apache.hadoop.classification.InterfaceAudience.Private; import org.apache.hadoop.classification.InterfaceAudience.Private;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
@ -190,6 +191,9 @@ public class ConverterUtils {
} catch (NumberFormatException n) { } catch (NumberFormatException n) {
throw new IllegalArgumentException("Invalid AppAttemptId: " throw new IllegalArgumentException("Invalid AppAttemptId: "
+ applicationAttmeptIdStr, n); + applicationAttmeptIdStr, n);
} catch (NoSuchElementException e) {
throw new IllegalArgumentException("Invalid AppAttemptId: "
+ applicationAttmeptIdStr, e);
} }
} }
@ -206,6 +210,9 @@ public class ConverterUtils {
} catch (NumberFormatException n) { } catch (NumberFormatException n) {
throw new IllegalArgumentException("Invalid ApplicationId: " throw new IllegalArgumentException("Invalid ApplicationId: "
+ appIdStr, n); + appIdStr, n);
} catch (NoSuchElementException e) {
throw new IllegalArgumentException("Invalid ApplicationId: "
+ appIdStr, e);
} }
} }

View File

@ -99,4 +99,19 @@ public class TestConverterUtils {
assertEquals(nid.getPort(), 0); assertEquals(nid.getPort(), 0);
assertEquals(nid.getHost(), "node"); assertEquals(nid.getHost(), "node");
} }
@Test(expected = IllegalArgumentException.class)
public void testInvalidContainerId() {
ConverterUtils.toContainerId("container_e20_1423221031460_0003_01");
}
@Test(expected = IllegalArgumentException.class)
public void testInvalidAppattemptId() {
ConverterUtils.toApplicationAttemptId("appattempt_1423221031460");
}
@Test(expected = IllegalArgumentException.class)
public void testApplicationId() {
ConverterUtils.toApplicationId("application_1423221031460");
}
} }