HADOOP-16532. Fix TestViewFsTrash to use the correct homeDir. Contributed by Xing Lin. (#3514)

(cherry picked from commit 97c0f96879)
This commit is contained in:
Xing Lin 2021-10-13 13:43:47 -07:00 committed by Konstantin V Shvachko
parent c7b40e43f5
commit c8f22fe737
2 changed files with 20 additions and 28 deletions

View File

@ -120,9 +120,10 @@ public class TestTrash {
/** /**
* Test trash for the shell's delete command for the default file system * Test trash for the shell's delete command for the default file system
* specified in the paramter conf * specified in the parameter conf
* @param conf * @param conf - configuration object for the filesystem
* @param base - the base path where files are created * @param base - the base path where files are created
* @param trashRootFs - the filesystem object to test trash
* @param trashRoot - the expected place where the trashbin resides * @param trashRoot - the expected place where the trashbin resides
* @throws IOException * @throws IOException
*/ */
@ -778,7 +779,7 @@ public class TestTrash {
} }
} }
static class TestLFS extends LocalFileSystem { public static class TestLFS extends LocalFileSystem {
Path home; Path home;
TestLFS() { TestLFS() {
this(TEST_DIR); this(TEST_DIR);

View File

@ -17,14 +17,10 @@
*/ */
package org.apache.hadoop.fs.viewfs; package org.apache.hadoop.fs.viewfs;
import java.io.IOException;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.FileSystemTestHelper; import org.apache.hadoop.fs.FileSystemTestHelper;
import org.apache.hadoop.fs.FsConstants; import org.apache.hadoop.fs.FsConstants;
import org.apache.hadoop.fs.LocalFileSystem;
import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.Path;
import org.apache.hadoop.fs.TestTrash; import org.apache.hadoop.fs.TestTrash;
import org.junit.After; import org.junit.After;
@ -35,31 +31,26 @@ public class TestViewFsTrash {
FileSystem fsTarget; // the target file system - the mount will point here FileSystem fsTarget; // the target file system - the mount will point here
FileSystem fsView; FileSystem fsView;
Configuration conf; Configuration conf;
FileSystemTestHelper fileSystemTestHelper = new FileSystemTestHelper(); private FileSystemTestHelper fileSystemTestHelper;
class TestLFS extends LocalFileSystem {
Path home;
TestLFS() throws IOException {
this(new Path(fileSystemTestHelper.getTestRootDir()));
}
TestLFS(Path home) throws IOException {
super();
this.home = home;
}
@Override
public Path getHomeDirectory() {
return home;
}
}
@Before @Before
public void setUp() throws Exception { public void setUp() throws Exception {
fsTarget = FileSystem.getLocal(new Configuration()); Configuration targetFSConf = new Configuration();
fsTarget.mkdirs(new Path(fileSystemTestHelper. targetFSConf.setClass("fs.file.impl", TestTrash.TestLFS.class, FileSystem.class);
getTestRootPath(fsTarget), "dir1"));
fsTarget = FileSystem.getLocal(targetFSConf);
fileSystemTestHelper = new FileSystemTestHelper(fsTarget.getHomeDirectory().toUri().getPath());
conf = ViewFileSystemTestSetup.createConfig(); conf = ViewFileSystemTestSetup.createConfig();
fsView = ViewFileSystemTestSetup.setupForViewFileSystem(conf, fileSystemTestHelper, fsTarget); fsView = ViewFileSystemTestSetup.setupForViewFileSystem(conf, fileSystemTestHelper, fsTarget);
conf.set("fs.defaultFS", FsConstants.VIEWFS_URI.toString()); conf.set("fs.defaultFS", FsConstants.VIEWFS_URI.toString());
/*
* Need to set the fs.file.impl to TestViewFsTrash.TestLFS. Otherwise, it will load
* LocalFileSystem implementation which uses System.getProperty("user.home") for homeDirectory.
*/
conf.setClass("fs.file.impl", TestTrash.TestLFS.class, FileSystem.class);
} }
@After @After
@ -70,9 +61,9 @@ public class TestViewFsTrash {
} }
@Test @Test
public void testTrash() throws IOException { public void testTrash() throws Exception {
TestTrash.trashShell(conf, fileSystemTestHelper.getTestRootPath(fsView), TestTrash.trashShell(conf, fileSystemTestHelper.getTestRootPath(fsView),
fsTarget, new Path(fsTarget.getHomeDirectory(), ".Trash/Current")); fsView, new Path(fileSystemTestHelper.getTestRootPath(fsView), ".Trash/Current"));
} }
} }