HADOOP-14255. S3A to delete unnecessary fake directory objects in mkdirs(). Contributed by Mingliang Liu
(cherry picked from commit 507845074970b90330db86bc1ff0124def550bb5)
This commit is contained in:
parent
d77cada182
commit
508389ee54
|
@ -126,4 +126,46 @@ public abstract class AbstractContractMkdirTest extends AbstractFSContractTestBa
|
|||
assertPathExists("check path existence without trailing slash failed",
|
||||
path("testmkdir/b"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testMkdirsPopulatingAllNonexistentAncestors() throws IOException {
|
||||
describe("Verify mkdir will populate all its non-existent ancestors");
|
||||
final FileSystem fs = getFileSystem();
|
||||
|
||||
final Path parent = path("testMkdirsPopulatingAllNonexistentAncestors");
|
||||
assertTrue(fs.mkdirs(parent));
|
||||
assertPathExists(parent + " should exist before making nested dir", parent);
|
||||
|
||||
Path nested = path(parent + "/a/b/c/d/e/f/g/h/i/j/k/L");
|
||||
assertTrue(fs.mkdirs(nested));
|
||||
while (nested != null && !nested.equals(parent) && !nested.isRoot()) {
|
||||
assertPathExists(nested + " nested dir should exist", nested);
|
||||
nested = nested.getParent();
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testMkdirsDoesNotRemoveParentDirectories() throws IOException {
|
||||
describe("Verify mkdir will make its parent existent");
|
||||
final FileSystem fs = getFileSystem();
|
||||
|
||||
final Path parent = path("testMkdirsDoesNotRemoveParentDirectories");
|
||||
assertTrue(fs.mkdirs(parent));
|
||||
|
||||
Path p = parent;
|
||||
for (int i = 0; i < 10; i++) {
|
||||
assertTrue(fs.mkdirs(p));
|
||||
assertPathExists(p + " should exist after mkdir(" + p + ")", p);
|
||||
p = path(p + "/dir-" + i);
|
||||
}
|
||||
|
||||
// After mkdirs(sub-directory), its parent directory still exists
|
||||
p = p.getParent();
|
||||
while (p != null && !p.equals(parent) && !p.isRoot()) {
|
||||
assertPathExists("Path " + p + " should exist", p);
|
||||
assertIsDirectory(p);
|
||||
p = p.getParent();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1524,8 +1524,6 @@ public class S3AFileSystem extends FileSystem {
|
|||
* @throws IOException other IO problems
|
||||
* @throws AmazonClientException on failures inside the AWS SDK
|
||||
*/
|
||||
// TODO: If we have created an empty file at /foo/bar and we then call
|
||||
// mkdirs for /foo/bar/baz/roo what happens to the empty file /foo/bar/?
|
||||
private boolean innerMkdirs(Path f, FsPermission permission)
|
||||
throws IOException, FileAlreadyExistsException, AmazonClientException {
|
||||
LOG.debug("Making directory: {}", f);
|
||||
|
@ -1560,6 +1558,7 @@ public class S3AFileSystem extends FileSystem {
|
|||
|
||||
String key = pathToKey(f);
|
||||
createFakeDirectory(key);
|
||||
deleteUnnecessaryFakeDirectories(f.getParent());
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue