YARN-2204. Addendum patch. TestAMRestart#testAMRestartWithExistingContainers assumes CapacityScheduler. (Robert Kanter via kasha)
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1606168 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
5f880f79d2
commit
f911f5495b
|
@ -45,6 +45,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.rmapp.attempt.RMAppAttempt;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmapp.attempt.RMAppAttemptImpl;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmapp.attempt.RMAppAttemptImpl;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmapp.attempt.RMAppAttemptState;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmapp.attempt.RMAppAttemptState;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainerState;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainerState;
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.AbstractYarnScheduler;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.SchedulerApplicationAttempt;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.SchedulerApplicationAttempt;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
|
||||||
|
@ -57,8 +58,6 @@ public class TestAMRestart {
|
||||||
public void testAMRestartWithExistingContainers() throws Exception {
|
public void testAMRestartWithExistingContainers() throws Exception {
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
YarnConfiguration conf = new YarnConfiguration();
|
||||||
conf.setInt(YarnConfiguration.RM_AM_MAX_ATTEMPTS, 2);
|
conf.setInt(YarnConfiguration.RM_AM_MAX_ATTEMPTS, 2);
|
||||||
conf.setClass(YarnConfiguration.RM_SCHEDULER, CapacityScheduler.class,
|
|
||||||
ResourceScheduler.class);
|
|
||||||
|
|
||||||
MockRM rm1 = new MockRM(conf);
|
MockRM rm1 = new MockRM(conf);
|
||||||
rm1.start();
|
rm1.start();
|
||||||
|
@ -125,9 +124,9 @@ public class TestAMRestart {
|
||||||
ContainerId.newInstance(am1.getApplicationAttemptId(), 6);
|
ContainerId.newInstance(am1.getApplicationAttemptId(), 6);
|
||||||
nm1.nodeHeartbeat(true);
|
nm1.nodeHeartbeat(true);
|
||||||
SchedulerApplicationAttempt schedulerAttempt =
|
SchedulerApplicationAttempt schedulerAttempt =
|
||||||
((CapacityScheduler) rm1.getResourceScheduler())
|
((AbstractYarnScheduler) rm1.getResourceScheduler())
|
||||||
.getCurrentAttemptForContainer(containerId6);
|
.getCurrentAttemptForContainer(containerId6);
|
||||||
while (schedulerAttempt.getReservedContainers().size() == 0) {
|
while (schedulerAttempt.getReservedContainers().isEmpty()) {
|
||||||
System.out.println("Waiting for container " + containerId6
|
System.out.println("Waiting for container " + containerId6
|
||||||
+ " to be reserved.");
|
+ " to be reserved.");
|
||||||
nm1.nodeHeartbeat(true);
|
nm1.nodeHeartbeat(true);
|
||||||
|
@ -221,7 +220,7 @@ public class TestAMRestart {
|
||||||
|
|
||||||
// record the scheduler attempt for testing.
|
// record the scheduler attempt for testing.
|
||||||
SchedulerApplicationAttempt schedulerNewAttempt =
|
SchedulerApplicationAttempt schedulerNewAttempt =
|
||||||
((CapacityScheduler) rm1.getResourceScheduler())
|
((AbstractYarnScheduler) rm1.getResourceScheduler())
|
||||||
.getCurrentAttemptForContainer(containerId2);
|
.getCurrentAttemptForContainer(containerId2);
|
||||||
// finish this application
|
// finish this application
|
||||||
MockRM.finishAMAndVerifyAppState(app1, rm1, nm1, am2);
|
MockRM.finishAMAndVerifyAppState(app1, rm1, nm1, am2);
|
||||||
|
|
Loading…
Reference in New Issue