YARN-9949. Add missing queue configs for root queue in RMWebService#CapacitySchedulerInfo.
Contributed by Prabhu Joseph.
This commit is contained in:
parent
8eda9fcab8
commit
f9b872b6ec
|
@ -50,6 +50,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.placement.MultiNo
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.placement.MultiNodePolicySpec;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.placement.MultiNodePolicySpec;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FairOrderingPolicy;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FairOrderingPolicy;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FifoOrderingPolicy;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FifoOrderingPolicy;
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FifoOrderingPolicyForPendingApps;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FifoOrderingPolicyWithExclusivePartitions;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.FifoOrderingPolicyWithExclusivePartitions;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.OrderingPolicy;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.OrderingPolicy;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.SchedulableEntity;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy.SchedulableEntity;
|
||||||
|
@ -163,6 +164,9 @@ public class CapacitySchedulerConfiguration extends ReservationSchedulerConfigur
|
||||||
public static final String FIFO_WITH_PARTITIONS_APP_ORDERING_POLICY
|
public static final String FIFO_WITH_PARTITIONS_APP_ORDERING_POLICY
|
||||||
= "fifo-with-partitions";
|
= "fifo-with-partitions";
|
||||||
|
|
||||||
|
public static final String FIFO_FOR_PENDING_APPS
|
||||||
|
= "fifo-for-pending-apps";
|
||||||
|
|
||||||
public static final String DEFAULT_APP_ORDERING_POLICY =
|
public static final String DEFAULT_APP_ORDERING_POLICY =
|
||||||
FIFO_APP_ORDERING_POLICY;
|
FIFO_APP_ORDERING_POLICY;
|
||||||
|
|
||||||
|
@ -573,6 +577,10 @@ public class CapacitySchedulerConfiguration extends ReservationSchedulerConfigur
|
||||||
if (policyType.trim().equals(FIFO_WITH_PARTITIONS_APP_ORDERING_POLICY)) {
|
if (policyType.trim().equals(FIFO_WITH_PARTITIONS_APP_ORDERING_POLICY)) {
|
||||||
policyType = FifoOrderingPolicyWithExclusivePartitions.class.getName();
|
policyType = FifoOrderingPolicyWithExclusivePartitions.class.getName();
|
||||||
}
|
}
|
||||||
|
if (policyType.trim().equals(FIFO_FOR_PENDING_APPS)) {
|
||||||
|
policyType = FifoOrderingPolicyForPendingApps.class.getName();
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
orderingPolicy = (OrderingPolicy<S>)
|
orderingPolicy = (OrderingPolicy<S>)
|
||||||
Class.forName(policyType).newInstance();
|
Class.forName(policyType).newInstance();
|
||||||
|
|
|
@ -139,4 +139,7 @@ public abstract class AbstractComparatorOrderingPolicy<S extends SchedulableEnti
|
||||||
@Override
|
@Override
|
||||||
public abstract String getInfo();
|
public abstract String getInfo();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public abstract String getConfigName();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.concurrent.ConcurrentSkipListSet;
|
||||||
|
|
||||||
import com.google.common.annotations.VisibleForTesting;
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
|
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
||||||
import org.apache.hadoop.yarn.nodelabels.CommonNodeLabelsManager;
|
import org.apache.hadoop.yarn.nodelabels.CommonNodeLabelsManager;
|
||||||
|
|
||||||
|
@ -119,4 +120,9 @@ public class FairOrderingPolicy<S extends SchedulableEntity> extends AbstractCom
|
||||||
return "FairOrderingPolicy" + sbw;
|
return "FairOrderingPolicy" + sbw;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getConfigName() {
|
||||||
|
return CapacitySchedulerConfiguration.FAIR_APP_ORDERING_POLICY;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@ package org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.concurrent.ConcurrentSkipListSet;
|
import java.util.concurrent.ConcurrentSkipListSet;
|
||||||
|
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -62,4 +63,9 @@ public class FifoOrderingPolicy<S extends SchedulableEntity> extends AbstractCom
|
||||||
return "FifoOrderingPolicy";
|
return "FifoOrderingPolicy";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getConfigName() {
|
||||||
|
return CapacitySchedulerConfiguration.FIFO_APP_ORDERING_POLICY;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,7 @@ package org.apache.hadoop.yarn.server.resourcemanager.scheduler.policy;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
||||||
import java.util.concurrent.ConcurrentSkipListSet;
|
import java.util.concurrent.ConcurrentSkipListSet;
|
||||||
|
|
||||||
|
@ -55,6 +56,11 @@ public class FifoOrderingPolicyForPendingApps<S extends SchedulableEntity>
|
||||||
return "FifoOrderingPolicyForPendingApps";
|
return "FifoOrderingPolicyForPendingApps";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getConfigName() {
|
||||||
|
return CapacitySchedulerConfiguration.FIFO_FOR_PENDING_APPS;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void configure(Map<String, String> conf) {
|
public void configure(Map<String, String> conf) {
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmcontainer.RMContainer;
|
||||||
|
|
||||||
|
|
||||||
|
@ -136,6 +137,12 @@ public class FifoOrderingPolicyWithExclusivePartitions<S extends SchedulableEnti
|
||||||
return "FifoOrderingPolicyWithExclusivePartitions";
|
return "FifoOrderingPolicyWithExclusivePartitions";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getConfigName() {
|
||||||
|
return CapacitySchedulerConfiguration
|
||||||
|
.FIFO_WITH_PARTITIONS_APP_ORDERING_POLICY;
|
||||||
|
}
|
||||||
|
|
||||||
private OrderingPolicy<S> getPartitionOrderingPolicy(String partition) {
|
private OrderingPolicy<S> getPartitionOrderingPolicy(String partition) {
|
||||||
String keyPartition = orderingPolicies.containsKey(partition) ?
|
String keyPartition = orderingPolicies.containsKey(partition) ?
|
||||||
partition : DEFAULT_PARTITION;
|
partition : DEFAULT_PARTITION;
|
||||||
|
|
|
@ -129,4 +129,10 @@ public interface OrderingPolicy<S extends SchedulableEntity> {
|
||||||
*/
|
*/
|
||||||
public String getInfo();
|
public String getInfo();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return configuration name (which will be used to set ordering policy).
|
||||||
|
* @return configuration name
|
||||||
|
*/
|
||||||
|
String getConfigName();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -201,7 +201,7 @@ class CapacitySchedulerPage extends RmView {
|
||||||
__("Configured Minimum User Limit Percent:", Integer.toString(lqinfo.getUserLimit()) + "%").
|
__("Configured Minimum User Limit Percent:", Integer.toString(lqinfo.getUserLimit()) + "%").
|
||||||
__("Configured User Limit Factor:", lqinfo.getUserLimitFactor()).
|
__("Configured User Limit Factor:", lqinfo.getUserLimitFactor()).
|
||||||
__("Accessible Node Labels:", StringUtils.join(",", lqinfo.getNodeLabels())).
|
__("Accessible Node Labels:", StringUtils.join(",", lqinfo.getNodeLabels())).
|
||||||
__("Ordering Policy: ", lqinfo.getOrderingPolicyInfo()).
|
__("Ordering Policy: ", lqinfo.getOrderingPolicyDisplayName()).
|
||||||
__("Preemption:",
|
__("Preemption:",
|
||||||
lqinfo.getPreemptionDisabled() ? "disabled" : "enabled").
|
lqinfo.getPreemptionDisabled() ? "disabled" : "enabled").
|
||||||
__("Intra-queue Preemption:", lqinfo.getIntraQueuePreemptionDisabled()
|
__("Intra-queue Preemption:", lqinfo.getIntraQueuePreemptionDisabled()
|
||||||
|
|
|
@ -24,11 +24,17 @@ import javax.xml.bind.annotation.XmlRootElement;
|
||||||
import javax.xml.bind.annotation.XmlTransient;
|
import javax.xml.bind.annotation.XmlTransient;
|
||||||
import javax.xml.bind.annotation.XmlType;
|
import javax.xml.bind.annotation.XmlType;
|
||||||
|
|
||||||
|
import org.apache.hadoop.util.StringUtils;
|
||||||
|
import org.apache.hadoop.security.authorize.AccessControlList;
|
||||||
|
import org.apache.hadoop.yarn.security.AccessType;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CSQueue;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CSQueue;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.LeafQueue;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.LeafQueue;
|
||||||
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.ParentQueue;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@XmlRootElement(name = "capacityScheduler")
|
@XmlRootElement(name = "capacityScheduler")
|
||||||
|
@ -43,6 +49,10 @@ public class CapacitySchedulerInfo extends SchedulerInfo {
|
||||||
protected CapacitySchedulerQueueInfoList queues;
|
protected CapacitySchedulerQueueInfoList queues;
|
||||||
protected QueueCapacitiesInfo capacities;
|
protected QueueCapacitiesInfo capacities;
|
||||||
protected CapacitySchedulerHealthInfo health;
|
protected CapacitySchedulerHealthInfo health;
|
||||||
|
protected ResourceInfo maximumAllocation;
|
||||||
|
protected QueueAclsInfo queueAcls;
|
||||||
|
protected int queuePriority;
|
||||||
|
protected String orderingPolicyInfo;
|
||||||
|
|
||||||
@XmlTransient
|
@XmlTransient
|
||||||
static final float EPSILON = 1e-8f;
|
static final float EPSILON = 1e-8f;
|
||||||
|
@ -63,6 +73,31 @@ public class CapacitySchedulerInfo extends SchedulerInfo {
|
||||||
parent.getQueueResourceQuotas(), false);
|
parent.getQueueResourceQuotas(), false);
|
||||||
queues = getQueues(cs, parent);
|
queues = getQueues(cs, parent);
|
||||||
health = new CapacitySchedulerHealthInfo(cs);
|
health = new CapacitySchedulerHealthInfo(cs);
|
||||||
|
maximumAllocation = new ResourceInfo(parent.getMaximumAllocation());
|
||||||
|
|
||||||
|
CapacitySchedulerConfiguration conf = cs.getConfiguration();
|
||||||
|
queueAcls = new QueueAclsInfo();
|
||||||
|
for (Map.Entry<AccessType, AccessControlList> e : conf
|
||||||
|
.getAcls(queueName).entrySet()) {
|
||||||
|
QueueAclInfo queueAcl = new QueueAclInfo(e.getKey().toString(),
|
||||||
|
e.getValue().getAclString());
|
||||||
|
queueAcls.add(queueAcl);
|
||||||
|
}
|
||||||
|
|
||||||
|
String aclApplicationMaxPriority = "acl_" +
|
||||||
|
StringUtils.toLowerCase(AccessType.APPLICATION_MAX_PRIORITY.toString());
|
||||||
|
String priorityAcls = conf.get(parent.getQueuePath()
|
||||||
|
+ aclApplicationMaxPriority, conf.ALL_ACL);
|
||||||
|
|
||||||
|
QueueAclInfo queueAcl = new QueueAclInfo(
|
||||||
|
AccessType.APPLICATION_MAX_PRIORITY.toString(), priorityAcls);
|
||||||
|
queueAcls.add(queueAcl);
|
||||||
|
|
||||||
|
queuePriority = parent.getPriority().getPriority();
|
||||||
|
if (parent instanceof ParentQueue) {
|
||||||
|
orderingPolicyInfo = ((ParentQueue) parent).getQueueOrderingPolicy()
|
||||||
|
.getConfigName();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getCapacity() {
|
public float getCapacity() {
|
||||||
|
@ -85,6 +120,22 @@ public class CapacitySchedulerInfo extends SchedulerInfo {
|
||||||
return this.queueName;
|
return this.queueName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ResourceInfo getMaximumAllocation() {
|
||||||
|
return maximumAllocation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public QueueAclsInfo getQueueAcls() {
|
||||||
|
return queueAcls;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getPriority() {
|
||||||
|
return queuePriority;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOrderingPolicyInfo() {
|
||||||
|
return orderingPolicyInfo;
|
||||||
|
}
|
||||||
|
|
||||||
public CapacitySchedulerQueueInfoList getQueues() {
|
public CapacitySchedulerQueueInfoList getQueues() {
|
||||||
return this.queues;
|
return this.queues;
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,6 +58,9 @@ public class CapacitySchedulerLeafQueueInfo extends CapacitySchedulerQueueInfo {
|
||||||
protected long maxApplicationLifetime;
|
protected long maxApplicationLifetime;
|
||||||
protected long defaultApplicationLifetime;
|
protected long defaultApplicationLifetime;
|
||||||
|
|
||||||
|
@XmlTransient
|
||||||
|
protected String orderingPolicyDisplayName;
|
||||||
|
|
||||||
CapacitySchedulerLeafQueueInfo() {
|
CapacitySchedulerLeafQueueInfo() {
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -76,7 +79,8 @@ public class CapacitySchedulerLeafQueueInfo extends CapacitySchedulerQueueInfo {
|
||||||
usedAMResource = new ResourceInfo(q.getQueueResourceUsage().getAMUsed());
|
usedAMResource = new ResourceInfo(q.getQueueResourceUsage().getAMUsed());
|
||||||
preemptionDisabled = q.getPreemptionDisabled();
|
preemptionDisabled = q.getPreemptionDisabled();
|
||||||
intraQueuePreemptionDisabled = q.getIntraQueuePreemptionDisabled();
|
intraQueuePreemptionDisabled = q.getIntraQueuePreemptionDisabled();
|
||||||
orderingPolicyInfo = q.getOrderingPolicy().getInfo();
|
orderingPolicyDisplayName = q.getOrderingPolicy().getInfo();
|
||||||
|
orderingPolicyInfo = q.getOrderingPolicy().getConfigName();
|
||||||
defaultNodeLabelExpression = q.getDefaultNodeLabelExpression();
|
defaultNodeLabelExpression = q.getDefaultNodeLabelExpression();
|
||||||
defaultPriority = q.getDefaultApplicationPriority().getPriority();
|
defaultPriority = q.getDefaultApplicationPriority().getPriority();
|
||||||
ArrayList<UserInfo> usersList = users.getUsersList();
|
ArrayList<UserInfo> usersList = users.getUsersList();
|
||||||
|
@ -165,6 +169,10 @@ public class CapacitySchedulerLeafQueueInfo extends CapacitySchedulerQueueInfo {
|
||||||
return intraQueuePreemptionDisabled;
|
return intraQueuePreemptionDisabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getOrderingPolicyDisplayName() {
|
||||||
|
return orderingPolicyDisplayName;
|
||||||
|
}
|
||||||
|
|
||||||
public String getDefaultNodeLabelExpression() {
|
public String getDefaultNodeLabelExpression() {
|
||||||
return defaultNodeLabelExpression;
|
return defaultNodeLabelExpression;
|
||||||
}
|
}
|
||||||
|
|
|
@ -87,6 +87,8 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
int maxApplicationsPerUser;
|
int maxApplicationsPerUser;
|
||||||
int userLimit;
|
int userLimit;
|
||||||
float userLimitFactor;
|
float userLimitFactor;
|
||||||
|
long defaultApplicationLifetime;
|
||||||
|
long maxApplicationLifetime;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class WebServletModule extends ServletModule {
|
private static class WebServletModule extends ServletModule {
|
||||||
|
@ -131,6 +133,8 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
config.setQueues(A, new String[] {"a1", "a2"});
|
config.setQueues(A, new String[] {"a1", "a2"});
|
||||||
config.setCapacity(A1, 30);
|
config.setCapacity(A1, 30);
|
||||||
config.setMaximumCapacity(A1, 50);
|
config.setMaximumCapacity(A1, 50);
|
||||||
|
config.setMaximumLifetimePerQueue(A2, 100);
|
||||||
|
config.setDefaultLifetimePerQueue(A2, 50);
|
||||||
|
|
||||||
config.setUserLimitFactor(A1, 100.0f);
|
config.setUserLimitFactor(A1, 100.0f);
|
||||||
config.setCapacity(A2, 70);
|
config.setCapacity(A2, 70);
|
||||||
|
@ -311,6 +315,10 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
lqi.userLimit = WebServicesTestUtils.getXmlInt(qElem, "userLimit");
|
lqi.userLimit = WebServicesTestUtils.getXmlInt(qElem, "userLimit");
|
||||||
lqi.userLimitFactor =
|
lqi.userLimitFactor =
|
||||||
WebServicesTestUtils.getXmlFloat(qElem, "userLimitFactor");
|
WebServicesTestUtils.getXmlFloat(qElem, "userLimitFactor");
|
||||||
|
lqi.defaultApplicationLifetime =
|
||||||
|
WebServicesTestUtils.getXmlLong(qElem, "defaultApplicationLifetime");
|
||||||
|
lqi.maxApplicationLifetime =
|
||||||
|
WebServicesTestUtils.getXmlLong(qElem, "maxApplicationLifetime");
|
||||||
verifyLeafQueueGeneric(q, lqi);
|
verifyLeafQueueGeneric(q, lqi);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -321,7 +329,7 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
JSONObject info = json.getJSONObject("scheduler");
|
JSONObject info = json.getJSONObject("scheduler");
|
||||||
assertEquals("incorrect number of elements in: " + info, 1, info.length());
|
assertEquals("incorrect number of elements in: " + info, 1, info.length());
|
||||||
info = info.getJSONObject("schedulerInfo");
|
info = info.getJSONObject("schedulerInfo");
|
||||||
assertEquals("incorrect number of elements in: " + info, 8, info.length());
|
assertEquals("incorrect number of elements in: " + info, 12, info.length());
|
||||||
verifyClusterSchedulerGeneric(info.getString("type"),
|
verifyClusterSchedulerGeneric(info.getString("type"),
|
||||||
(float) info.getDouble("usedCapacity"),
|
(float) info.getDouble("usedCapacity"),
|
||||||
(float) info.getDouble("capacity"),
|
(float) info.getDouble("capacity"),
|
||||||
|
@ -337,6 +345,16 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
assertEquals("incorrect number of elements in: " + health, 3,
|
assertEquals("incorrect number of elements in: " + health, 3,
|
||||||
lastRunDetails.length());
|
lastRunDetails.length());
|
||||||
|
|
||||||
|
JSONObject maximumAllocation = info.getJSONObject("maximumAllocation");
|
||||||
|
assertEquals("8192", maximumAllocation.getString("memory"));
|
||||||
|
assertEquals("4", maximumAllocation.getString("vCores"));
|
||||||
|
|
||||||
|
JSONObject queueAcls = info.getJSONObject("queueAcls");
|
||||||
|
assertEquals(1, queueAcls.length());
|
||||||
|
|
||||||
|
assertEquals("0", info.getString("queuePriority"));
|
||||||
|
assertEquals("utilization", info.getString("orderingPolicyInfo"));
|
||||||
|
|
||||||
JSONArray arr = info.getJSONObject("queues").getJSONArray("queue");
|
JSONArray arr = info.getJSONObject("queues").getJSONArray("queue");
|
||||||
assertEquals("incorrect number of elements in: " + arr, 2, arr.length());
|
assertEquals("incorrect number of elements in: " + arr, 2, arr.length());
|
||||||
|
|
||||||
|
@ -362,10 +380,10 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
private void verifySubQueue(JSONObject info, String q,
|
private void verifySubQueue(JSONObject info, String q,
|
||||||
float parentAbsCapacity, float parentAbsMaxCapacity)
|
float parentAbsCapacity, float parentAbsMaxCapacity)
|
||||||
throws JSONException, Exception {
|
throws JSONException, Exception {
|
||||||
int numExpectedElements = 20;
|
int numExpectedElements = 24;
|
||||||
boolean isParentQueue = true;
|
boolean isParentQueue = true;
|
||||||
if (!info.has("queues")) {
|
if (!info.has("queues")) {
|
||||||
numExpectedElements = 35;
|
numExpectedElements = 42;
|
||||||
isParentQueue = false;
|
isParentQueue = false;
|
||||||
}
|
}
|
||||||
assertEquals("incorrect number of elements", numExpectedElements, info.length());
|
assertEquals("incorrect number of elements", numExpectedElements, info.length());
|
||||||
|
@ -391,6 +409,16 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
String q2 = q + "." + obj.getString("queueName");
|
String q2 = q + "." + obj.getString("queueName");
|
||||||
verifySubQueue(obj, q2, qi.absoluteCapacity, qi.absoluteMaxCapacity);
|
verifySubQueue(obj, q2, qi.absoluteCapacity, qi.absoluteMaxCapacity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JSONObject maximumAllocation = info.getJSONObject("maximumAllocation");
|
||||||
|
assertEquals("8192", maximumAllocation.getString("memory"));
|
||||||
|
assertEquals("4", maximumAllocation.getString("vCores"));
|
||||||
|
|
||||||
|
JSONObject queueAcls = info.getJSONObject("queueAcls");
|
||||||
|
assertEquals(1, queueAcls.length());
|
||||||
|
|
||||||
|
assertEquals("0", info.getString("queuePriority"));
|
||||||
|
assertEquals("utilization", info.getString("orderingPolicyInfo"));
|
||||||
} else {
|
} else {
|
||||||
Assert.assertEquals("\"type\" field is incorrect",
|
Assert.assertEquals("\"type\" field is incorrect",
|
||||||
"capacitySchedulerLeafQueueInfo", info.getString("type"));
|
"capacitySchedulerLeafQueueInfo", info.getString("type"));
|
||||||
|
@ -402,6 +430,9 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
lqi.maxApplicationsPerUser = info.getInt("maxApplicationsPerUser");
|
lqi.maxApplicationsPerUser = info.getInt("maxApplicationsPerUser");
|
||||||
lqi.userLimit = info.getInt("userLimit");
|
lqi.userLimit = info.getInt("userLimit");
|
||||||
lqi.userLimitFactor = (float) info.getDouble("userLimitFactor");
|
lqi.userLimitFactor = (float) info.getDouble("userLimitFactor");
|
||||||
|
lqi.defaultApplicationLifetime =
|
||||||
|
info.getLong("defaultApplicationLifetime");
|
||||||
|
lqi.maxApplicationLifetime = info.getLong("maxApplicationLifetime");
|
||||||
verifyLeafQueueGeneric(q, lqi);
|
verifyLeafQueueGeneric(q, lqi);
|
||||||
// resourcesUsed and users (per-user resources used) are checked in
|
// resourcesUsed and users (per-user resources used) are checked in
|
||||||
// testPerUserResource()
|
// testPerUserResource()
|
||||||
|
@ -466,6 +497,15 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
|
||||||
info.userLimit);
|
info.userLimit);
|
||||||
assertEquals("userLimitFactor doesn't match",
|
assertEquals("userLimitFactor doesn't match",
|
||||||
csConf.getUserLimitFactor(q), info.userLimitFactor, 1e-3f);
|
csConf.getUserLimitFactor(q), info.userLimitFactor, 1e-3f);
|
||||||
|
|
||||||
|
if (q.equals("root.a.a2")) {
|
||||||
|
assertEquals("defaultApplicationLifetime doesn't match",
|
||||||
|
csConf.getDefaultLifetimePerQueue(q),
|
||||||
|
info.defaultApplicationLifetime);
|
||||||
|
assertEquals("maxApplicationLifetime doesn't match",
|
||||||
|
csConf.getMaximumLifetimePerQueue(q),
|
||||||
|
info.maxApplicationLifetime);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Return a child Node of node with the tagname or null if none exists
|
//Return a child Node of node with the tagname or null if none exists
|
||||||
|
|
|
@ -466,7 +466,7 @@ public class TestRMWebServicesForCSWithPartitions extends JerseyTestBase {
|
||||||
JSONObject info = json.getJSONObject("scheduler");
|
JSONObject info = json.getJSONObject("scheduler");
|
||||||
assertEquals("incorrect number of elements", 1, info.length());
|
assertEquals("incorrect number of elements", 1, info.length());
|
||||||
info = info.getJSONObject("schedulerInfo");
|
info = info.getJSONObject("schedulerInfo");
|
||||||
assertEquals("incorrect number of elements", 8, info.length());
|
assertEquals("incorrect number of elements", 12, info.length());
|
||||||
JSONObject capacitiesJsonObject = info.getJSONObject(CAPACITIES);
|
JSONObject capacitiesJsonObject = info.getJSONObject(CAPACITIES);
|
||||||
JSONArray partitionsCapsArray =
|
JSONArray partitionsCapsArray =
|
||||||
capacitiesJsonObject.getJSONArray(QUEUE_CAPACITIES_BY_PARTITION);
|
capacitiesJsonObject.getJSONArray(QUEUE_CAPACITIES_BY_PARTITION);
|
||||||
|
|
Loading…
Reference in New Issue