You are viewing a plain text version of this content. The canonical link for it is here.
Posted to common-commits@hadoop.apache.org by da...@apache.org on 2012/11/06 16:57:58 UTC
svn commit: r1406198 - in
/hadoop/common/trunk/hadoop-common-project/hadoop-common/src:
main/java/org/apache/hadoop/fs/shell/Test.java test/resources/testConf.xml
Author: daryn
Date: Tue Nov 6 15:57:58 2012
New Revision: 1406198
URL: http://svn.apache.org/viewvc?rev=1406198&view=rev
Log:
HDFS-1331. dfs -test should work like /bin/test (Andy Isaacson via daryn)
Modified:
hadoop/common/trunk/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/shell/Test.java
hadoop/common/trunk/hadoop-common-project/hadoop-common/src/test/resources/testConf.xml
Modified: hadoop/common/trunk/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/shell/Test.java
URL: http://svn.apache.org/viewvc/hadoop/common/trunk/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/shell/Test.java?rev=1406198&r1=1406197&r2=1406198&view=diff
==============================================================================
--- hadoop/common/trunk/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/shell/Test.java (original)
+++ hadoop/common/trunk/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/shell/Test.java Tue Nov 6 15:57:58 2012
@@ -37,16 +37,21 @@ class Test extends FsCommand {
}
public static final String NAME = "test";
- public static final String USAGE = "-[ezd] <path>";
+ public static final String USAGE = "-[defsz] <path>";
public static final String DESCRIPTION =
- "If file exists, has zero length, is a directory\n" +
- "then return 0, else return 1.";
+ "Answer various questions about <path>, with result via exit status.\n" +
+ " -d return 0 if <path> is a directory.\n" +
+ " -e return 0 if <path> exists.\n" +
+ " -f return 0 if <path> is a file.\n" +
+ " -s return 0 if file <path> is greater than zero bytes in size.\n" +
+ " -z return 0 if file <path> is zero bytes in size.\n" +
+ "else, return 1.";
private char flag;
@Override
protected void processOptions(LinkedList<String> args) {
- CommandFormat cf = new CommandFormat(1, 1, "e", "d", "z");
+ CommandFormat cf = new CommandFormat(1, 1, "e", "d", "f", "s", "z");
cf.parse(args);
String[] opts = cf.getOpts().toArray(new String[0]);
@@ -71,6 +76,12 @@ class Test extends FsCommand {
case 'd':
test = item.stat.isDirectory();
break;
+ case 'f':
+ test = item.stat.isFile();
+ break;
+ case 's':
+ test = (item.stat.getLen() > 0);
+ break;
case 'z':
test = (item.stat.getLen() == 0);
break;
Modified: hadoop/common/trunk/hadoop-common-project/hadoop-common/src/test/resources/testConf.xml
URL: http://svn.apache.org/viewvc/hadoop/common/trunk/hadoop-common-project/hadoop-common/src/test/resources/testConf.xml?rev=1406198&r1=1406197&r2=1406198&view=diff
==============================================================================
--- hadoop/common/trunk/hadoop-common-project/hadoop-common/src/test/resources/testConf.xml (original)
+++ hadoop/common/trunk/hadoop-common-project/hadoop-common/src/test/resources/testConf.xml Tue Nov 6 15:57:58 2012
@@ -591,11 +591,11 @@
<comparators>
<comparator>
<type>RegexpComparator</type>
- <expected-output>^-test -\[ezd\] <path>:\s+If file exists, has zero length, is a directory( )*</expected-output>
+ <expected-output>^-test -\[defsz\] <path>:\sAnswer various questions about <path>, with result via exit status.</expected-output>
</comparator>
<comparator>
<type>RegexpComparator</type>
- <expected-output>^( |\t)*then return 0, else return 1.( )*</expected-output>
+ <expected-output>^( |\t)*else, return 1.( )*</expected-output>
</comparator>
</comparators>
</test>