YARN-597. TestFSDownload fails on Windows due to dependencies on tar/gzip/jar tools. Contributed by Ivan Mitic.

git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1482149 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Arun Murthy 2013-05-13 23:49:05 +00:00
parent 2103c80b77
commit 6f236b28ff
2 changed files with 44 additions and 79 deletions

View File

@ -41,6 +41,9 @@ Trunk - Unreleased
classpath with new process's environment variables and localized resources classpath with new process's environment variables and localized resources
(Chris Nauroth via bikas) (Chris Nauroth via bikas)
YARN-597. TestFSDownload fails on Windows due to dependencies on
tar/gzip/jar tools. (Ivan Mitic via acmurthy)
BREAKDOWN OF HADOOP-8562 SUBTASKS AND RELATED JIRAS BREAKDOWN OF HADOOP-8562 SUBTASKS AND RELATED JIRAS
YARN-158. Yarn creating package-info.java must not depend on sh. YARN-158. Yarn creating package-info.java must not depend on sh.

View File

@ -25,7 +25,6 @@ import static org.junit.Assert.assertEquals;
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.net.URI;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.util.EnumSet; import java.util.EnumSet;
import java.util.HashMap; import java.util.HashMap;
@ -36,11 +35,16 @@ import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; import java.util.concurrent.Executors;
import java.util.concurrent.Future; import java.util.concurrent.Future;
import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicLong;
import java.util.jar.JarEntry;
import java.util.jar.JarOutputStream; import java.util.jar.JarOutputStream;
import java.util.jar.Manifest; import java.util.jar.Manifest;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
import junit.framework.Assert; import junit.framework.Assert;
import org.apache.commons.compress.archivers.tar.TarArchiveEntry;
import org.apache.commons.compress.archivers.tar.TarArchiveOutputStream;
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;
@ -49,12 +53,10 @@ import org.apache.hadoop.fs.FSDataOutputStream;
import org.apache.hadoop.fs.FileContext; import org.apache.hadoop.fs.FileContext;
import org.apache.hadoop.fs.FileStatus; import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.fs.LocalDirAllocator; import org.apache.hadoop.fs.LocalDirAllocator;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.fs.permission.FsPermission; import org.apache.hadoop.fs.permission.FsPermission;
import org.apache.hadoop.security.UserGroupInformation; import org.apache.hadoop.security.UserGroupInformation;
import org.apache.hadoop.util.Shell.ShellCommandExecutor;
import org.apache.hadoop.yarn.api.records.LocalResource; import org.apache.hadoop.yarn.api.records.LocalResource;
import org.apache.hadoop.yarn.api.records.LocalResourceType; import org.apache.hadoop.yarn.api.records.LocalResourceType;
import org.apache.hadoop.yarn.api.records.LocalResourceVisibility; import org.apache.hadoop.yarn.api.records.LocalResourceVisibility;
@ -122,32 +124,20 @@ public class TestFSDownload {
static LocalResource createTarFile(FileContext files, Path p, int len, static LocalResource createTarFile(FileContext files, Path p, int len,
Random r, LocalResourceVisibility vis) throws IOException, Random r, LocalResourceVisibility vis) throws IOException,
URISyntaxException { URISyntaxException {
FSDataOutputStream outFile = null;
try {
byte[] bytes = new byte[len]; byte[] bytes = new byte[len];
Path tarPath = new Path(p.toString());
outFile = files.create(tarPath, EnumSet.of(CREATE, OVERWRITE));
r.nextBytes(bytes); r.nextBytes(bytes);
outFile.write(bytes);
} finally { File archiveFile = new File(p.toUri().getPath() + ".tar");
if (outFile != null) archiveFile.createNewFile();
outFile.close(); TarArchiveOutputStream out = new TarArchiveOutputStream(
} new FileOutputStream(archiveFile));
StringBuffer tarCommand = new StringBuffer(); TarArchiveEntry entry = new TarArchiveEntry(p.getName());
URI u = new URI(p.getParent().toString()); entry.setSize(bytes.length);
tarCommand.append("cd '"); out.putArchiveEntry(entry);
tarCommand.append(FileUtil.makeShellPath(u.getPath().toString())); out.write(bytes);
tarCommand.append("' ; "); out.closeArchiveEntry();
tarCommand.append("tar -czf " + p.getName() + ".tar " + p.getName()); out.close();
String[] shellCmd = { "bash", "-c", tarCommand.toString() };
ShellCommandExecutor shexec = new ShellCommandExecutor(shellCmd);
shexec.execute();
int exitcode = shexec.getExitCode();
if (exitcode != 0) {
throw new IOException("Error untarring file " + p
+ ". Tar process exited with exit code " + exitcode);
}
LocalResource ret = recordFactory.newRecordInstance(LocalResource.class); LocalResource ret = recordFactory.newRecordInstance(LocalResource.class);
ret.setResource(ConverterUtils.getYarnUrlFromPath(new Path(p.toString() ret.setResource(ConverterUtils.getYarnUrlFromPath(new Path(p.toString()
+ ".tar"))); + ".tar")));
@ -162,32 +152,18 @@ public class TestFSDownload {
static LocalResource createJarFile(FileContext files, Path p, int len, static LocalResource createJarFile(FileContext files, Path p, int len,
Random r, LocalResourceVisibility vis) throws IOException, Random r, LocalResourceVisibility vis) throws IOException,
URISyntaxException { URISyntaxException {
FSDataOutputStream outFile = null;
try {
byte[] bytes = new byte[len]; byte[] bytes = new byte[len];
Path tarPath = new Path(p.toString());
outFile = files.create(tarPath, EnumSet.of(CREATE, OVERWRITE));
r.nextBytes(bytes); r.nextBytes(bytes);
outFile.write(bytes);
} finally { File archiveFile = new File(p.toUri().getPath() + ".jar");
if (outFile != null) archiveFile.createNewFile();
outFile.close(); JarOutputStream out = new JarOutputStream(
} new FileOutputStream(archiveFile));
StringBuffer tarCommand = new StringBuffer(); out.putNextEntry(new JarEntry(p.getName()));
URI u = new URI(p.getParent().toString()); out.write(bytes);
tarCommand.append("cd '"); out.closeEntry();
tarCommand.append(FileUtil.makeShellPath(u.getPath().toString())); out.close();
tarCommand.append("' ; ");
tarCommand.append("jar cf " + p.getName() + ".jar " + p.getName());
String[] shellCmd = { "bash", "-c", tarCommand.toString() };
ShellCommandExecutor shexec = new ShellCommandExecutor(shellCmd);
shexec.execute();
int exitcode = shexec.getExitCode();
if (exitcode != 0) {
throw new IOException("Error untarring file " + p
+ ". Tar process exited with exit code " + exitcode);
}
LocalResource ret = recordFactory.newRecordInstance(LocalResource.class); LocalResource ret = recordFactory.newRecordInstance(LocalResource.class);
ret.setResource(ConverterUtils.getYarnUrlFromPath(new Path(p.toString() ret.setResource(ConverterUtils.getYarnUrlFromPath(new Path(p.toString()
+ ".jar"))); + ".jar")));
@ -202,39 +178,25 @@ public class TestFSDownload {
static LocalResource createZipFile(FileContext files, Path p, int len, static LocalResource createZipFile(FileContext files, Path p, int len,
Random r, LocalResourceVisibility vis) throws IOException, Random r, LocalResourceVisibility vis) throws IOException,
URISyntaxException { URISyntaxException {
FSDataOutputStream outFile = null;
try {
byte[] bytes = new byte[len]; byte[] bytes = new byte[len];
Path tarPath = new Path(p.toString());
outFile = files.create(tarPath, EnumSet.of(CREATE, OVERWRITE));
r.nextBytes(bytes); r.nextBytes(bytes);
outFile.write(bytes);
} finally { File archiveFile = new File(p.toUri().getPath() + ".zip");
if (outFile != null) archiveFile.createNewFile();
outFile.close(); ZipOutputStream out = new ZipOutputStream(
} new FileOutputStream(archiveFile));
StringBuffer zipCommand = new StringBuffer(); out.putNextEntry(new ZipEntry(p.getName()));
URI u = new URI(p.getParent().toString()); out.write(bytes);
zipCommand.append("cd '"); out.closeEntry();
zipCommand.append(FileUtil.makeShellPath(u.getPath().toString())); out.close();
zipCommand.append("' ; ");
zipCommand.append("gzip " + p.getName());
String[] shellCmd = { "bash", "-c", zipCommand.toString() };
ShellCommandExecutor shexec = new ShellCommandExecutor(shellCmd);
shexec.execute();
int exitcode = shexec.getExitCode();
if (exitcode != 0) {
throw new IOException("Error untarring file " + p
+ ". Tar process exited with exit code " + exitcode);
}
LocalResource ret = recordFactory.newRecordInstance(LocalResource.class); LocalResource ret = recordFactory.newRecordInstance(LocalResource.class);
ret.setResource(ConverterUtils.getYarnUrlFromPath(new Path(p.toString() ret.setResource(ConverterUtils.getYarnUrlFromPath(new Path(p.toString()
+ ".zip"))); + ".zip")));
ret.setSize(len); ret.setSize(len);
ret.setType(LocalResourceType.ARCHIVE); ret.setType(LocalResourceType.ARCHIVE);
ret.setVisibility(vis); ret.setVisibility(vis);
ret.setTimestamp(files.getFileStatus(new Path(p.toString() + ".gz")) ret.setTimestamp(files.getFileStatus(new Path(p.toString() + ".zip"))
.getModificationTime()); .getModificationTime());
return ret; return ret;
} }