HDFS-15529: getChildFilesystems should include fallback fs as well (#2234). Contributed by Uma Maheswara Rao G.
This commit is contained in:
parent
5c15815773
commit
b3660d0147
|
@ -394,6 +394,15 @@ abstract class InodeTree<T> {
|
||||||
return rootFallbackLink != null;
|
return rootFallbackLink != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return true if the root represented as internalDir. In LinkMergeSlash,
|
||||||
|
* there will be root to root mapping. So, root does not represent as
|
||||||
|
* internalDir.
|
||||||
|
*/
|
||||||
|
protected boolean isRootInternalDir() {
|
||||||
|
return root.isInternalDir();
|
||||||
|
}
|
||||||
|
|
||||||
protected INodeLink<T> getRootFallbackLink() {
|
protected INodeLink<T> getRootFallbackLink() {
|
||||||
Preconditions.checkState(root.isInternalDir());
|
Preconditions.checkState(root.isInternalDir());
|
||||||
return rootFallbackLink;
|
return rootFallbackLink;
|
||||||
|
|
|
@ -939,6 +939,12 @@ public class ViewFileSystem extends FileSystem {
|
||||||
FileSystem targetFs = mountPoint.target.targetFileSystem;
|
FileSystem targetFs = mountPoint.target.targetFileSystem;
|
||||||
children.addAll(Arrays.asList(targetFs.getChildFileSystems()));
|
children.addAll(Arrays.asList(targetFs.getChildFileSystems()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (fsState.isRootInternalDir() && fsState.getRootFallbackLink() != null) {
|
||||||
|
children.addAll(Arrays.asList(
|
||||||
|
fsState.getRootFallbackLink().targetFileSystem
|
||||||
|
.getChildFileSystems()));
|
||||||
|
}
|
||||||
return children.toArray(new FileSystem[]{});
|
return children.toArray(new FileSystem[]{});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -476,10 +476,18 @@ public class TestViewFileSystemOverloadSchemeWithHdfsScheme {
|
||||||
// 2. Two hdfs file systems should be there if no cache.
|
// 2. Two hdfs file systems should be there if no cache.
|
||||||
conf.setBoolean(Constants.CONFIG_VIEWFS_ENABLE_INNER_CACHE, false);
|
conf.setBoolean(Constants.CONFIG_VIEWFS_ENABLE_INNER_CACHE, false);
|
||||||
try (FileSystem vfs = FileSystem.get(conf)) {
|
try (FileSystem vfs = FileSystem.get(conf)) {
|
||||||
Assert.assertEquals(2, vfs.getChildFileSystems().length);
|
Assert.assertEquals(isFallBackExist(conf) ? 3 : 2,
|
||||||
|
vfs.getChildFileSystems().length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// HDFS-15529: if any extended tests added fallback, then getChildFileSystems
|
||||||
|
// will include fallback as well.
|
||||||
|
private boolean isFallBackExist(Configuration config) {
|
||||||
|
return config.get(ConfigUtil.getConfigViewFsPrefix(defaultFSURI
|
||||||
|
.getAuthority()) + "." + Constants.CONFIG_VIEWFS_LINK_FALLBACK) != null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create mount links as follows
|
* Create mount links as follows
|
||||||
* hdfs://localhost:xxx/HDFSUser0 --> hdfs://localhost:xxx/HDFSUser/
|
* hdfs://localhost:xxx/HDFSUser0 --> hdfs://localhost:xxx/HDFSUser/
|
||||||
|
@ -501,7 +509,8 @@ public class TestViewFileSystemOverloadSchemeWithHdfsScheme {
|
||||||
conf.setBoolean(Constants.CONFIG_VIEWFS_ENABLE_INNER_CACHE, false);
|
conf.setBoolean(Constants.CONFIG_VIEWFS_ENABLE_INNER_CACHE, false);
|
||||||
// Two hdfs file systems should be there if no cache.
|
// Two hdfs file systems should be there if no cache.
|
||||||
try (FileSystem vfs = FileSystem.get(conf)) {
|
try (FileSystem vfs = FileSystem.get(conf)) {
|
||||||
Assert.assertEquals(2, vfs.getChildFileSystems().length);
|
Assert.assertEquals(isFallBackExist(conf) ? 3 : 2,
|
||||||
|
vfs.getChildFileSystems().length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -528,7 +537,8 @@ public class TestViewFileSystemOverloadSchemeWithHdfsScheme {
|
||||||
// cache should work.
|
// cache should work.
|
||||||
conf.setBoolean(Constants.CONFIG_VIEWFS_ENABLE_INNER_CACHE, false);
|
conf.setBoolean(Constants.CONFIG_VIEWFS_ENABLE_INNER_CACHE, false);
|
||||||
try (FileSystem vfs = FileSystem.get(conf)) {
|
try (FileSystem vfs = FileSystem.get(conf)) {
|
||||||
Assert.assertEquals(1, vfs.getChildFileSystems().length);
|
Assert.assertEquals(isFallBackExist(conf) ? 2 : 1,
|
||||||
|
vfs.getChildFileSystems().length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue