YARN-3029. FSDownload.unpack() uses local locale for FS case conversion, may not work everywhere. Contributed by Varun Saxena.

This commit is contained in:
Tsuyoshi Ozawa 2015-01-30 04:42:05 +09:00
parent 89b07490f8
commit 7acce7d364
3 changed files with 34 additions and 7 deletions

View File

@ -440,6 +440,9 @@ Release 2.7.0 - UNRELEASED
YARN-3079. Scheduler should also update maximumAllocation when updateNodeResource. YARN-3079. Scheduler should also update maximumAllocation when updateNodeResource.
(Zhihai Xu via wangda) (Zhihai Xu via wangda)
YARN-3029. FSDownload.unpack() uses local locale for FS case conversion, may not
work everywhere. (Varun Saxena via ozawa)
Release 2.6.0 - 2014-11-18 Release 2.6.0 - 2014-11-18
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -23,6 +23,7 @@ import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.security.PrivilegedExceptionAction; import java.security.PrivilegedExceptionAction;
import java.util.Locale;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future; import java.util.concurrent.Future;
@ -271,7 +272,7 @@ public class FSDownload implements Callable<Path> {
private long unpack(File localrsrc, File dst) throws IOException { private long unpack(File localrsrc, File dst) throws IOException {
switch (resource.getType()) { switch (resource.getType()) {
case ARCHIVE: { case ARCHIVE: {
String lowerDst = dst.getName().toLowerCase(); String lowerDst = dst.getName().toLowerCase(Locale.ENGLISH);
if (lowerDst.endsWith(".jar")) { if (lowerDst.endsWith(".jar")) {
RunJar.unJar(localrsrc, dst); RunJar.unJar(localrsrc, dst);
} else if (lowerDst.endsWith(".zip")) { } else if (lowerDst.endsWith(".zip")) {
@ -290,7 +291,7 @@ public class FSDownload implements Callable<Path> {
} }
break; break;
case PATTERN: { case PATTERN: {
String lowerDst = dst.getName().toLowerCase(); String lowerDst = dst.getName().toLowerCase(Locale.ENGLISH);
if (lowerDst.endsWith(".jar")) { if (lowerDst.endsWith(".jar")) {
String p = resource.getPattern(); String p = resource.getPattern();
RunJar.unJar(localrsrc, dst, RunJar.unJar(localrsrc, dst,

View File

@ -33,6 +33,7 @@ import java.util.ArrayList;
import java.util.EnumSet; import java.util.EnumSet;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.Random; import java.util.Random;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
@ -67,7 +68,6 @@ import org.apache.hadoop.fs.FileSystem;
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.util.Shell;
import org.apache.hadoop.security.UserGroupInformation; import org.apache.hadoop.security.UserGroupInformation;
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;
@ -232,7 +232,7 @@ public class TestFSDownload {
byte[] bytes = new byte[len]; byte[] bytes = new byte[len];
r.nextBytes(bytes); r.nextBytes(bytes);
File archiveFile = new File(p.toUri().getPath() + ".zip"); File archiveFile = new File(p.toUri().getPath() + ".ZIP");
archiveFile.createNewFile(); archiveFile.createNewFile();
ZipOutputStream out = new ZipOutputStream( ZipOutputStream out = new ZipOutputStream(
new FileOutputStream(archiveFile)); new FileOutputStream(archiveFile));
@ -243,11 +243,11 @@ public class TestFSDownload {
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() + ".zip")) ret.setTimestamp(files.getFileStatus(new Path(p.toString() + ".ZIP"))
.getModificationTime()); .getModificationTime());
return ret; return ret;
} }
@ -474,8 +474,8 @@ public class TestFSDownload {
int size = rand.nextInt(512) + 512; int size = rand.nextInt(512) + 512;
LocalResourceVisibility vis = LocalResourceVisibility.PRIVATE; LocalResourceVisibility vis = LocalResourceVisibility.PRIVATE;
Path p = new Path(basedir, "" + 1); Path p = new Path(basedir, "" + 1);
String strFileName = "";
LocalResource rsrc = null; LocalResource rsrc = null;
switch (fileType) { switch (fileType) {
case TAR: case TAR:
@ -487,6 +487,7 @@ public class TestFSDownload {
break; break;
case ZIP: case ZIP:
rsrc = createZipFile(files, p, size, rand, vis); rsrc = createZipFile(files, p, size, rand, vis);
strFileName = p.getName() + ".ZIP";
break; break;
case TGZ: case TGZ:
rsrc = createTgzFile(files, p, size, rand, vis); rsrc = createTgzFile(files, p, size, rand, vis);
@ -509,6 +510,13 @@ public class TestFSDownload {
FileStatus[] childFiles = files.getDefaultFileSystem().listStatus( FileStatus[] childFiles = files.getDefaultFileSystem().listStatus(
filestatus.getPath()); filestatus.getPath());
for (FileStatus childfile : childFiles) { for (FileStatus childfile : childFiles) {
if(strFileName.endsWith(".ZIP") &&
childfile.getPath().getName().equals(strFileName) &&
!childfile.isDirectory()) {
Assert.fail("Failure...After unzip, there should have been a" +
" directory formed with zip file name but found a file. "
+ childfile.getPath());
}
if (childfile.getPath().getName().startsWith("tmp")) { if (childfile.getPath().getName().startsWith("tmp")) {
Assert.fail("Tmp File should not have been there " Assert.fail("Tmp File should not have been there "
+ childfile.getPath()); + childfile.getPath());
@ -539,6 +547,21 @@ public class TestFSDownload {
downloadWithFileType(TEST_FILE_TYPE.ZIP); downloadWithFileType(TEST_FILE_TYPE.ZIP);
} }
/*
* To test fix for YARN-3029
*/
@Test (timeout=10000)
public void testDownloadArchiveZipWithTurkishLocale() throws IOException,
URISyntaxException, InterruptedException {
Locale defaultLocale = Locale.getDefault();
// Set to Turkish
Locale turkishLocale = new Locale("tr", "TR");
Locale.setDefault(turkishLocale);
downloadWithFileType(TEST_FILE_TYPE.ZIP);
// Set the locale back to original default locale
Locale.setDefault(defaultLocale);
}
@Test (timeout=10000) @Test (timeout=10000)
public void testDownloadArchiveTgz() throws IOException, URISyntaxException, public void testDownloadArchiveTgz() throws IOException, URISyntaxException,
InterruptedException { InterruptedException {