HADOOP-12772. NetworkTopologyWithNodeGroup.getNodeGroup() can loop infinitely for invalid 'loc' values. Contributed by Kuhu Shukla.
(cherry picked from commit 49e176c29f
)
This commit is contained in:
parent
86760c0f52
commit
51a705432c
|
@ -1079,6 +1079,9 @@ Release 2.7.3 - UNRELEASED
|
||||||
|
|
||||||
HADOOP-12761. incremental maven build is not really incremental (sjlee)
|
HADOOP-12761. incremental maven build is not really incremental (sjlee)
|
||||||
|
|
||||||
|
HADOOP-12772. NetworkTopologyWithNodeGroup.getNodeGroup() can loop
|
||||||
|
infinitely for invalid 'loc' values (Kuhu Shukla via kihwal)
|
||||||
|
|
||||||
Release 2.7.2 - 2016-01-25
|
Release 2.7.2 - 2016-01-25
|
||||||
|
|
||||||
INCOMPATIBLE CHANGES
|
INCOMPATIBLE CHANGES
|
||||||
|
|
|
@ -101,7 +101,12 @@ public class NetworkTopologyWithNodeGroup extends NetworkTopology {
|
||||||
return null;
|
return null;
|
||||||
} else {
|
} else {
|
||||||
// may be a leaf node
|
// may be a leaf node
|
||||||
return getNodeGroup(node.getNetworkLocation());
|
if(!(node.getNetworkLocation() == null ||
|
||||||
|
node.getNetworkLocation().isEmpty())) {
|
||||||
|
return getNodeGroup(node.getNetworkLocation());
|
||||||
|
} else {
|
||||||
|
return NodeBase.ROOT;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// not in cluster map, don't handle it
|
// not in cluster map, don't handle it
|
||||||
|
|
|
@ -127,7 +127,14 @@ public class NodeBase implements Node {
|
||||||
* is not {@link #PATH_SEPARATOR}
|
* is not {@link #PATH_SEPARATOR}
|
||||||
*/
|
*/
|
||||||
public static String normalize(String path) {
|
public static String normalize(String path) {
|
||||||
if (path == null || path.length() == 0) return ROOT;
|
if (path == null) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"Network Location is null ");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (path.length() == 0) {
|
||||||
|
return ROOT;
|
||||||
|
}
|
||||||
|
|
||||||
if (path.charAt(0) != PATH_SEPARATOR) {
|
if (path.charAt(0) != PATH_SEPARATOR) {
|
||||||
throw new IllegalArgumentException(
|
throw new IllegalArgumentException(
|
||||||
|
|
|
@ -178,7 +178,20 @@ public class TestNetworkTopologyWithNodeGroup {
|
||||||
assertTrue(frequency.get(key) > 0 || key == dataNodes[0]);
|
assertTrue(frequency.get(key) > 0 || key == dataNodes[0]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNodeGroup() throws Exception {
|
||||||
|
String res = cluster.getNodeGroup("");
|
||||||
|
assertTrue("NodeGroup should be NodeBase.ROOT for empty location",
|
||||||
|
res.equals(NodeBase.ROOT));
|
||||||
|
try {
|
||||||
|
cluster.getNodeGroup(null);
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
assertTrue("Null Network Location should throw exception!",
|
||||||
|
e.getMessage().contains("Network Location is null"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This test checks that adding a node with invalid topology will be failed
|
* This test checks that adding a node with invalid topology will be failed
|
||||||
* with an exception to show topology is invalid.
|
* with an exception to show topology is invalid.
|
||||||
|
|
Loading…
Reference in New Issue