YARN-5953:Create CLI for changing YARN configurations. (Jonathan Hung via xgong)
This commit is contained in:
parent
e566fd8b58
commit
916bdbd6be
|
@ -142,6 +142,9 @@ function yarncmd_case
|
||||||
HADOOP_SUBCMD_SUPPORTDAEMONIZATION="true"
|
HADOOP_SUBCMD_SUPPORTDAEMONIZATION="true"
|
||||||
HADOOP_CLASSNAME='org.apache.hadoop.yarn.server.router.Router'
|
HADOOP_CLASSNAME='org.apache.hadoop.yarn.server.router.Router'
|
||||||
;;
|
;;
|
||||||
|
schedconf)
|
||||||
|
HADOOP_CLASSNAME='org.apache.hadoop.yarn.client.cli.SchedConfCLI'
|
||||||
|
;;
|
||||||
scmadmin)
|
scmadmin)
|
||||||
HADOOP_CLASSNAME='org.apache.hadoop.yarn.client.SCMAdmin'
|
HADOOP_CLASSNAME='org.apache.hadoop.yarn.client.SCMAdmin'
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -295,6 +295,11 @@ goto :eof
|
||||||
set YARN_OPTS=%YARN_OPTS% %YARN_CLIENT_OPTS%
|
set YARN_OPTS=%YARN_OPTS% %YARN_CLIENT_OPTS%
|
||||||
goto :eof
|
goto :eof
|
||||||
|
|
||||||
|
:schedconf
|
||||||
|
set CLASS=org.apache.hadoop.yarn.client.cli.SchedConfCLI
|
||||||
|
set YARN_OPTS=%YARN_OPTS% %YARN_CLIENT_OPTS%
|
||||||
|
goto :eof
|
||||||
|
|
||||||
@rem This changes %1, %2 etc. Hence those cannot be used after calling this.
|
@rem This changes %1, %2 etc. Hence those cannot be used after calling this.
|
||||||
:make_command_arguments
|
:make_command_arguments
|
||||||
if "%1" == "--config" (
|
if "%1" == "--config" (
|
||||||
|
|
|
@ -0,0 +1,238 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hadoop.yarn.client.cli;
|
||||||
|
|
||||||
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
|
import com.sun.jersey.api.client.Client;
|
||||||
|
import com.sun.jersey.api.client.ClientResponse;
|
||||||
|
import com.sun.jersey.api.client.WebResource;
|
||||||
|
import org.apache.commons.cli.CommandLine;
|
||||||
|
import org.apache.commons.cli.GnuParser;
|
||||||
|
import org.apache.commons.cli.MissingArgumentException;
|
||||||
|
import org.apache.commons.cli.Options;
|
||||||
|
import org.apache.hadoop.classification.InterfaceAudience.Public;
|
||||||
|
import org.apache.hadoop.classification.InterfaceStability.Evolving;
|
||||||
|
import org.apache.hadoop.conf.Configured;
|
||||||
|
import org.apache.hadoop.util.Tool;
|
||||||
|
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
import org.apache.hadoop.yarn.webapp.util.WebAppUtils;
|
||||||
|
import org.apache.hadoop.yarn.webapp.util.YarnWebServiceUtils;
|
||||||
|
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
import javax.ws.rs.core.Response.Status;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CLI for modifying scheduler configuration.
|
||||||
|
*/
|
||||||
|
@Public
|
||||||
|
@Evolving
|
||||||
|
public class SchedConfCLI extends Configured implements Tool {
|
||||||
|
|
||||||
|
private static final String ADD_QUEUES_OPTION = "addQueues";
|
||||||
|
private static final String REMOVE_QUEUES_OPTION = "removeQueues";
|
||||||
|
private static final String UPDATE_QUEUES_OPTION = "updateQueues";
|
||||||
|
private static final String GLOBAL_OPTIONS = "globalUpdates";
|
||||||
|
private static final String HELP_CMD = "help";
|
||||||
|
|
||||||
|
private static final String CONF_ERR_MSG = "Specify configuration key " +
|
||||||
|
"value as confKey=confVal.";
|
||||||
|
|
||||||
|
public SchedConfCLI() {
|
||||||
|
super(new YarnConfiguration());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
SchedConfCLI cli = new SchedConfCLI();
|
||||||
|
int exitCode = cli.run(args);
|
||||||
|
System.exit(exitCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int run(String[] args) throws Exception {
|
||||||
|
Options opts = new Options();
|
||||||
|
|
||||||
|
opts.addOption("add", ADD_QUEUES_OPTION, true,
|
||||||
|
"Add queues with configurations");
|
||||||
|
opts.addOption("remove", REMOVE_QUEUES_OPTION, true,
|
||||||
|
"Remove queues");
|
||||||
|
opts.addOption("update", UPDATE_QUEUES_OPTION, true,
|
||||||
|
"Update queue configurations");
|
||||||
|
opts.addOption("global", GLOBAL_OPTIONS, true,
|
||||||
|
"Update global scheduler configurations");
|
||||||
|
opts.addOption("h", HELP_CMD, false, "Displays help for all commands.");
|
||||||
|
|
||||||
|
int exitCode = -1;
|
||||||
|
CommandLine parsedCli = null;
|
||||||
|
try {
|
||||||
|
parsedCli = new GnuParser().parse(opts, args);
|
||||||
|
} catch (MissingArgumentException ex) {
|
||||||
|
System.err.println("Missing argument for options");
|
||||||
|
printUsage();
|
||||||
|
return exitCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parsedCli.hasOption(HELP_CMD)) {
|
||||||
|
printUsage();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean hasOption = false;
|
||||||
|
SchedConfUpdateInfo updateInfo = new SchedConfUpdateInfo();
|
||||||
|
try {
|
||||||
|
if (parsedCli.hasOption(ADD_QUEUES_OPTION)) {
|
||||||
|
hasOption = true;
|
||||||
|
addQueues(parsedCli.getOptionValue(ADD_QUEUES_OPTION), updateInfo);
|
||||||
|
}
|
||||||
|
if (parsedCli.hasOption(REMOVE_QUEUES_OPTION)) {
|
||||||
|
hasOption = true;
|
||||||
|
removeQueues(parsedCli.getOptionValue(REMOVE_QUEUES_OPTION),
|
||||||
|
updateInfo);
|
||||||
|
}
|
||||||
|
if (parsedCli.hasOption(UPDATE_QUEUES_OPTION)) {
|
||||||
|
hasOption = true;
|
||||||
|
updateQueues(parsedCli.getOptionValue(UPDATE_QUEUES_OPTION),
|
||||||
|
updateInfo);
|
||||||
|
}
|
||||||
|
if (parsedCli.hasOption(GLOBAL_OPTIONS)) {
|
||||||
|
hasOption = true;
|
||||||
|
globalUpdates(parsedCli.getOptionValue(GLOBAL_OPTIONS), updateInfo);
|
||||||
|
}
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
System.err.println(e.getMessage());
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!hasOption) {
|
||||||
|
System.err.println("Invalid Command Usage: ");
|
||||||
|
printUsage();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
Client webServiceClient = Client.create();
|
||||||
|
WebResource webResource = webServiceClient.resource(WebAppUtils.
|
||||||
|
getRMWebAppURLWithScheme(getConf()));
|
||||||
|
ClientResponse response = webResource.path("ws").path("v1").path("cluster")
|
||||||
|
.path("sched-conf").accept(MediaType.APPLICATION_JSON)
|
||||||
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
|
.put(ClientResponse.class);
|
||||||
|
if (response != null) {
|
||||||
|
if (response.getStatus() == Status.OK.getStatusCode()) {
|
||||||
|
System.out.println("Configuration changed successfully.");
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
System.err.println("Configuration change unsuccessful: "
|
||||||
|
+ response.getEntity(String.class));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
System.err.println("Configuration change unsuccessful: null response");
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
void addQueues(String args, SchedConfUpdateInfo updateInfo) {
|
||||||
|
if (args == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ArrayList<QueueConfigInfo> queueConfigInfos = new ArrayList<>();
|
||||||
|
for (String arg : args.split(";")) {
|
||||||
|
queueConfigInfos.add(getQueueConfigInfo(arg));
|
||||||
|
}
|
||||||
|
updateInfo.setAddQueueInfo(queueConfigInfos);
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
void removeQueues(String args, SchedConfUpdateInfo updateInfo) {
|
||||||
|
if (args == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
List<String> queuesToRemove = Arrays.asList(args.split(","));
|
||||||
|
updateInfo.setRemoveQueueInfo(new ArrayList<>(queuesToRemove));
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
void updateQueues(String args, SchedConfUpdateInfo updateInfo) {
|
||||||
|
if (args == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ArrayList<QueueConfigInfo> queueConfigInfos = new ArrayList<>();
|
||||||
|
for (String arg : args.split(";")) {
|
||||||
|
queueConfigInfos.add(getQueueConfigInfo(arg));
|
||||||
|
}
|
||||||
|
updateInfo.setUpdateQueueInfo(queueConfigInfos);
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
void globalUpdates(String args, SchedConfUpdateInfo updateInfo) {
|
||||||
|
if (args == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
HashMap<String, String> globalUpdates = new HashMap<>();
|
||||||
|
for (String globalUpdate : args.split(",")) {
|
||||||
|
putKeyValuePair(globalUpdates, globalUpdate);
|
||||||
|
}
|
||||||
|
updateInfo.setGlobalParams(globalUpdates);
|
||||||
|
}
|
||||||
|
|
||||||
|
private QueueConfigInfo getQueueConfigInfo(String arg) {
|
||||||
|
String[] queueArgs = arg.split(",");
|
||||||
|
String queuePath = queueArgs[0];
|
||||||
|
Map<String, String> queueConfigs = new HashMap<>();
|
||||||
|
for (int i = 1; i < queueArgs.length; ++i) {
|
||||||
|
putKeyValuePair(queueConfigs, queueArgs[i]);
|
||||||
|
}
|
||||||
|
return new QueueConfigInfo(queuePath, queueConfigs);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void putKeyValuePair(Map<String, String> kv, String args) {
|
||||||
|
String[] argParts = args.split("=");
|
||||||
|
if (argParts.length == 1) {
|
||||||
|
if (argParts[0].isEmpty() || !args.contains("=")) {
|
||||||
|
throw new IllegalArgumentException(CONF_ERR_MSG);
|
||||||
|
} else {
|
||||||
|
// key specified, but no value e.g. "confKey="
|
||||||
|
kv.put(argParts[0], null);
|
||||||
|
}
|
||||||
|
} else if (argParts.length > 2) {
|
||||||
|
throw new IllegalArgumentException(CONF_ERR_MSG);
|
||||||
|
} else {
|
||||||
|
if (argParts[0].isEmpty()) {
|
||||||
|
throw new IllegalArgumentException(CONF_ERR_MSG);
|
||||||
|
}
|
||||||
|
kv.put(argParts[0], argParts[1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void printUsage() {
|
||||||
|
System.out.println("yarn schedconf [-add queueAddPath1,confKey1=confVal1,"
|
||||||
|
+ "confKey2=confVal2;queueAddPath2,confKey3=confVal3] "
|
||||||
|
+ "[-remove queueRemovePath1,queueRemovePath2] "
|
||||||
|
+ "[-update queueUpdatePath1,confKey1=confVal1] "
|
||||||
|
+ "[-global globalConfKey1=globalConfVal1,"
|
||||||
|
+ "globalConfKey2=globalConfVal2]");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,160 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hadoop.yarn.client.cli;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.PrintStream;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertNull;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for testing {@link SchedConfCLI}.
|
||||||
|
*/
|
||||||
|
public class TestSchedConfCLI {
|
||||||
|
|
||||||
|
private ByteArrayOutputStream sysOutStream;
|
||||||
|
private PrintStream sysOut;
|
||||||
|
|
||||||
|
private ByteArrayOutputStream sysErrStream;
|
||||||
|
private PrintStream sysErr;
|
||||||
|
|
||||||
|
private SchedConfCLI cli;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
sysOutStream = new ByteArrayOutputStream();
|
||||||
|
sysOut = new PrintStream(sysOutStream);
|
||||||
|
System.setOut(sysOut);
|
||||||
|
|
||||||
|
sysErrStream = new ByteArrayOutputStream();
|
||||||
|
sysErr = new PrintStream(sysErrStream);
|
||||||
|
System.setErr(sysErr);
|
||||||
|
|
||||||
|
cli = new SchedConfCLI();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 10000)
|
||||||
|
public void testInvalidConf() throws Exception {
|
||||||
|
// conf pair with no key should be invalid
|
||||||
|
int exitCode = cli.run(new String[] {"-add", "root.a,=confVal"});
|
||||||
|
assertTrue("Should return an error code", exitCode != 0);
|
||||||
|
assertTrue(sysErrStream.toString().contains("Specify configuration key " +
|
||||||
|
"value as confKey=confVal."));
|
||||||
|
exitCode = cli.run(new String[] {"-update", "root.a,=confVal"});
|
||||||
|
assertTrue("Should return an error code", exitCode != 0);
|
||||||
|
assertTrue(sysErrStream.toString().contains("Specify configuration key " +
|
||||||
|
"value as confKey=confVal."));
|
||||||
|
|
||||||
|
exitCode = cli.run(new String[] {"-add", "root.a,confKey=confVal=conf"});
|
||||||
|
assertTrue("Should return an error code", exitCode != 0);
|
||||||
|
assertTrue(sysErrStream.toString().contains("Specify configuration key " +
|
||||||
|
"value as confKey=confVal."));
|
||||||
|
exitCode = cli.run(new String[] {"-update", "root.a,confKey=confVal=c"});
|
||||||
|
assertTrue("Should return an error code", exitCode != 0);
|
||||||
|
assertTrue(sysErrStream.toString().contains("Specify configuration key " +
|
||||||
|
"value as confKey=confVal."));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 10000)
|
||||||
|
public void testAddQueues() {
|
||||||
|
SchedConfUpdateInfo schedUpdateInfo = new SchedConfUpdateInfo();
|
||||||
|
cli.addQueues("root.a,a1=aVal1,a2=aVal2," +
|
||||||
|
"a3=", schedUpdateInfo);
|
||||||
|
QueueConfigInfo addInfo = schedUpdateInfo.getAddQueueInfo().get(0);
|
||||||
|
assertEquals("root.a", addInfo.getQueue());
|
||||||
|
Map<String, String> params = addInfo.getParams();
|
||||||
|
assertEquals(3, params.size());
|
||||||
|
assertEquals("aVal1", params.get("a1"));
|
||||||
|
assertEquals("aVal2", params.get("a2"));
|
||||||
|
assertNull(params.get("a3"));
|
||||||
|
|
||||||
|
schedUpdateInfo = new SchedConfUpdateInfo();
|
||||||
|
cli.addQueues("root.b,b1=bVal1;root.c,c1=cVal1", schedUpdateInfo);
|
||||||
|
assertEquals(2, schedUpdateInfo.getAddQueueInfo().size());
|
||||||
|
QueueConfigInfo bAddInfo = schedUpdateInfo.getAddQueueInfo().get(0);
|
||||||
|
assertEquals("root.b", bAddInfo.getQueue());
|
||||||
|
Map<String, String> bParams = bAddInfo.getParams();
|
||||||
|
assertEquals(1, bParams.size());
|
||||||
|
assertEquals("bVal1", bParams.get("b1"));
|
||||||
|
QueueConfigInfo cAddInfo = schedUpdateInfo.getAddQueueInfo().get(1);
|
||||||
|
assertEquals("root.c", cAddInfo.getQueue());
|
||||||
|
Map<String, String> cParams = cAddInfo.getParams();
|
||||||
|
assertEquals(1, cParams.size());
|
||||||
|
assertEquals("cVal1", cParams.get("c1"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 10000)
|
||||||
|
public void testRemoveQueues() {
|
||||||
|
SchedConfUpdateInfo schedUpdateInfo = new SchedConfUpdateInfo();
|
||||||
|
cli.removeQueues("root.a,root.b,root.c.c1", schedUpdateInfo);
|
||||||
|
List<String> removeInfo = schedUpdateInfo.getRemoveQueueInfo();
|
||||||
|
assertEquals(3, removeInfo.size());
|
||||||
|
assertEquals("root.a", removeInfo.get(0));
|
||||||
|
assertEquals("root.b", removeInfo.get(1));
|
||||||
|
assertEquals("root.c.c1", removeInfo.get(2));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 10000)
|
||||||
|
public void testUpdateQueues() {
|
||||||
|
SchedConfUpdateInfo schedUpdateInfo = new SchedConfUpdateInfo();
|
||||||
|
cli.updateQueues("root.a,a1=aVal1,a2=aVal2," +
|
||||||
|
"a3=", schedUpdateInfo);
|
||||||
|
QueueConfigInfo updateInfo = schedUpdateInfo.getUpdateQueueInfo().get(0);
|
||||||
|
assertEquals("root.a", updateInfo.getQueue());
|
||||||
|
Map<String, String> params = updateInfo.getParams();
|
||||||
|
assertEquals(3, params.size());
|
||||||
|
assertEquals("aVal1", params.get("a1"));
|
||||||
|
assertEquals("aVal2", params.get("a2"));
|
||||||
|
assertNull(params.get("a3"));
|
||||||
|
|
||||||
|
schedUpdateInfo = new SchedConfUpdateInfo();
|
||||||
|
cli.updateQueues("root.b,b1=bVal1;root.c,c1=cVal1", schedUpdateInfo);
|
||||||
|
assertEquals(2, schedUpdateInfo.getUpdateQueueInfo().size());
|
||||||
|
QueueConfigInfo bUpdateInfo = schedUpdateInfo.getUpdateQueueInfo().get(0);
|
||||||
|
assertEquals("root.b", bUpdateInfo.getQueue());
|
||||||
|
Map<String, String> bParams = bUpdateInfo.getParams();
|
||||||
|
assertEquals(1, bParams.size());
|
||||||
|
assertEquals("bVal1", bParams.get("b1"));
|
||||||
|
QueueConfigInfo cUpdateInfo = schedUpdateInfo.getUpdateQueueInfo().get(1);
|
||||||
|
assertEquals("root.c", cUpdateInfo.getQueue());
|
||||||
|
Map<String, String> cParams = cUpdateInfo.getParams();
|
||||||
|
assertEquals(1, cParams.size());
|
||||||
|
assertEquals("cVal1", cParams.get("c1"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 10000)
|
||||||
|
public void testGlobalUpdate() {
|
||||||
|
SchedConfUpdateInfo schedUpdateInfo = new SchedConfUpdateInfo();
|
||||||
|
cli.globalUpdates("schedKey1=schedVal1,schedKey2=schedVal2",
|
||||||
|
schedUpdateInfo);
|
||||||
|
Map<String, String> globalInfo = schedUpdateInfo.getGlobalParams();
|
||||||
|
assertEquals(2, globalInfo.size());
|
||||||
|
assertEquals("schedVal1", globalInfo.get("schedKey1"));
|
||||||
|
assertEquals("schedVal2", globalInfo.get("schedKey2"));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Data structures for scheduler configuration mutation info.
|
||||||
|
*/
|
||||||
|
@InterfaceAudience.Private
|
||||||
|
@InterfaceStability.Unstable
|
||||||
|
package org.apache.hadoop.yarn.webapp.dao;
|
||||||
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
|
import org.apache.hadoop.classification.InterfaceStability;
|
||||||
|
|
|
@ -23,9 +23,14 @@ import com.sun.jersey.api.client.ClientResponse;
|
||||||
import com.sun.jersey.api.client.UniformInterfaceException;
|
import com.sun.jersey.api.client.UniformInterfaceException;
|
||||||
import com.sun.jersey.api.client.WebResource;
|
import com.sun.jersey.api.client.WebResource;
|
||||||
import javax.ws.rs.core.MediaType;
|
import javax.ws.rs.core.MediaType;
|
||||||
|
|
||||||
|
import com.sun.jersey.api.json.JSONJAXBContext;
|
||||||
|
import com.sun.jersey.api.json.JSONMarshaller;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.codehaus.jettison.json.JSONObject;
|
import org.codehaus.jettison.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.StringWriter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class contains several utility function which could be used to generate
|
* This class contains several utility function which could be used to generate
|
||||||
* Restful calls to RM/NM/AHS.
|
* Restful calls to RM/NM/AHS.
|
||||||
|
@ -59,4 +64,13 @@ public final class YarnWebServiceUtils {
|
||||||
.get(ClientResponse.class);
|
.get(ClientResponse.class);
|
||||||
return response.getEntity(JSONObject.class);
|
return response.getEntity(JSONObject.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("rawtypes")
|
||||||
|
public static String toJson(Object nsli, Class klass) throws Exception {
|
||||||
|
StringWriter sw = new StringWriter();
|
||||||
|
JSONJAXBContext ctx = new JSONJAXBContext(klass);
|
||||||
|
JSONMarshaller jm = ctx.createJSONMarshaller();
|
||||||
|
jm.marshallToJSON(nsli, sw);
|
||||||
|
return sw.toString();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ package org.apache.hadoop.yarn.server.resourcemanager.scheduler;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Interface for determining whether configuration mutations are allowed.
|
* Interface for determining whether configuration mutations are allowed.
|
||||||
|
|
|
@ -22,7 +22,7 @@ import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.yarn.security.YarnAuthorizationProvider;
|
import org.apache.hadoop.yarn.security.YarnAuthorizationProvider;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default configuration mutation ACL policy. Checks if user is YARN admin.
|
* Default configuration mutation ACL policy. Checks if user is YARN admin.
|
||||||
|
|
|
@ -19,7 +19,7 @@ package org.apache.hadoop.yarn.server.resourcemanager.scheduler;
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
package org.apache.hadoop.yarn.server.resourcemanager.scheduler;
|
package org.apache.hadoop.yarn.server.resourcemanager.scheduler;
|
||||||
|
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
|
|
@ -137,11 +137,11 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.placement.Placeme
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.placement.SimplePlacementSet;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.placement.SimplePlacementSet;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.security.AppPriorityACLsManager;
|
import org.apache.hadoop.yarn.server.resourcemanager.security.AppPriorityACLsManager;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.security.RMContainerTokenSecretManager;
|
import org.apache.hadoop.yarn.server.resourcemanager.security.RMContainerTokenSecretManager;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
|
||||||
import org.apache.hadoop.yarn.server.utils.Lock;
|
import org.apache.hadoop.yarn.server.utils.Lock;
|
||||||
import org.apache.hadoop.yarn.util.resource.DefaultResourceCalculator;
|
import org.apache.hadoop.yarn.util.resource.DefaultResourceCalculator;
|
||||||
import org.apache.hadoop.yarn.util.resource.ResourceCalculator;
|
import org.apache.hadoop.yarn.util.resource.ResourceCalculator;
|
||||||
import org.apache.hadoop.yarn.util.resource.Resources;
|
import org.apache.hadoop.yarn.util.resource.Resources;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
import com.google.common.annotations.VisibleForTesting;
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
|
|
|
@ -31,8 +31,8 @@ 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.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.conf.YarnConfigurationStore.LogMutation;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.conf.YarnConfigurationStore.LogMutation;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.QueueConfigInfo;
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
|
@ -27,8 +27,8 @@ import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ConfigurationMutationACLPolicy;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ConfigurationMutationACLPolicy;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.MutableConfScheduler;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.MutableConfScheduler;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.Queue;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.Queue;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.QueueConfigInfo;
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
|
@ -199,6 +199,7 @@ import org.apache.hadoop.yarn.webapp.BadRequestException;
|
||||||
import org.apache.hadoop.yarn.webapp.ForbiddenException;
|
import org.apache.hadoop.yarn.webapp.ForbiddenException;
|
||||||
import org.apache.hadoop.yarn.webapp.NotFoundException;
|
import org.apache.hadoop.yarn.webapp.NotFoundException;
|
||||||
import org.apache.hadoop.yarn.webapp.util.WebAppUtils;
|
import org.apache.hadoop.yarn.webapp.util.WebAppUtils;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
|
||||||
import com.google.common.annotations.VisibleForTesting;
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.hadoop.yarn.server.resourcemanager.webapp.dao;
|
package org.apache.hadoop.yarn.webapp.dao;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.hadoop.yarn.server.resourcemanager.webapp.dao;
|
package org.apache.hadoop.yarn.webapp.dao;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -54,16 +54,32 @@ public class SchedConfUpdateInfo {
|
||||||
return addQueueInfo;
|
return addQueueInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setAddQueueInfo(ArrayList<QueueConfigInfo> addQueueInfo) {
|
||||||
|
this.addQueueInfo = addQueueInfo;
|
||||||
|
}
|
||||||
|
|
||||||
public ArrayList<String> getRemoveQueueInfo() {
|
public ArrayList<String> getRemoveQueueInfo() {
|
||||||
return removeQueueInfo;
|
return removeQueueInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setRemoveQueueInfo(ArrayList<String> removeQueueInfo) {
|
||||||
|
this.removeQueueInfo = removeQueueInfo;
|
||||||
|
}
|
||||||
|
|
||||||
public ArrayList<QueueConfigInfo> getUpdateQueueInfo() {
|
public ArrayList<QueueConfigInfo> getUpdateQueueInfo() {
|
||||||
return updateQueueInfo;
|
return updateQueueInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setUpdateQueueInfo(ArrayList<QueueConfigInfo> updateQueueInfo) {
|
||||||
|
this.updateQueueInfo = updateQueueInfo;
|
||||||
|
}
|
||||||
|
|
||||||
@XmlElementWrapper(name = "global-updates")
|
@XmlElementWrapper(name = "global-updates")
|
||||||
public HashMap<String, String> getGlobalParams() {
|
public HashMap<String, String> getGlobalParams() {
|
||||||
return global;
|
return global;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setGlobalParams(HashMap<String, String> globalInfo) {
|
||||||
|
this.global = globalInfo;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,8 +25,8 @@ import org.apache.hadoop.yarn.api.records.QueueInfo;
|
||||||
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.conf.QueueAdminConfigurationMutationACLPolicy;
|
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.conf.QueueAdminConfigurationMutationACLPolicy;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.QueueConfigInfo;
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
|
|
@ -23,8 +23,8 @@ import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
|
||||||
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.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.QueueConfigInfo;
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
|
|
@ -22,8 +22,6 @@ import com.google.inject.Guice;
|
||||||
import com.google.inject.servlet.ServletModule;
|
import com.google.inject.servlet.ServletModule;
|
||||||
import com.sun.jersey.api.client.ClientResponse;
|
import com.sun.jersey.api.client.ClientResponse;
|
||||||
import com.sun.jersey.api.client.WebResource;
|
import com.sun.jersey.api.client.WebResource;
|
||||||
import com.sun.jersey.api.json.JSONJAXBContext;
|
|
||||||
import com.sun.jersey.api.json.JSONMarshaller;
|
|
||||||
import com.sun.jersey.guice.spi.container.servlet.GuiceContainer;
|
import com.sun.jersey.guice.spi.container.servlet.GuiceContainer;
|
||||||
import com.sun.jersey.test.framework.WebAppDescriptor;
|
import com.sun.jersey.test.framework.WebAppDescriptor;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
@ -35,11 +33,12 @@ import org.apache.hadoop.yarn.server.resourcemanager.ResourceManager;
|
||||||
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.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.CapacitySchedulerConfiguration;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.QueueConfigInfo;
|
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.SchedConfUpdateInfo;
|
|
||||||
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
|
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
|
||||||
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
|
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
|
||||||
import org.apache.hadoop.yarn.webapp.JerseyTestBase;
|
import org.apache.hadoop.yarn.webapp.JerseyTestBase;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.QueueConfigInfo;
|
||||||
|
import org.apache.hadoop.yarn.webapp.dao.SchedConfUpdateInfo;
|
||||||
|
import org.apache.hadoop.yarn.webapp.util.YarnWebServiceUtils;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -50,7 +49,6 @@ import javax.ws.rs.core.Response.Status;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.StringWriter;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
@ -183,8 +181,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
|
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
|
@ -218,8 +216,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
|
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
|
@ -244,8 +242,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
|
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
|
@ -269,8 +267,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
|
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
|
@ -300,8 +298,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
|
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
|
@ -332,8 +330,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
|
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
|
@ -360,8 +358,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
CapacitySchedulerConfiguration newCSConf =
|
CapacitySchedulerConfiguration newCSConf =
|
||||||
|
@ -395,8 +393,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
CapacitySchedulerConfiguration newCSConf = cs.getConfiguration();
|
CapacitySchedulerConfiguration newCSConf = cs.getConfiguration();
|
||||||
|
@ -413,8 +411,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
newCSConf = cs.getConfiguration();
|
newCSConf = cs.getConfiguration();
|
||||||
|
@ -443,8 +441,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
CapacitySchedulerConfiguration newCSConf =
|
CapacitySchedulerConfiguration newCSConf =
|
||||||
|
@ -468,8 +466,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
CapacitySchedulerConfiguration newCSConf =
|
CapacitySchedulerConfiguration newCSConf =
|
||||||
|
@ -483,8 +481,8 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
r.path("ws").path("v1").path("cluster")
|
r.path("ws").path("v1").path("cluster")
|
||||||
.path("sched-conf").queryParam("user.name", userName)
|
.path("sched-conf").queryParam("user.name", userName)
|
||||||
.accept(MediaType.APPLICATION_JSON)
|
.accept(MediaType.APPLICATION_JSON)
|
||||||
.entity(toJson(updateInfo, SchedConfUpdateInfo.class),
|
.entity(YarnWebServiceUtils.toJson(updateInfo,
|
||||||
MediaType.APPLICATION_JSON)
|
SchedConfUpdateInfo.class), MediaType.APPLICATION_JSON)
|
||||||
.put(ClientResponse.class);
|
.put(ClientResponse.class);
|
||||||
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
assertEquals(Status.OK.getStatusCode(), response.getStatus());
|
||||||
newCSConf =
|
newCSConf =
|
||||||
|
@ -506,13 +504,4 @@ public class TestRMWebServicesConfigurationMutation extends JerseyTestBase {
|
||||||
}
|
}
|
||||||
super.tearDown();
|
super.tearDown();
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("rawtypes")
|
|
||||||
private String toJson(Object nsli, Class klass) throws Exception {
|
|
||||||
StringWriter sw = new StringWriter();
|
|
||||||
JSONJAXBContext ctx = new JSONJAXBContext(klass);
|
|
||||||
JSONMarshaller jm = ctx.createJSONMarshaller();
|
|
||||||
jm.marshallToJSON(nsli, sw);
|
|
||||||
return sw.toString();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue