HDFS-4615. Fix TestDFSShell failures on Windows. Contributed by Arpit Agarwal
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1459586 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e976294d35
commit
c2e186bae6
@ -442,6 +442,9 @@ Release 2.0.5-beta - UNRELEASED
|
||||
HDFS-4609. TestAuditLogs should release log handles between tests.
|
||||
(Ivan Mitic via szetszwo)
|
||||
|
||||
HDFS-4615. Fix TestDFSShell failures on Windows. (Arpit Agarwal
|
||||
via szetszwo)
|
||||
|
||||
Release 2.0.4-alpha - UNRELEASED
|
||||
|
||||
INCOMPATIBLE CHANGES
|
||||
|
@ -35,6 +35,7 @@
|
||||
import java.util.List;
|
||||
import java.util.Random;
|
||||
import java.util.Scanner;
|
||||
import java.util.concurrent.atomic.AtomicInteger;
|
||||
import java.util.zip.DeflaterOutputStream;
|
||||
import java.util.zip.GZIPOutputStream;
|
||||
|
||||
@ -68,6 +69,7 @@
|
||||
*/
|
||||
public class TestDFSShell {
|
||||
private static final Log LOG = LogFactory.getLog(TestDFSShell.class);
|
||||
private static AtomicInteger counter = new AtomicInteger();
|
||||
|
||||
static final String TEST_ROOT_DIR =
|
||||
new Path(System.getProperty("test.build.data","/tmp"))
|
||||
@ -512,7 +514,7 @@ public void testURIPaths() throws Exception {
|
||||
createLocalFile(furi);
|
||||
argv = new String[3];
|
||||
argv[0] = "-put";
|
||||
argv[1] = furi.toString();
|
||||
argv[1] = furi.toURI().toString();
|
||||
argv[2] = dstFs.getUri().toString() + "/furi";
|
||||
ret = ToolRunner.run(shell, argv);
|
||||
assertEquals(" put is working ", 0, ret);
|
||||
@ -889,6 +891,9 @@ void testChmod(Configuration conf, FileSystem fs, String chmodDir)
|
||||
assertEquals("rw-rw-rw-",
|
||||
fs.getFileStatus(file).getPermission().toString());
|
||||
|
||||
// Skip "sticky bit" tests on Windows.
|
||||
//
|
||||
if (!Path.WINDOWS) {
|
||||
// test sticky bit on directories
|
||||
Path dir2 = new Path(dir, "stickybit");
|
||||
fs.mkdirs(dir2);
|
||||
@ -911,6 +916,10 @@ void testChmod(Configuration conf, FileSystem fs, String chmodDir)
|
||||
confirmPermissionChange("777", "rwxrwxrwt", fs, shell, dir2);
|
||||
|
||||
fs.delete(dir2, true);
|
||||
} else {
|
||||
LOG.info("Skipped sticky bit tests on Windows");
|
||||
}
|
||||
|
||||
fs.delete(dir, true);
|
||||
|
||||
} finally {
|
||||
@ -1595,27 +1604,29 @@ public void testInvalidShell() throws Exception {
|
||||
// force Copy Option is -f
|
||||
@Test (timeout = 30000)
|
||||
public void testCopyCommandsWithForceOption() throws Exception {
|
||||
final int SUCCESS = 0;
|
||||
final int ERROR = 1;
|
||||
|
||||
Configuration conf = new Configuration();
|
||||
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf).numDataNodes(1)
|
||||
.format(true).build();
|
||||
FsShell shell = null;
|
||||
FileSystem fs = null;
|
||||
final File localFile = new File(TEST_ROOT_DIR, "testFileForPut");
|
||||
final String localfilepath = localFile.getAbsolutePath();
|
||||
final String testdir = TEST_ROOT_DIR + "/ForceTestDir";
|
||||
final String localfilepath = new Path(localFile.getAbsolutePath()).toUri().toString();
|
||||
final String testdir = "/tmp/TestDFSShell-testCopyCommandsWithForceOption-"
|
||||
+ counter.getAndIncrement();
|
||||
final Path hdfsTestDir = new Path(testdir);
|
||||
try {
|
||||
fs = cluster.getFileSystem();
|
||||
fs.mkdirs(hdfsTestDir);
|
||||
localFile.createNewFile();
|
||||
writeFile(fs, new Path(TEST_ROOT_DIR, "testFileForPut"));
|
||||
writeFile(fs, new Path(testdir, "testFileForPut"));
|
||||
shell = new FsShell();
|
||||
|
||||
// Tests for put
|
||||
String[] argv = new String[] { "-put", "-f", localfilepath, testdir };
|
||||
int res = ToolRunner.run(shell, argv);
|
||||
int SUCCESS = 0;
|
||||
int ERROR = 1;
|
||||
assertEquals("put -f is not working", SUCCESS, res);
|
||||
|
||||
argv = new String[] { "-put", localfilepath, testdir };
|
||||
@ -1687,8 +1698,13 @@ private void deleteFileUsingTrash(
|
||||
try {
|
||||
// Create and delete a file
|
||||
fs = cluster.getFileSystem();
|
||||
writeFile(fs, new Path(TEST_ROOT_DIR, "foo"));
|
||||
final String testFile = TEST_ROOT_DIR + "/foo";
|
||||
|
||||
// Use a separate tmp dir for each invocation.
|
||||
final String testdir = "/tmp/TestDFSShell-deleteFileUsingTrash-" +
|
||||
counter.getAndIncrement();
|
||||
|
||||
writeFile(fs, new Path(testdir, "foo"));
|
||||
final String testFile = testdir + "/foo";
|
||||
final String trashFile = shell.getCurrentTrashDir() + "/" + testFile;
|
||||
String[] argv = new String[] { "-rm", testFile };
|
||||
int res = ToolRunner.run(shell, argv);
|
||||
|
Loading…
Reference in New Issue
Block a user