blob: 3c2b2b998ff91b34d600997e3ec4442ea8b7dd2e [file] [log] [blame]
/**
* 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.cli;
import org.apache.hadoop.cli.util.*;
import org.apache.hadoop.cli.util.CommandExecutor.Result;
import org.apache.hadoop.tools.HadoopArchives;
import org.apache.hadoop.mapred.JobConf;
import org.apache.hadoop.mapred.MiniMRCluster;
import org.apache.hadoop.mapred.tools.MRAdmin;
import org.apache.hadoop.mapreduce.server.jobtracker.JTConfig;
import org.apache.hadoop.security.authorize.HadoopPolicyProvider;
import org.apache.hadoop.security.authorize.PolicyProvider;
import org.apache.hadoop.util.ToolRunner;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.xml.sax.SAXException;
public class TestMRCLI extends TestHDFSCLI {
protected MiniMRCluster mrCluster = null;
protected String jobtracker = null;
private JobConf mrConf;
@Before
public void setUp() throws Exception {
super.setUp();
conf.setClass(PolicyProvider.POLICY_PROVIDER_CONFIG,
HadoopPolicyProvider.class, PolicyProvider.class);
mrConf = new JobConf(conf);
mrCluster = new MiniMRCluster(1, dfsCluster.getFileSystem().getUri().toString(), 1,
null, null, mrConf);
jobtracker = mrCluster.createJobConf().get(JTConfig.JT_IPC_ADDRESS, "local");
}
@After
public void tearDown() throws Exception {
mrCluster.shutdown();
super.tearDown();
}
@Override
protected TestConfigFileParser getConfigParser() {
return new TestConfigFileParserMR();
}
protected String getTestFile() {
return "testMRConf.xml";
}
@Override
protected String expandCommand(final String cmd) {
String expCmd = cmd;
expCmd = expCmd.replaceAll("JOBTRACKER", jobtracker);
expCmd = super.expandCommand(expCmd);
return expCmd;
}
@Override
protected Result execute(CLICommand cmd) throws Exception {
if (cmd.getType() instanceof CLICommandMRAdmin)
return new TestMRCLI.MRCmdExecutor(jobtracker).executeCommand(cmd.getCmd());
else if (cmd.getType() instanceof CLICommandArchive)
return new TestMRCLI.ArchiveCmdExecutor(namenode, mrConf).executeCommand(cmd.getCmd());
else
return super.execute(cmd);
}
public static class MRCmdExecutor extends CommandExecutor {
private String jobtracker = null;
public MRCmdExecutor(String jobtracker) {
this.jobtracker = jobtracker;
}
@Override
protected void execute(final String cmd) throws Exception{
MRAdmin mradmin = new MRAdmin();
String[] args = getCommandAsArgs(cmd, "JOBTRACKER", jobtracker);
ToolRunner.run(mradmin, args);
}
}
public static class ArchiveCmdExecutor extends CommandExecutor {
private String namenode = null;
private JobConf jobConf = null;
public ArchiveCmdExecutor(String namenode, JobConf jobConf) {
this.namenode = namenode;
this.jobConf = jobConf;
}
@Override
protected void execute(final String cmd) throws Exception {
HadoopArchives archive = new HadoopArchives(jobConf);
String[] args = getCommandAsArgs(cmd, "NAMENODE", namenode);
ToolRunner.run(archive, args);
}
}
@Test
@Override
public void testAll () {
super.testAll();
}
class TestConfigFileParserMR extends CLITestHelper.TestConfigFileParser {
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
if (qName.equals("mr-admin-command")) {
if (testCommands != null) {
testCommands.add(new CLITestCmdMR(charString,
new CLICommandMRAdmin()));
} else if (cleanupCommands != null) {
cleanupCommands.add(new CLITestCmdMR(charString,
new CLICommandMRAdmin()));
}
} else if (qName.equals("archive-command")) {
if (testCommands != null) {
testCommands.add(new CLITestCmdMR(charString,
new CLICommandArchive()));
} else if (cleanupCommands != null) {
cleanupCommands.add(new CLITestCmdMR(charString,
new CLICommandArchive()));
}
} else {
super.endElement(uri, localName, qName);
}
}
}
}