HDFS-13816. dfs.getQuotaUsage() throws NPE on non-existent dir instead of FileNotFoundException. Contributed by Vinayakumar B.
(cherry picked from commit b098281454
)
This commit is contained in:
parent
07529a209d
commit
0254100074
|
@ -565,6 +565,10 @@ class FSDirStatAndListingOp {
|
|||
fsd.readLock();
|
||||
try {
|
||||
INode targetNode = iip.getLastINode();
|
||||
if (targetNode == null) {
|
||||
throw new FileNotFoundException(
|
||||
"File/Directory does not exist: " + iip.getPath());
|
||||
}
|
||||
QuotaUsage usage = null;
|
||||
if (targetNode.isDirectory()) {
|
||||
DirectoryWithQuotaFeature feature =
|
||||
|
|
|
@ -28,6 +28,7 @@ import static org.junit.Assert.assertTrue;
|
|||
import static org.junit.Assert.fail;
|
||||
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.io.FileNotFoundException;
|
||||
import java.io.IOException;
|
||||
import java.io.OutputStream;
|
||||
import java.io.PrintStream;
|
||||
|
@ -332,6 +333,13 @@ public class TestQuota {
|
|||
// 14a: set quota on a non-existent directory
|
||||
Path nonExistentPath = new Path(dir, "test1");
|
||||
assertFalse(dfs.exists(nonExistentPath));
|
||||
try {
|
||||
compareQuotaUsage(null, dfs, nonExistentPath);
|
||||
fail("Expected FileNotFoundException");
|
||||
} catch (FileNotFoundException fnfe) {
|
||||
GenericTestUtils.assertExceptionContains(
|
||||
"File/Directory does not exist: " + nonExistentPath, fnfe);
|
||||
}
|
||||
args = new String[]{"-setQuota", "1", nonExistentPath.toString()};
|
||||
runCommand(admin, args, true);
|
||||
runCommand(admin, true, "-setSpaceQuota", "1g", // for space quota
|
||||
|
|
Loading…
Reference in New Issue