YARN-5994. TestCapacityScheduler.testAMLimitUsage fails intermittently. Contributed by Eric Badger
This commit is contained in:
parent
0cab57223e
commit
a41f8dd58e
@ -40,6 +40,7 @@
|
|||||||
import java.util.concurrent.BrokenBarrierException;
|
import java.util.concurrent.BrokenBarrierException;
|
||||||
import java.util.concurrent.CyclicBarrier;
|
import java.util.concurrent.CyclicBarrier;
|
||||||
|
|
||||||
|
import com.google.common.base.Supplier;
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
@ -48,6 +49,7 @@
|
|||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.security.token.Token;
|
import org.apache.hadoop.security.token.Token;
|
||||||
import org.apache.hadoop.security.token.TokenIdentifier;
|
import org.apache.hadoop.security.token.TokenIdentifier;
|
||||||
|
import org.apache.hadoop.test.GenericTestUtils;
|
||||||
import org.apache.hadoop.yarn.LocalConfigurationProvider;
|
import org.apache.hadoop.yarn.LocalConfigurationProvider;
|
||||||
import org.apache.hadoop.yarn.api.ApplicationMasterProtocol;
|
import org.apache.hadoop.yarn.api.ApplicationMasterProtocol;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.AllocateRequest;
|
import org.apache.hadoop.yarn.api.protocolrecords.AllocateRequest;
|
||||||
@ -3626,7 +3628,7 @@ public void testDefaultNodeLabelExpressionQueueConfig() throws Exception {
|
|||||||
Assert.assertEquals(queueInfoB.getDefaultNodeLabelExpression(), "y");
|
Assert.assertEquals(queueInfoB.getDefaultNodeLabelExpression(), "y");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 30000)
|
@Test(timeout = 60000)
|
||||||
public void testAMLimitUsage() throws Exception {
|
public void testAMLimitUsage() throws Exception {
|
||||||
|
|
||||||
CapacitySchedulerConfiguration config =
|
CapacitySchedulerConfiguration config =
|
||||||
@ -3754,7 +3756,8 @@ protected RMNodeLabelsManager createNodeLabelManager() {
|
|||||||
private void verifyAMLimitForLeafQueue(CapacitySchedulerConfiguration config)
|
private void verifyAMLimitForLeafQueue(CapacitySchedulerConfiguration config)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
MockRM rm = setUpMove(config);
|
MockRM rm = setUpMove(config);
|
||||||
rm.registerNode("127.0.0.1:1234", 2 * GB);
|
int nodeMemory = 4 * GB;
|
||||||
|
rm.registerNode("127.0.0.1:1234", nodeMemory);
|
||||||
|
|
||||||
String queueName = "a1";
|
String queueName = "a1";
|
||||||
String userName = "user_0";
|
String userName = "user_0";
|
||||||
@ -3770,6 +3773,14 @@ private void verifyAMLimitForLeafQueue(CapacitySchedulerConfiguration config)
|
|||||||
Resource.newInstance(amResourceLimit.getMemorySize() + 2048,
|
Resource.newInstance(amResourceLimit.getMemorySize() + 2048,
|
||||||
amResourceLimit.getVirtualCores() + 1);
|
amResourceLimit.getVirtualCores() + 1);
|
||||||
|
|
||||||
|
// Wait for the scheduler to be updated with new node capacity
|
||||||
|
GenericTestUtils.waitFor(new Supplier<Boolean>() {
|
||||||
|
@Override
|
||||||
|
public Boolean get() {
|
||||||
|
return scheduler.getMaximumResourceCapability().getMemorySize() == nodeMemory;
|
||||||
|
}
|
||||||
|
}, 100, 60 * 1000);
|
||||||
|
|
||||||
rm.submitApp(amResource1, "app-1", userName, null, queueName);
|
rm.submitApp(amResource1, "app-1", userName, null, queueName);
|
||||||
|
|
||||||
rm.submitApp(amResource2, "app-2", userName, null, queueName);
|
rm.submitApp(amResource2, "app-2", userName, null, queueName);
|
||||||
|
Loading…
Reference in New Issue
Block a user