Author: tgraves
Date: Fri Dec 21 19:06:39 2012
New Revision: 1425095
URL: http://svn.apache.org/viewvc?rev=1425095&view=rev
Log:
HADOOP-9152. HDFS can report negative DFS Used on clusters with very small
amounts of data (Brock Noland via tgraves)
Modified:
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/CHANGES.txt
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/DU.java
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/TestDU.java
Modified:
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/CHANGES.txt
URL:
http://svn.apache.org/viewvc/hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/CHANGES.txt?rev=1425095&r1=1425094&r2=1425095&view=diff
==============================================================================
---
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/CHANGES.txt
(original)
+++
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/CHANGES.txt
Fri Dec 21 19:06:39 2012
@@ -39,6 +39,9 @@ Release 0.23.6 - UNRELEASED
HADOOP-9105. FsShell -moveFromLocal erroneously fails (daryn via bobby)
+ HADOOP-9152. HDFS can report negative DFS Used on clusters with very
+ small amounts of data (Brock Noland via tgraves)
+
Release 0.23.5 - UNRELEASED
INCOMPATIBLE CHANGES
Modified:
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/DU.java
URL:
http://svn.apache.org/viewvc/hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/DU.java?rev=1425095&r1=1425094&r2=1425095&view=diff
==============================================================================
---
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/DU.java
(original)
+++
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/DU.java
Fri Dec 21 19:06:39 2012
@@ -135,7 +135,7 @@ public class DU extends Shell {
}
}
- return used.longValue();
+ return Math.max(used.longValue(), 0L);
}
/**
Modified:
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/TestDU.java
URL:
http://svn.apache.org/viewvc/hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/TestDU.java?rev=1425095&r1=1425094&r2=1425095&view=diff
==============================================================================
---
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/TestDU.java
(original)
+++
hadoop/common/branches/branch-0.23/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/TestDU.java
Fri Dec 21 19:06:39 2012
@@ -101,4 +101,12 @@ public class TestDU extends TestCase {
duSize >= writtenSize &&
writtenSize <= (duSize + slack));
}
+ public void testDUGetUsedWillNotReturnNegative() throws IOException {
+ File file = new File(DU_DIR, "data");
+ assertTrue(file.createNewFile());
+ DU du = new DU(file, 10000);
+ du.decDfsUsed(Long.MAX_VALUE);
+ long duSize = du.getUsed();
+ assertTrue(String.valueOf(duSize), duSize >= 0L);
+ }
}