YARN-11388: Prevent resource leaks in TestClientRMService. (#5187)
Signed-off-by: Shilun Fan <slfan1989@apache.org>
(cherry picked from commit 6b67373d10
)
This commit is contained in:
parent
290dc7817c
commit
1f270d8a5e
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
package org.apache.hadoop.yarn.server.resourcemanager;
|
package org.apache.hadoop.yarn.server.resourcemanager;
|
||||||
|
|
||||||
|
import static java.nio.charset.StandardCharsets.UTF_8;
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
@ -59,9 +60,11 @@
|
|||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
import org.apache.hadoop.fs.FileUtil;
|
||||||
import org.apache.hadoop.ipc.Server;
|
import org.apache.hadoop.ipc.Server;
|
||||||
import org.apache.hadoop.metrics2.lib.DefaultMetricsSystem;
|
import org.apache.hadoop.metrics2.lib.DefaultMetricsSystem;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
|
import org.apache.hadoop.test.GenericTestUtils;
|
||||||
import org.apache.hadoop.yarn.MockApps;
|
import org.apache.hadoop.yarn.MockApps;
|
||||||
import org.apache.hadoop.yarn.api.ApplicationClientProtocol;
|
import org.apache.hadoop.yarn.api.ApplicationClientProtocol;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ApplicationsRequestScope;
|
import org.apache.hadoop.yarn.api.protocolrecords.ApplicationsRequestScope;
|
||||||
@ -202,12 +205,17 @@ public class TestClientRMService {
|
|||||||
.getRecordFactory(null);
|
.getRecordFactory(null);
|
||||||
|
|
||||||
private String appType = "MockApp";
|
private String appType = "MockApp";
|
||||||
|
|
||||||
private final static String QUEUE_1 = "Q-1";
|
private final static String QUEUE_1 = "Q-1";
|
||||||
private final static String QUEUE_2 = "Q-2";
|
private final static String QUEUE_2 = "Q-2";
|
||||||
private final static String APPLICATION_TAG_SC_PREPROCESSOR ="mytag:foo";
|
private final static String APPLICATION_TAG_SC_PREPROCESSOR ="mytag:foo";
|
||||||
private File resourceTypesFile = null;
|
private File resourceTypesFile = null;
|
||||||
|
|
||||||
|
private Configuration conf;
|
||||||
|
private ResourceManager resourceManager;
|
||||||
|
private YarnRPC rpc;
|
||||||
|
private ApplicationClientProtocol client;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetDecommissioningClusterNodes() throws Exception {
|
public void testGetDecommissioningClusterNodes() throws Exception {
|
||||||
MockRM rm = new MockRM() {
|
MockRM rm = new MockRM() {
|
||||||
@ -218,6 +226,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
int nodeMemory = 1024;
|
int nodeMemory = 1024;
|
||||||
@ -230,13 +239,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
rm.waitForState(nm1.getNodeId(), NodeState.DECOMMISSIONING);
|
rm.waitForState(nm1.getNodeId(), NodeState.DECOMMISSIONING);
|
||||||
|
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client =
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
(ApplicationClientProtocol) rpc
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
|
||||||
|
|
||||||
// Make call
|
// Make call
|
||||||
List<NodeReport> nodeReports = client.getClusterNodes(
|
List<NodeReport> nodeReports = client.getClusterNodes(
|
||||||
@ -247,9 +255,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
NodeReport nr = nodeReports.iterator().next();
|
NodeReport nr = nodeReports.iterator().next();
|
||||||
Assert.assertEquals(decommissioningTimeout, nr.getDecommissioningTimeout());
|
Assert.assertEquals(decommissioningTimeout, nr.getDecommissioningTimeout());
|
||||||
Assert.assertNull(nr.getNodeUpdateType());
|
Assert.assertNull(nr.getNodeUpdateType());
|
||||||
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -261,6 +266,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
RMNodeLabelsManager labelsMgr = rm.getRMContext().getNodeLabelManager();
|
RMNodeLabelsManager labelsMgr = rm.getRMContext().getNodeLabelManager();
|
||||||
labelsMgr.addToCluserNodeLabelsWithDefaultExclusivity(ImmutableSet.of("x", "y"));
|
labelsMgr.addToCluserNodeLabelsWithDefaultExclusivity(ImmutableSet.of("x", "y"));
|
||||||
@ -272,7 +278,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
labelsMgr.replaceLabelsOnNode(map);
|
labelsMgr.replaceLabelsOnNode(map);
|
||||||
rm.sendNodeStarted(node);
|
rm.sendNodeStarted(node);
|
||||||
node.nodeHeartbeat(true);
|
node.nodeHeartbeat(true);
|
||||||
|
|
||||||
// Add and lose a node with label = y
|
// Add and lose a node with label = y
|
||||||
MockNM lostNode = rm.registerNode("host2:1235", 1024);
|
MockNM lostNode = rm.registerNode("host2:1235", 1024);
|
||||||
rm.sendNodeStarted(lostNode);
|
rm.sendNodeStarted(lostNode);
|
||||||
@ -281,13 +287,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
rm.sendNodeLost(lostNode);
|
rm.sendNodeLost(lostNode);
|
||||||
|
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client =
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
(ApplicationClientProtocol) rpc
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
|
||||||
|
|
||||||
// Make call
|
// Make call
|
||||||
GetClusterNodesRequest request =
|
GetClusterNodesRequest request =
|
||||||
@ -297,7 +302,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
Assert.assertEquals(1, nodeReports.size());
|
Assert.assertEquals(1, nodeReports.size());
|
||||||
Assert.assertNotSame("Node is expected to be healthy!", NodeState.UNHEALTHY,
|
Assert.assertNotSame("Node is expected to be healthy!", NodeState.UNHEALTHY,
|
||||||
nodeReports.get(0).getNodeState());
|
nodeReports.get(0).getNodeState());
|
||||||
|
|
||||||
// Check node's label = x
|
// Check node's label = x
|
||||||
Assert.assertTrue(nodeReports.get(0).getNodeLabels().contains("x"));
|
Assert.assertTrue(nodeReports.get(0).getNodeLabels().contains("x"));
|
||||||
Assert.assertNull(nodeReports.get(0).getDecommissioningTimeout());
|
Assert.assertNull(nodeReports.get(0).getDecommissioningTimeout());
|
||||||
@ -311,34 +316,34 @@ protected ClientRMService createClientRMService() {
|
|||||||
nodeReports = client.getClusterNodes(request).getNodeReports();
|
nodeReports = client.getClusterNodes(request).getNodeReports();
|
||||||
Assert.assertEquals("Unhealthy nodes should not show up by default", 0,
|
Assert.assertEquals("Unhealthy nodes should not show up by default", 0,
|
||||||
nodeReports.size());
|
nodeReports.size());
|
||||||
|
|
||||||
// Change label of host1 to y
|
// Change label of host1 to y
|
||||||
map = new HashMap<NodeId, Set<String>>();
|
map = new HashMap<NodeId, Set<String>>();
|
||||||
map.put(node.getNodeId(), ImmutableSet.of("y"));
|
map.put(node.getNodeId(), ImmutableSet.of("y"));
|
||||||
labelsMgr.replaceLabelsOnNode(map);
|
labelsMgr.replaceLabelsOnNode(map);
|
||||||
|
|
||||||
// Now query for UNHEALTHY nodes
|
// Now query for UNHEALTHY nodes
|
||||||
request = GetClusterNodesRequest.newInstance(EnumSet.of(NodeState.UNHEALTHY));
|
request = GetClusterNodesRequest.newInstance(EnumSet.of(NodeState.UNHEALTHY));
|
||||||
nodeReports = client.getClusterNodes(request).getNodeReports();
|
nodeReports = client.getClusterNodes(request).getNodeReports();
|
||||||
Assert.assertEquals(1, nodeReports.size());
|
Assert.assertEquals(1, nodeReports.size());
|
||||||
Assert.assertEquals("Node is expected to be unhealthy!", NodeState.UNHEALTHY,
|
Assert.assertEquals("Node is expected to be unhealthy!", NodeState.UNHEALTHY,
|
||||||
nodeReports.get(0).getNodeState());
|
nodeReports.get(0).getNodeState());
|
||||||
|
|
||||||
Assert.assertTrue(nodeReports.get(0).getNodeLabels().contains("y"));
|
Assert.assertTrue(nodeReports.get(0).getNodeLabels().contains("y"));
|
||||||
Assert.assertNull(nodeReports.get(0).getDecommissioningTimeout());
|
Assert.assertNull(nodeReports.get(0).getDecommissioningTimeout());
|
||||||
Assert.assertNull(nodeReports.get(0).getNodeUpdateType());
|
Assert.assertNull(nodeReports.get(0).getNodeUpdateType());
|
||||||
|
|
||||||
// Remove labels of host1
|
// Remove labels of host1
|
||||||
map = new HashMap<NodeId, Set<String>>();
|
map = new HashMap<NodeId, Set<String>>();
|
||||||
map.put(node.getNodeId(), ImmutableSet.of("y"));
|
map.put(node.getNodeId(), ImmutableSet.of("y"));
|
||||||
labelsMgr.removeLabelsFromNode(map);
|
labelsMgr.removeLabelsFromNode(map);
|
||||||
|
|
||||||
// Query all states should return all nodes
|
// Query all states should return all nodes
|
||||||
rm.registerNode("host3:1236", 1024);
|
rm.registerNode("host3:1236", 1024);
|
||||||
request = GetClusterNodesRequest.newInstance(EnumSet.allOf(NodeState.class));
|
request = GetClusterNodesRequest.newInstance(EnumSet.allOf(NodeState.class));
|
||||||
nodeReports = client.getClusterNodes(request).getNodeReports();
|
nodeReports = client.getClusterNodes(request).getNodeReports();
|
||||||
Assert.assertEquals(3, nodeReports.size());
|
Assert.assertEquals(3, nodeReports.size());
|
||||||
|
|
||||||
// All host1-3's label should be empty (instead of null)
|
// All host1-3's label should be empty (instead of null)
|
||||||
for (NodeReport report : nodeReports) {
|
for (NodeReport report : nodeReports) {
|
||||||
Assert.assertTrue(report.getNodeLabels() != null
|
Assert.assertTrue(report.getNodeLabels() != null
|
||||||
@ -346,11 +351,8 @@ protected ClientRMService createClientRMService() {
|
|||||||
Assert.assertNull(report.getDecommissioningTimeout());
|
Assert.assertNull(report.getDecommissioningTimeout());
|
||||||
Assert.assertNull(report.getNodeUpdateType());
|
Assert.assertNull(report.getNodeUpdateType());
|
||||||
}
|
}
|
||||||
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNonExistingApplicationReport() throws YarnException {
|
public void testNonExistingApplicationReport() throws YarnException {
|
||||||
RMContext rmContext = mock(RMContext.class);
|
RMContext rmContext = mock(RMContext.class);
|
||||||
@ -358,7 +360,6 @@ public void testNonExistingApplicationReport() throws YarnException {
|
|||||||
new ConcurrentHashMap<ApplicationId, RMApp>());
|
new ConcurrentHashMap<ApplicationId, RMApp>());
|
||||||
ClientRMService rmService = new ClientRMService(rmContext, null, null,
|
ClientRMService rmService = new ClientRMService(rmContext, null, null,
|
||||||
null, null, null);
|
null, null, null);
|
||||||
RecordFactory recordFactory = RecordFactoryProvider.getRecordFactory(null);
|
|
||||||
GetApplicationReportRequest request = recordFactory
|
GetApplicationReportRequest request = recordFactory
|
||||||
.newRecordInstance(GetApplicationReportRequest.class);
|
.newRecordInstance(GetApplicationReportRequest.class);
|
||||||
request.setApplicationId(ApplicationId.newInstance(0, 0));
|
request.setApplicationId(ApplicationId.newInstance(0, 0));
|
||||||
@ -373,7 +374,7 @@ public void testNonExistingApplicationReport() throws YarnException {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetApplicationReport() throws Exception {
|
public void testGetApplicationReport() throws Exception {
|
||||||
ResourceScheduler scheduler = mock(ResourceScheduler.class);
|
ResourceScheduler scheduler = mock(ResourceScheduler.class);
|
||||||
RMContext rmContext = mock(RMContext.class);
|
RMContext rmContext = mock(RMContext.class);
|
||||||
@ -389,14 +390,13 @@ public void testGetApplicationReport() throws Exception {
|
|||||||
ClientRMService rmService = new ClientRMService(rmContext, scheduler,
|
ClientRMService rmService = new ClientRMService(rmContext, scheduler,
|
||||||
null, mockAclsManager, null, null);
|
null, mockAclsManager, null, null);
|
||||||
try {
|
try {
|
||||||
RecordFactory recordFactory = RecordFactoryProvider.getRecordFactory(null);
|
|
||||||
GetApplicationReportRequest request = recordFactory
|
GetApplicationReportRequest request = recordFactory
|
||||||
.newRecordInstance(GetApplicationReportRequest.class);
|
.newRecordInstance(GetApplicationReportRequest.class);
|
||||||
request.setApplicationId(appId1);
|
request.setApplicationId(appId1);
|
||||||
GetApplicationReportResponse response =
|
GetApplicationReportResponse response =
|
||||||
rmService.getApplicationReport(request);
|
rmService.getApplicationReport(request);
|
||||||
ApplicationReport report = response.getApplicationReport();
|
ApplicationReport report = response.getApplicationReport();
|
||||||
ApplicationResourceUsageReport usageReport =
|
ApplicationResourceUsageReport usageReport =
|
||||||
report.getApplicationResourceUsageReport();
|
report.getApplicationResourceUsageReport();
|
||||||
Assert.assertEquals(10, usageReport.getMemorySeconds());
|
Assert.assertEquals(10, usageReport.getMemorySeconds());
|
||||||
Assert.assertEquals(3, usageReport.getVcoreSeconds());
|
Assert.assertEquals(3, usageReport.getVcoreSeconds());
|
||||||
@ -443,12 +443,11 @@ public void testGetApplicationReport() throws Exception {
|
|||||||
rmService.close();
|
rmService.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetApplicationAttemptReport() throws YarnException,
|
public void testGetApplicationAttemptReport() throws YarnException,
|
||||||
IOException {
|
IOException {
|
||||||
ClientRMService rmService = createRMService();
|
ClientRMService rmService = createRMService();
|
||||||
RecordFactory recordFactory = RecordFactoryProvider.getRecordFactory(null);
|
|
||||||
GetApplicationAttemptReportRequest request = recordFactory
|
GetApplicationAttemptReportRequest request = recordFactory
|
||||||
.newRecordInstance(GetApplicationAttemptReportRequest.class);
|
.newRecordInstance(GetApplicationAttemptReportRequest.class);
|
||||||
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
||||||
@ -477,7 +476,7 @@ public void testGetApplicationResourceUsageReportDummy() throws YarnException,
|
|||||||
public void handle(Event event) {
|
public void handle(Event event) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
ApplicationSubmissionContext asContext =
|
ApplicationSubmissionContext asContext =
|
||||||
mock(ApplicationSubmissionContext.class);
|
mock(ApplicationSubmissionContext.class);
|
||||||
YarnConfiguration config = new YarnConfiguration();
|
YarnConfiguration config = new YarnConfiguration();
|
||||||
RMAppAttemptImpl rmAppAttemptImpl = new RMAppAttemptImpl(attemptId,
|
RMAppAttemptImpl rmAppAttemptImpl = new RMAppAttemptImpl(attemptId,
|
||||||
@ -490,7 +489,6 @@ public void handle(Event event) {
|
|||||||
@Test
|
@Test
|
||||||
public void testGetApplicationAttempts() throws YarnException, IOException {
|
public void testGetApplicationAttempts() throws YarnException, IOException {
|
||||||
ClientRMService rmService = createRMService();
|
ClientRMService rmService = createRMService();
|
||||||
RecordFactory recordFactory = RecordFactoryProvider.getRecordFactory(null);
|
|
||||||
GetApplicationAttemptsRequest request = recordFactory
|
GetApplicationAttemptsRequest request = recordFactory
|
||||||
.newRecordInstance(GetApplicationAttemptsRequest.class);
|
.newRecordInstance(GetApplicationAttemptsRequest.class);
|
||||||
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
||||||
@ -512,7 +510,6 @@ public void testGetApplicationAttempts() throws YarnException, IOException {
|
|||||||
@Test
|
@Test
|
||||||
public void testGetContainerReport() throws YarnException, IOException {
|
public void testGetContainerReport() throws YarnException, IOException {
|
||||||
ClientRMService rmService = createRMService();
|
ClientRMService rmService = createRMService();
|
||||||
RecordFactory recordFactory = RecordFactoryProvider.getRecordFactory(null);
|
|
||||||
GetContainerReportRequest request = recordFactory
|
GetContainerReportRequest request = recordFactory
|
||||||
.newRecordInstance(GetContainerReportRequest.class);
|
.newRecordInstance(GetContainerReportRequest.class);
|
||||||
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
||||||
@ -533,7 +530,6 @@ public void testGetContainerReport() throws YarnException, IOException {
|
|||||||
@Test
|
@Test
|
||||||
public void testGetContainers() throws YarnException, IOException {
|
public void testGetContainers() throws YarnException, IOException {
|
||||||
ClientRMService rmService = createRMService();
|
ClientRMService rmService = createRMService();
|
||||||
RecordFactory recordFactory = RecordFactoryProvider.getRecordFactory(null);
|
|
||||||
GetContainersRequest request = recordFactory
|
GetContainersRequest request = recordFactory
|
||||||
.newRecordInstance(GetContainersRequest.class);
|
.newRecordInstance(GetContainersRequest.class);
|
||||||
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
ApplicationAttemptId attemptId = ApplicationAttemptId.newInstance(
|
||||||
@ -598,12 +594,13 @@ public void testForceKillNonExistingApplication() throws YarnException {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testApplicationTagsValidation() throws IOException {
|
public void testApplicationTagsValidation() throws IOException {
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
conf = new YarnConfiguration();
|
||||||
int maxtags = 3, appMaxTagLength = 5;
|
int maxtags = 3, appMaxTagLength = 5;
|
||||||
conf.setInt(YarnConfiguration.RM_APPLICATION_MAX_TAGS, maxtags);
|
conf.setInt(YarnConfiguration.RM_APPLICATION_MAX_TAGS, maxtags);
|
||||||
conf.setInt(YarnConfiguration.RM_APPLICATION_MAX_TAG_LENGTH,
|
conf.setInt(YarnConfiguration.RM_APPLICATION_MAX_TAG_LENGTH,
|
||||||
appMaxTagLength);
|
appMaxTagLength);
|
||||||
MockRM rm = new MockRM(conf);
|
MockRM rm = new MockRM(conf);
|
||||||
|
resourceManager = rm;
|
||||||
rm.init(conf);
|
rm.init(conf);
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
@ -625,7 +622,6 @@ public void testApplicationTagsValidation() throws IOException {
|
|||||||
tags = Arrays.asList("tãg1", "tag2#");
|
tags = Arrays.asList("tãg1", "tag2#");
|
||||||
validateApplicationTag(rmService, tags,
|
validateApplicationTag(rmService, tags,
|
||||||
"A tag can only have ASCII characters! Invalid tag - tãg1");
|
"A tag can only have ASCII characters! Invalid tag - tãg1");
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void validateApplicationTag(ClientRMService rmService,
|
private void validateApplicationTag(ClientRMService rmService,
|
||||||
@ -643,9 +639,10 @@ private void validateApplicationTag(ClientRMService rmService,
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testForceKillApplication() throws Exception {
|
public void testForceKillApplication() throws Exception {
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
conf = new YarnConfiguration();
|
||||||
conf.setBoolean(MockRM.ENABLE_WEBAPP, true);
|
conf.setBoolean(MockRM.ENABLE_WEBAPP, true);
|
||||||
MockRM rm = new MockRM(conf);
|
MockRM rm = new MockRM(conf);
|
||||||
|
resourceManager = rm;
|
||||||
rm.init(conf);
|
rm.init(conf);
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
@ -701,7 +698,7 @@ public void testForceKillApplication() throws Exception {
|
|||||||
assertEquals("Incorrect number of apps in the RM", 2,
|
assertEquals("Incorrect number of apps in the RM", 2,
|
||||||
rmService.getApplications(getRequest).getApplicationList().size());
|
rmService.getApplications(getRequest).getApplicationList().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test (expected = ApplicationNotFoundException.class)
|
@Test (expected = ApplicationNotFoundException.class)
|
||||||
public void testMoveAbsentApplication() throws YarnException {
|
public void testMoveAbsentApplication() throws YarnException {
|
||||||
RMContext rmContext = mock(RMContext.class);
|
RMContext rmContext = mock(RMContext.class);
|
||||||
@ -1205,7 +1202,7 @@ private void setupCurrentCall(String hostName) throws UnknownHostException {
|
|||||||
new byte[]{123, 123, 123, 123}));
|
new byte[]{123, 123, 123, 123}));
|
||||||
Server.getCurCall().set(mockCall);
|
Server.getCurCall().set(mockCall);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test (timeout = 30000)
|
@Test (timeout = 30000)
|
||||||
@SuppressWarnings ("rawtypes")
|
@SuppressWarnings ("rawtypes")
|
||||||
public void testAppSubmit() throws Exception {
|
public void testAppSubmit() throws Exception {
|
||||||
@ -1353,7 +1350,7 @@ public void handle(Event event) {}
|
|||||||
ApplicationId[] appIds =
|
ApplicationId[] appIds =
|
||||||
{getApplicationId(101), getApplicationId(102), getApplicationId(103)};
|
{getApplicationId(101), getApplicationId(102), getApplicationId(103)};
|
||||||
List<String> tags = Arrays.asList("Tag1", "Tag2", "Tag3");
|
List<String> tags = Arrays.asList("Tag1", "Tag2", "Tag3");
|
||||||
|
|
||||||
long[] submitTimeMillis = new long[3];
|
long[] submitTimeMillis = new long[3];
|
||||||
// Submit applications
|
// Submit applications
|
||||||
for (int i = 0; i < appIds.length; i++) {
|
for (int i = 0; i < appIds.length; i++) {
|
||||||
@ -1380,23 +1377,23 @@ public void handle(Event event) {}
|
|||||||
request.setLimit(1L);
|
request.setLimit(1L);
|
||||||
assertEquals("Failed to limit applications", 1,
|
assertEquals("Failed to limit applications", 1,
|
||||||
rmService.getApplications(request).getApplicationList().size());
|
rmService.getApplications(request).getApplicationList().size());
|
||||||
|
|
||||||
// Check start range
|
// Check start range
|
||||||
request = GetApplicationsRequest.newInstance();
|
request = GetApplicationsRequest.newInstance();
|
||||||
request.setStartRange(submitTimeMillis[0] + 1, System.currentTimeMillis());
|
request.setStartRange(submitTimeMillis[0] + 1, System.currentTimeMillis());
|
||||||
|
|
||||||
// 2 applications are submitted after first timeMills
|
// 2 applications are submitted after first timeMills
|
||||||
assertEquals("Incorrect number of matching start range",
|
assertEquals("Incorrect number of matching start range",
|
||||||
2, rmService.getApplications(request).getApplicationList().size());
|
2, rmService.getApplications(request).getApplicationList().size());
|
||||||
|
|
||||||
// 1 application is submitted after the second timeMills
|
// 1 application is submitted after the second timeMills
|
||||||
request.setStartRange(submitTimeMillis[1] + 1, System.currentTimeMillis());
|
request.setStartRange(submitTimeMillis[1] + 1, System.currentTimeMillis());
|
||||||
assertEquals("Incorrect number of matching start range",
|
assertEquals("Incorrect number of matching start range",
|
||||||
1, rmService.getApplications(request).getApplicationList().size());
|
1, rmService.getApplications(request).getApplicationList().size());
|
||||||
|
|
||||||
// no application is submitted after the third timeMills
|
// no application is submitted after the third timeMills
|
||||||
request.setStartRange(submitTimeMillis[2] + 1, System.currentTimeMillis());
|
request.setStartRange(submitTimeMillis[2] + 1, System.currentTimeMillis());
|
||||||
assertEquals("Incorrect number of matching start range",
|
assertEquals("Incorrect number of matching start range",
|
||||||
0, rmService.getApplications(request).getApplicationList().size());
|
0, rmService.getApplications(request).getApplicationList().size());
|
||||||
|
|
||||||
// Check queue
|
// Check queue
|
||||||
@ -1468,7 +1465,7 @@ public void handle(Event event) {}
|
|||||||
assertEquals("Incorrect number of applications for the scope", 3,
|
assertEquals("Incorrect number of applications for the scope", 3,
|
||||||
rmService.getApplications(request).getApplicationList().size());
|
rmService.getApplications(request).getApplicationList().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout=4000)
|
@Test(timeout=4000)
|
||||||
public void testConcurrentAppSubmit()
|
public void testConcurrentAppSubmit()
|
||||||
throws IOException, InterruptedException, BrokenBarrierException,
|
throws IOException, InterruptedException, BrokenBarrierException,
|
||||||
@ -1487,7 +1484,7 @@ public void testConcurrentAppSubmit()
|
|||||||
appId1, null, null);
|
appId1, null, null);
|
||||||
final SubmitApplicationRequest submitRequest2 = mockSubmitAppRequest(
|
final SubmitApplicationRequest submitRequest2 = mockSubmitAppRequest(
|
||||||
appId2, null, null);
|
appId2, null, null);
|
||||||
|
|
||||||
final CyclicBarrier startBarrier = new CyclicBarrier(2);
|
final CyclicBarrier startBarrier = new CyclicBarrier(2);
|
||||||
final CyclicBarrier endBarrier = new CyclicBarrier(2);
|
final CyclicBarrier endBarrier = new CyclicBarrier(2);
|
||||||
|
|
||||||
@ -1529,7 +1526,7 @@ public void run() {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
t.start();
|
t.start();
|
||||||
|
|
||||||
// submit another app, so go through while the first app is blocked
|
// submit another app, so go through while the first app is blocked
|
||||||
startBarrier.await();
|
startBarrier.await();
|
||||||
rmService.submitApplication(submitRequest2);
|
rmService.submitApplication(submitRequest2);
|
||||||
@ -1615,21 +1612,21 @@ private void mockRMContext(ResourceScheduler scheduler, RMContext rmContext)
|
|||||||
|
|
||||||
private ConcurrentHashMap<ApplicationId, RMApp> getRMApps(
|
private ConcurrentHashMap<ApplicationId, RMApp> getRMApps(
|
||||||
RMContext rmContext, YarnScheduler yarnScheduler) {
|
RMContext rmContext, YarnScheduler yarnScheduler) {
|
||||||
ConcurrentHashMap<ApplicationId, RMApp> apps =
|
ConcurrentHashMap<ApplicationId, RMApp> apps =
|
||||||
new ConcurrentHashMap<ApplicationId, RMApp>();
|
new ConcurrentHashMap<ApplicationId, RMApp>();
|
||||||
ApplicationId applicationId1 = getApplicationId(1);
|
ApplicationId applicationId1 = getApplicationId(1);
|
||||||
ApplicationId applicationId2 = getApplicationId(2);
|
ApplicationId applicationId2 = getApplicationId(2);
|
||||||
ApplicationId applicationId3 = getApplicationId(3);
|
ApplicationId applicationId3 = getApplicationId(3);
|
||||||
YarnConfiguration config = new YarnConfiguration();
|
YarnConfiguration config = new YarnConfiguration();
|
||||||
apps.put(applicationId1, getRMApp(rmContext, yarnScheduler, applicationId1,
|
apps.put(applicationId1, getRMApp(rmContext, yarnScheduler, applicationId1,
|
||||||
config, "testqueue", 10, 3,null,null));
|
config, "testqueue", 10, 3, null, null));
|
||||||
apps.put(applicationId2, getRMApp(rmContext, yarnScheduler, applicationId2,
|
apps.put(applicationId2, getRMApp(rmContext, yarnScheduler, applicationId2,
|
||||||
config, "a", 20, 2,null,""));
|
config, "a", 20, 2, null, ""));
|
||||||
apps.put(applicationId3, getRMApp(rmContext, yarnScheduler, applicationId3,
|
apps.put(applicationId3, getRMApp(rmContext, yarnScheduler, applicationId3,
|
||||||
config, "testqueue", 40, 5,"high-mem","high-mem"));
|
config, "testqueue", 40, 5, "high-mem", "high-mem"));
|
||||||
return apps;
|
return apps;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<ApplicationAttemptId> getSchedulerApps(
|
private List<ApplicationAttemptId> getSchedulerApps(
|
||||||
Map<ApplicationId, RMApp> apps) {
|
Map<ApplicationId, RMApp> apps) {
|
||||||
List<ApplicationAttemptId> schedApps = new ArrayList<ApplicationAttemptId>();
|
List<ApplicationAttemptId> schedApps = new ArrayList<ApplicationAttemptId>();
|
||||||
@ -1642,7 +1639,7 @@ private List<ApplicationAttemptId> getSchedulerApps(
|
|||||||
private static ApplicationId getApplicationId(int id) {
|
private static ApplicationId getApplicationId(int id) {
|
||||||
return ApplicationId.newInstance(123456, id);
|
return ApplicationId.newInstance(123456, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ApplicationAttemptId getApplicationAttemptId(int id) {
|
private static ApplicationAttemptId getApplicationAttemptId(int id) {
|
||||||
return ApplicationAttemptId.newInstance(getApplicationId(id), 1);
|
return ApplicationAttemptId.newInstance(getApplicationId(id), 1);
|
||||||
}
|
}
|
||||||
@ -1667,7 +1664,7 @@ public ApplicationReport createAndGetApplicationReport(
|
|||||||
String clientUserName, boolean allowAccess) {
|
String clientUserName, boolean allowAccess) {
|
||||||
ApplicationReport report = super.createAndGetApplicationReport(
|
ApplicationReport report = super.createAndGetApplicationReport(
|
||||||
clientUserName, allowAccess);
|
clientUserName, allowAccess);
|
||||||
ApplicationResourceUsageReport usageReport =
|
ApplicationResourceUsageReport usageReport =
|
||||||
report.getApplicationResourceUsageReport();
|
report.getApplicationResourceUsageReport();
|
||||||
usageReport.setMemorySeconds(memorySeconds);
|
usageReport.setMemorySeconds(memorySeconds);
|
||||||
usageReport.setVcoreSeconds(vcoreSeconds);
|
usageReport.setVcoreSeconds(vcoreSeconds);
|
||||||
@ -1687,8 +1684,7 @@ public ApplicationReport createAndGetApplicationReport(
|
|||||||
RMContainerImpl containerimpl = spy(new RMContainerImpl(container,
|
RMContainerImpl containerimpl = spy(new RMContainerImpl(container,
|
||||||
SchedulerRequestKey.extractFrom(container), attemptId, null, "",
|
SchedulerRequestKey.extractFrom(container), attemptId, null, "",
|
||||||
rmContext));
|
rmContext));
|
||||||
Map<ApplicationAttemptId, RMAppAttempt> attempts =
|
Map<ApplicationAttemptId, RMAppAttempt> attempts = new HashMap<>();
|
||||||
new HashMap<ApplicationAttemptId, RMAppAttempt>();
|
|
||||||
attempts.put(attemptId, rmAppAttemptImpl);
|
attempts.put(attemptId, rmAppAttemptImpl);
|
||||||
when(app.getCurrentAppAttempt()).thenReturn(rmAppAttemptImpl);
|
when(app.getCurrentAppAttempt()).thenReturn(rmAppAttemptImpl);
|
||||||
when(app.getAppAttempts()).thenReturn(attempts);
|
when(app.getAppAttempts()).thenReturn(attempts);
|
||||||
@ -1750,6 +1746,7 @@ private ResourceManager setupResourceManager() {
|
|||||||
ResourceScheduler.class);
|
ResourceScheduler.class);
|
||||||
conf.setBoolean(YarnConfiguration.RM_RESERVATION_SYSTEM_ENABLE, true);
|
conf.setBoolean(YarnConfiguration.RM_RESERVATION_SYSTEM_ENABLE, true);
|
||||||
MockRM rm = new MockRM(conf);
|
MockRM rm = new MockRM(conf);
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
try {
|
try {
|
||||||
rm.registerNode("127.0.0.1:1", 102400, 100);
|
rm.registerNode("127.0.0.1:1", 102400, 100);
|
||||||
@ -1790,8 +1787,8 @@ private ReservationSubmissionRequest submitReservationTestHelper(
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateReservation() {
|
public void testCreateReservation() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -1821,14 +1818,12 @@ public void testCreateReservation() {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Assert.assertTrue(e instanceof YarnException);
|
Assert.assertTrue(e instanceof YarnException);
|
||||||
}
|
}
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateReservation() {
|
public void testUpdateReservation() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -1857,14 +1852,12 @@ public void testUpdateReservation() {
|
|||||||
}
|
}
|
||||||
Assert.assertNotNull(uResponse);
|
Assert.assertNotNull(uResponse);
|
||||||
System.out.println("Update reservation response: " + uResponse);
|
System.out.println("Update reservation response: " + uResponse);
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testListReservationsByReservationId() {
|
public void testListReservationsByReservationId() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -1888,14 +1881,12 @@ public void testListReservationsByReservationId() {
|
|||||||
.getReservationId().getId(), reservationID.getId());
|
.getReservationId().getId(), reservationID.getId());
|
||||||
Assert.assertEquals(response.getReservationAllocationState().get(0)
|
Assert.assertEquals(response.getReservationAllocationState().get(0)
|
||||||
.getResourceAllocationRequests().size(), 0);
|
.getResourceAllocationRequests().size(), 0);
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testListReservationsByTimeInterval() {
|
public void testListReservationsByTimeInterval() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -1947,14 +1938,12 @@ public void testListReservationsByTimeInterval() {
|
|||||||
reservationRequests.getInterpreter().toString());
|
reservationRequests.getInterpreter().toString());
|
||||||
Assert.assertTrue(reservationRequests.getReservationResources().get(0)
|
Assert.assertTrue(reservationRequests.getReservationResources().get(0)
|
||||||
.getDuration() == duration);
|
.getDuration() == duration);
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testListReservationsByInvalidTimeInterval() {
|
public void testListReservationsByInvalidTimeInterval() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -1991,14 +1980,12 @@ public void testListReservationsByInvalidTimeInterval() {
|
|||||||
Assert.assertEquals(1, response.getReservationAllocationState().size());
|
Assert.assertEquals(1, response.getReservationAllocationState().size());
|
||||||
Assert.assertEquals(response.getReservationAllocationState().get(0)
|
Assert.assertEquals(response.getReservationAllocationState().get(0)
|
||||||
.getReservationId().getId(), sRequest.getReservationId().getId());
|
.getReservationId().getId(), sRequest.getReservationId().getId());
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testListReservationsByTimeIntervalContainingNoReservations() {
|
public void testListReservationsByTimeIntervalContainingNoReservations() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -2073,14 +2060,12 @@ public void testListReservationsByTimeIntervalContainingNoReservations() {
|
|||||||
// Ensure all reservations are filtered out.
|
// Ensure all reservations are filtered out.
|
||||||
Assert.assertNotNull(response);
|
Assert.assertNotNull(response);
|
||||||
assertThat(response.getReservationAllocationState()).isEmpty();
|
assertThat(response.getReservationAllocationState()).isEmpty();
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testReservationDelete() {
|
public void testReservationDelete() {
|
||||||
ResourceManager rm = setupResourceManager();
|
resourceManager = setupResourceManager();
|
||||||
ClientRMService clientService = rm.getClientRMService();
|
ClientRMService clientService = resourceManager.getClientRMService();
|
||||||
Clock clock = new UTCClock();
|
Clock clock = new UTCClock();
|
||||||
long arrival = clock.getTime();
|
long arrival = clock.getTime();
|
||||||
long duration = 60000;
|
long duration = 60000;
|
||||||
@ -2114,8 +2099,6 @@ public void testReservationDelete() {
|
|||||||
}
|
}
|
||||||
Assert.assertNotNull(response);
|
Assert.assertNotNull(response);
|
||||||
Assert.assertEquals(0, response.getReservationAllocationState().size());
|
Assert.assertEquals(0, response.getReservationAllocationState().size());
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -2128,6 +2111,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
.getRMDelegationTokenSecretManager());
|
.getRMDelegationTokenSecretManager());
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
NodeLabel labelX = NodeLabel.newInstance("x", false);
|
NodeLabel labelX = NodeLabel.newInstance("x", false);
|
||||||
NodeLabel labelY = NodeLabel.newInstance("y");
|
NodeLabel labelY = NodeLabel.newInstance("y");
|
||||||
@ -2142,12 +2126,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
labelsMgr.replaceLabelsOnNode(map);
|
labelsMgr.replaceLabelsOnNode(map);
|
||||||
|
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client = (ApplicationClientProtocol) rpc
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
|
|
||||||
// Get node labels collection
|
// Get node labels collection
|
||||||
GetClusterNodeLabelsResponse response = client
|
GetClusterNodeLabelsResponse response = client
|
||||||
@ -2168,9 +2152,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
// Below label "x" is not present in the response as exclusivity is true
|
// Below label "x" is not present in the response as exclusivity is true
|
||||||
Assert.assertFalse(nodeToLabels.get(node1).containsAll(
|
Assert.assertFalse(nodeToLabels.get(node1).containsAll(
|
||||||
Arrays.asList(NodeLabel.newInstance("x"))));
|
Arrays.asList(NodeLabel.newInstance("x"))));
|
||||||
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -2183,6 +2164,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
.getRMDelegationTokenSecretManager());
|
.getRMDelegationTokenSecretManager());
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
NodeLabel labelX = NodeLabel.newInstance("x", false);
|
NodeLabel labelX = NodeLabel.newInstance("x", false);
|
||||||
@ -2205,12 +2187,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
labelsMgr.replaceLabelsOnNode(map);
|
labelsMgr.replaceLabelsOnNode(map);
|
||||||
|
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client = (ApplicationClientProtocol) rpc
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
|
|
||||||
// Get node labels collection
|
// Get node labels collection
|
||||||
GetClusterNodeLabelsResponse response = client
|
GetClusterNodeLabelsResponse response = client
|
||||||
@ -2244,9 +2226,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
Assert.assertTrue(labelsToNodes.get(labelZ.getName()).containsAll(
|
Assert.assertTrue(labelsToNodes.get(labelZ.getName()).containsAll(
|
||||||
Arrays.asList(node1B, node3B)));
|
Arrays.asList(node1B, node3B)));
|
||||||
assertThat(labelsToNodes.get(labelY.getName())).isNull();
|
assertThat(labelsToNodes.get(labelY.getName())).isNull();
|
||||||
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 120000)
|
@Test(timeout = 120000)
|
||||||
@ -2259,6 +2238,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
NodeAttributesManager mgr = rm.getRMContext().getNodeAttributesManager();
|
NodeAttributesManager mgr = rm.getRMContext().getNodeAttributesManager();
|
||||||
@ -2278,12 +2258,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
nodes.put(host2.getHost(), ImmutableSet.of(docker));
|
nodes.put(host2.getHost(), ImmutableSet.of(docker));
|
||||||
mgr.addNodeAttributes(nodes);
|
mgr.addNodeAttributes(nodes);
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client = (ApplicationClientProtocol) rpc
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
|
|
||||||
GetClusterNodeAttributesRequest request =
|
GetClusterNodeAttributesRequest request =
|
||||||
GetClusterNodeAttributesRequest.newInstance();
|
GetClusterNodeAttributesRequest.newInstance();
|
||||||
@ -2295,8 +2275,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
Assert.assertTrue(attributes.contains(NodeAttributeInfo.newInstance(os)));
|
Assert.assertTrue(attributes.contains(NodeAttributeInfo.newInstance(os)));
|
||||||
Assert
|
Assert
|
||||||
.assertTrue(attributes.contains(NodeAttributeInfo.newInstance(docker)));
|
.assertTrue(attributes.contains(NodeAttributeInfo.newInstance(docker)));
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 120000)
|
@Test(timeout = 120000)
|
||||||
@ -2309,6 +2287,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
NodeAttributesManager mgr = rm.getRMContext().getNodeAttributesManager();
|
NodeAttributesManager mgr = rm.getRMContext().getNodeAttributesManager();
|
||||||
@ -2331,12 +2310,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
nodes.put(node2, ImmutableSet.of(docker, dist));
|
nodes.put(node2, ImmutableSet.of(docker, dist));
|
||||||
mgr.addNodeAttributes(nodes);
|
mgr.addNodeAttributes(nodes);
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client = (ApplicationClientProtocol) rpc
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
|
|
||||||
GetAttributesToNodesRequest request =
|
GetAttributesToNodesRequest request =
|
||||||
GetAttributesToNodesRequest.newInstance();
|
GetAttributesToNodesRequest.newInstance();
|
||||||
@ -2377,8 +2356,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
attrs3.get(os.getAttributeKey())));
|
attrs3.get(os.getAttributeKey())));
|
||||||
Assert.assertTrue(findHostnameAndValInMapping(node2, "docker0",
|
Assert.assertTrue(findHostnameAndValInMapping(node2, "docker0",
|
||||||
attrs3.get(docker.getAttributeKey())));
|
attrs3.get(docker.getAttributeKey())));
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean findHostnameAndValInMapping(String hostname, String attrVal,
|
private boolean findHostnameAndValInMapping(String hostname, String attrVal,
|
||||||
@ -2401,6 +2378,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
NodeAttributesManager mgr = rm.getRMContext().getNodeAttributesManager();
|
NodeAttributesManager mgr = rm.getRMContext().getNodeAttributesManager();
|
||||||
@ -2423,12 +2401,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
nodes.put(node2, ImmutableSet.of(docker, dist));
|
nodes.put(node2, ImmutableSet.of(docker, dist));
|
||||||
mgr.addNodeAttributes(nodes);
|
mgr.addNodeAttributes(nodes);
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client = (ApplicationClientProtocol) rpc
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
|
|
||||||
// Specify null for hostnames.
|
// Specify null for hostnames.
|
||||||
GetNodesToAttributesRequest request1 =
|
GetNodesToAttributesRequest request1 =
|
||||||
@ -2471,8 +2449,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
client.getNodesToAttributes(request4);
|
client.getNodesToAttributes(request4);
|
||||||
hostToAttrs = response4.getNodeToAttributes();
|
hostToAttrs = response4.getNodeToAttributes();
|
||||||
Assert.assertEquals(0, hostToAttrs.size());
|
Assert.assertEquals(0, hostToAttrs.size());
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 120000)
|
@Test(timeout = 120000)
|
||||||
@ -2480,13 +2456,14 @@ public void testUpdatePriorityAndKillAppWithZeroClusterResource()
|
|||||||
throws Exception {
|
throws Exception {
|
||||||
int maxPriority = 10;
|
int maxPriority = 10;
|
||||||
int appPriority = 5;
|
int appPriority = 5;
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
conf = new YarnConfiguration();
|
||||||
Assume.assumeFalse("FairScheduler does not support Application Priorities",
|
Assume.assumeFalse("FairScheduler does not support Application Priorities",
|
||||||
conf.get(YarnConfiguration.RM_SCHEDULER)
|
conf.get(YarnConfiguration.RM_SCHEDULER)
|
||||||
.equals(FairScheduler.class.getName()));
|
.equals(FairScheduler.class.getName()));
|
||||||
conf.setInt(YarnConfiguration.MAX_CLUSTER_LEVEL_APPLICATION_PRIORITY,
|
conf.setInt(YarnConfiguration.MAX_CLUSTER_LEVEL_APPLICATION_PRIORITY,
|
||||||
maxPriority);
|
maxPriority);
|
||||||
MockRM rm = new MockRM(conf);
|
MockRM rm = new MockRM(conf);
|
||||||
|
resourceManager = rm;
|
||||||
rm.init(conf);
|
rm.init(conf);
|
||||||
rm.start();
|
rm.start();
|
||||||
MockRMAppSubmissionData data = MockRMAppSubmissionData.Builder
|
MockRMAppSubmissionData data = MockRMAppSubmissionData.Builder
|
||||||
@ -2498,20 +2475,20 @@ public void testUpdatePriorityAndKillAppWithZeroClusterResource()
|
|||||||
testApplicationPriorityUpdation(rmService, app1, appPriority, appPriority);
|
testApplicationPriorityUpdation(rmService, app1, appPriority, appPriority);
|
||||||
rm.killApp(app1.getApplicationId());
|
rm.killApp(app1.getApplicationId());
|
||||||
rm.waitForState(app1.getApplicationId(), RMAppState.KILLED);
|
rm.waitForState(app1.getApplicationId(), RMAppState.KILLED);
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 120000)
|
@Test(timeout = 120000)
|
||||||
public void testUpdateApplicationPriorityRequest() throws Exception {
|
public void testUpdateApplicationPriorityRequest() throws Exception {
|
||||||
int maxPriority = 10;
|
int maxPriority = 10;
|
||||||
int appPriority = 5;
|
int appPriority = 5;
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
conf = new YarnConfiguration();
|
||||||
Assume.assumeFalse("FairScheduler does not support Application Priorities",
|
Assume.assumeFalse("FairScheduler does not support Application Priorities",
|
||||||
conf.get(YarnConfiguration.RM_SCHEDULER)
|
conf.get(YarnConfiguration.RM_SCHEDULER)
|
||||||
.equals(FairScheduler.class.getName()));
|
.equals(FairScheduler.class.getName()));
|
||||||
conf.setInt(YarnConfiguration.MAX_CLUSTER_LEVEL_APPLICATION_PRIORITY,
|
conf.setInt(YarnConfiguration.MAX_CLUSTER_LEVEL_APPLICATION_PRIORITY,
|
||||||
maxPriority);
|
maxPriority);
|
||||||
MockRM rm = new MockRM(conf);
|
MockRM rm = new MockRM(conf);
|
||||||
|
resourceManager = rm;
|
||||||
rm.init(conf);
|
rm.init(conf);
|
||||||
rm.start();
|
rm.start();
|
||||||
rm.registerNode("host1:1234", 1024);
|
rm.registerNode("host1:1234", 1024);
|
||||||
@ -2555,8 +2532,6 @@ public void testUpdateApplicationPriorityRequest() throws Exception {
|
|||||||
Assert.assertEquals("Incorrect priority has been set to application",
|
Assert.assertEquals("Incorrect priority has been set to application",
|
||||||
appPriority, rmService.updateApplicationPriority(updateRequest)
|
appPriority, rmService.updateApplicationPriority(updateRequest)
|
||||||
.getApplicationPriority().getPriority());
|
.getApplicationPriority().getPriority());
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testApplicationPriorityUpdation(ClientRMService rmService,
|
private void testApplicationPriorityUpdation(ClientRMService rmService,
|
||||||
@ -2576,55 +2551,53 @@ private void testApplicationPriorityUpdation(ClientRMService rmService,
|
|||||||
updateApplicationPriority.getApplicationPriority().getPriority());
|
updateApplicationPriority.getApplicationPriority().getPriority());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createExcludeFile(String filename) throws IOException {
|
private File createExcludeFile(File testDir) throws IOException {
|
||||||
File file = new File(filename);
|
File excludeFile = new File(testDir, "excludeFile");
|
||||||
if (file.exists()) {
|
try (FileOutputStream out = new FileOutputStream(excludeFile)) {
|
||||||
file.delete();
|
out.write("decommisssionedHost".getBytes(UTF_8));
|
||||||
}
|
}
|
||||||
|
return excludeFile;
|
||||||
FileOutputStream out = new FileOutputStream(file);
|
|
||||||
out.write("decommisssionedHost".getBytes());
|
|
||||||
out.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testRMStartWithDecommissionedNode() throws Exception {
|
public void testRMStartWithDecommissionedNode() throws Exception {
|
||||||
String excludeFile = "excludeFile";
|
File testDir = GenericTestUtils.getRandomizedTestDir();
|
||||||
createExcludeFile(excludeFile);
|
assertTrue("Failed to create test directory: " + testDir.getAbsolutePath(), testDir.mkdirs());
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
try {
|
||||||
conf.set(YarnConfiguration.RM_NODES_EXCLUDE_FILE_PATH,
|
File excludeFile = createExcludeFile(testDir);
|
||||||
excludeFile);
|
conf = new YarnConfiguration();
|
||||||
MockRM rm = new MockRM(conf) {
|
conf.set(YarnConfiguration.RM_NODES_EXCLUDE_FILE_PATH,
|
||||||
protected ClientRMService createClientRMService() {
|
excludeFile.getAbsolutePath());
|
||||||
return new ClientRMService(this.rmContext, scheduler,
|
MockRM rm = new MockRM(conf) {
|
||||||
this.rmAppManager, this.applicationACLsManager, this.queueACLsManager,
|
protected ClientRMService createClientRMService() {
|
||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
return new ClientRMService(this.rmContext, scheduler,
|
||||||
|
this.rmAppManager, this.applicationACLsManager, this.queueACLsManager,
|
||||||
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client =
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
(ApplicationClientProtocol) rpc
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
|
||||||
|
|
||||||
// Make call
|
// Make call
|
||||||
GetClusterNodesRequest request =
|
GetClusterNodesRequest request =
|
||||||
GetClusterNodesRequest.newInstance(EnumSet.allOf(NodeState.class));
|
GetClusterNodesRequest.newInstance(EnumSet.allOf(NodeState.class));
|
||||||
List<NodeReport> nodeReports = client.getClusterNodes(request).getNodeReports();
|
List<NodeReport> nodeReports = client.getClusterNodes(request).getNodeReports();
|
||||||
Assert.assertEquals(1, nodeReports.size());
|
assertEquals(1, nodeReports.size());
|
||||||
|
} finally {
|
||||||
rm.stop();
|
FileUtil.fullyDelete(testDir);
|
||||||
rpc.stopProxy(client, conf);
|
}
|
||||||
new File(excludeFile).delete();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetResourceTypesInfoWhenResourceProfileDisabled()
|
public void testGetResourceTypesInfoWhenResourceProfileDisabled()
|
||||||
throws Exception {
|
throws Exception {
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
conf = new YarnConfiguration();
|
||||||
MockRM rm = new MockRM(conf) {
|
MockRM rm = new MockRM(conf) {
|
||||||
protected ClientRMService createClientRMService() {
|
protected ClientRMService createClientRMService() {
|
||||||
return new ClientRMService(this.rmContext, scheduler,
|
return new ClientRMService(this.rmContext, scheduler,
|
||||||
@ -2632,14 +2605,14 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client =
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
(ApplicationClientProtocol) rpc
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
|
||||||
|
|
||||||
// Make call
|
// Make call
|
||||||
GetAllResourceTypeInfoRequest request =
|
GetAllResourceTypeInfoRequest request =
|
||||||
@ -2659,9 +2632,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
response.getResourceTypeInfo().get(1).getName());
|
response.getResourceTypeInfo().get(1).getName());
|
||||||
Assert.assertEquals(ResourceInformation.VCORES.getUnits(),
|
Assert.assertEquals(ResourceInformation.VCORES.getUnits(),
|
||||||
response.getResourceTypeInfo().get(1).getDefaultUnit());
|
response.getResourceTypeInfo().get(1).getDefaultUnit());
|
||||||
|
|
||||||
rm.stop();
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -2755,6 +2725,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
Resource resource = BuilderUtils.newResource(1024, 1);
|
Resource resource = BuilderUtils.newResource(1024, 1);
|
||||||
@ -2769,13 +2740,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
node.nodeHeartbeat(true);
|
node.nodeHeartbeat(true);
|
||||||
|
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client =
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
(ApplicationClientProtocol) rpc
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
|
||||||
|
|
||||||
// Make call
|
// Make call
|
||||||
GetClusterNodesRequest request =
|
GetClusterNodesRequest request =
|
||||||
@ -2807,9 +2777,6 @@ protected ClientRMService createClientRMService() {
|
|||||||
getResourceInformation("memory-mb").getUnits());
|
getResourceInformation("memory-mb").getUnits());
|
||||||
Assert.assertEquals(976562, nodeReports.get(0).getCapability().
|
Assert.assertEquals(976562, nodeReports.get(0).getCapability().
|
||||||
getResourceInformation("memory-mb").getValue());
|
getResourceInformation("memory-mb").getValue());
|
||||||
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -2821,6 +2788,7 @@ protected ClientRMService createClientRMService() {
|
|||||||
this.getRMContext().getRMDelegationTokenSecretManager());
|
this.getRMContext().getRMDelegationTokenSecretManager());
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
resourceManager = rm;
|
||||||
rm.start();
|
rm.start();
|
||||||
|
|
||||||
ClusterMetrics clusterMetrics = ClusterMetrics.getMetrics();
|
ClusterMetrics clusterMetrics = ClusterMetrics.getMetrics();
|
||||||
@ -2833,13 +2801,12 @@ protected ClientRMService createClientRMService() {
|
|||||||
repeat(7, clusterMetrics::incrNumShutdownNMs);
|
repeat(7, clusterMetrics::incrNumShutdownNMs);
|
||||||
|
|
||||||
// Create a client.
|
// Create a client.
|
||||||
Configuration conf = new Configuration();
|
conf = new Configuration();
|
||||||
YarnRPC rpc = YarnRPC.create(conf);
|
rpc = YarnRPC.create(conf);
|
||||||
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
InetSocketAddress rmAddress = rm.getClientRMService().getBindAddress();
|
||||||
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
LOG.info("Connecting to ResourceManager at " + rmAddress);
|
||||||
ApplicationClientProtocol client =
|
client = (ApplicationClientProtocol) rpc.getProxy(
|
||||||
(ApplicationClientProtocol) rpc
|
ApplicationClientProtocol.class, rmAddress, conf);
|
||||||
.getProxy(ApplicationClientProtocol.class, rmAddress, conf);
|
|
||||||
|
|
||||||
YarnClusterMetrics ymetrics = client.getClusterMetrics(
|
YarnClusterMetrics ymetrics = client.getClusterMetrics(
|
||||||
GetClusterMetricsRequest.newInstance()).getClusterMetrics();
|
GetClusterMetricsRequest.newInstance()).getClusterMetrics();
|
||||||
@ -2852,18 +2819,21 @@ protected ClientRMService createClientRMService() {
|
|||||||
Assert.assertEquals(5, ymetrics.getNumUnhealthyNodeManagers());
|
Assert.assertEquals(5, ymetrics.getNumUnhealthyNodeManagers());
|
||||||
Assert.assertEquals(6, ymetrics.getNumRebootedNodeManagers());
|
Assert.assertEquals(6, ymetrics.getNumRebootedNodeManagers());
|
||||||
Assert.assertEquals(7, ymetrics.getNumShutdownNodeManagers());
|
Assert.assertEquals(7, ymetrics.getNumShutdownNodeManagers());
|
||||||
|
|
||||||
rpc.stopProxy(client, conf);
|
|
||||||
rm.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
public void tearDown(){
|
public void tearDown() throws Exception {
|
||||||
if (resourceTypesFile != null && resourceTypesFile.exists()) {
|
if (resourceTypesFile != null && resourceTypesFile.exists()) {
|
||||||
resourceTypesFile.delete();
|
resourceTypesFile.delete();
|
||||||
}
|
}
|
||||||
ClusterMetrics.destroy();
|
ClusterMetrics.destroy();
|
||||||
DefaultMetricsSystem.shutdown();
|
DefaultMetricsSystem.shutdown();
|
||||||
|
if (conf != null && client != null && rpc != null) {
|
||||||
|
rpc.stopProxy(client, conf);
|
||||||
|
}
|
||||||
|
if (resourceManager != null) {
|
||||||
|
resourceManager.close();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void repeat(int n, Runnable r) {
|
private static void repeat(int n, Runnable r) {
|
||||||
|
Loading…
Reference in New Issue
Block a user