From 31cb5a7fa554f38471f9962cbdc25aabb002b6fd Mon Sep 17 00:00:00 2001 From: Thomas Graves Date: Fri, 17 Aug 2012 21:43:31 +0000 Subject: [PATCH] HADOOP-8695. TestPathData fails intermittently with JDK7 (Trevor Robinson via tgraves) git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1374447 13f79535-47bb-0310-9956-ffa450edef68 --- .../hadoop-common/CHANGES.txt | 3 + .../apache/hadoop/fs/shell/TestPathData.java | 78 +++++++++---------- 2 files changed, 41 insertions(+), 40 deletions(-) diff --git a/hadoop-common-project/hadoop-common/CHANGES.txt b/hadoop-common-project/hadoop-common/CHANGES.txt index 663f4d0f69..c4ec4a783b 100644 --- a/hadoop-common-project/hadoop-common/CHANGES.txt +++ b/hadoop-common-project/hadoop-common/CHANGES.txt @@ -925,6 +925,9 @@ Release 0.23.3 - UNRELEASED HADOOP-8697. TestWritableName fails intermittently with JDK7 (Trevor Robinson via tgraves) + HADOOP-8695. TestPathData fails intermittently with JDK7 (Trevor + Robinson via tgraves) + Release 0.23.2 - UNRELEASED INCOMPATIBLE CHANGES diff --git a/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/shell/TestPathData.java b/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/shell/TestPathData.java index be72f39694..4f3ae6f04e 100644 --- a/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/shell/TestPathData.java +++ b/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/fs/shell/TestPathData.java @@ -26,23 +26,17 @@ import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.Path; -import org.junit.BeforeClass; +import org.junit.After; +import org.junit.Before; import org.junit.Test; public class TestPathData { - protected static Configuration conf; - protected static FileSystem fs; - protected static String dirString; - protected static Path testDir; - protected static PathData item; - - protected static String[] d1Paths = - new String[] { "d1/f1", "d1/f1.1", "d1/f2" }; - protected static String[] d2Paths = - new String[] { "d2/f3" }; - - @BeforeClass - public static void initialize() throws Exception { + protected Configuration conf; + protected FileSystem fs; + protected Path testDir; + + @Before + public void initialize() throws Exception { conf = new Configuration(); fs = FileSystem.getLocal(conf); testDir = new Path( @@ -60,23 +54,28 @@ public static void initialize() throws Exception { fs.create(new Path("d2","f3")); } + @After + public void cleanup() throws Exception { + fs.close(); + } + @Test public void testWithDirStringAndConf() throws Exception { - dirString = "d1"; - item = new PathData(dirString, conf); - checkPathData(); + String dirString = "d1"; + PathData item = new PathData(dirString, conf); + checkPathData(dirString, item); // properly implementing symlink support in various commands will require // trailing slashes to be retained dirString = "d1/"; item = new PathData(dirString, conf); - checkPathData(); + checkPathData(dirString, item); } @Test public void testUnqualifiedUriContents() throws Exception { - dirString = "d1"; - item = new PathData(dirString, conf); + String dirString = "d1"; + PathData item = new PathData(dirString, conf); PathData[] items = item.getDirectoryContents(); assertEquals( sortedString("d1/f1", "d1/f1.1", "d1/f2"), @@ -86,8 +85,8 @@ public void testUnqualifiedUriContents() throws Exception { @Test public void testQualifiedUriContents() throws Exception { - dirString = fs.makeQualified(new Path("d1")).toString(); - item = new PathData(dirString, conf); + String dirString = fs.makeQualified(new Path("d1")).toString(); + PathData item = new PathData(dirString, conf); PathData[] items = item.getDirectoryContents(); assertEquals( sortedString(dirString+"/f1", dirString+"/f1.1", dirString+"/f2"), @@ -97,8 +96,8 @@ public void testQualifiedUriContents() throws Exception { @Test public void testCwdContents() throws Exception { - dirString = Path.CUR_DIR; - item = new PathData(dirString, conf); + String dirString = Path.CUR_DIR; + PathData item = new PathData(dirString, conf); PathData[] items = item.getDirectoryContents(); assertEquals( sortedString("d1", "d2"), @@ -106,17 +105,16 @@ public void testCwdContents() throws Exception { ); } - - @Test - public void testToFile() throws Exception { - item = new PathData(".", conf); + @Test + public void testToFile() throws Exception { + PathData item = new PathData(".", conf); assertEquals(new File(testDir.toString()), item.toFile()); - item = new PathData("d1/f1", conf); - assertEquals(new File(testDir+"/d1/f1"), item.toFile()); - item = new PathData(testDir+"/d1/f1", conf); - assertEquals(new File(testDir+"/d1/f1"), item.toFile()); - } - + item = new PathData("d1/f1", conf); + assertEquals(new File(testDir + "/d1/f1"), item.toFile()); + item = new PathData(testDir + "/d1/f1", conf); + assertEquals(new File(testDir + "/d1/f1"), item.toFile()); + } + @Test public void testAbsoluteGlob() throws Exception { PathData[] items = PathData.expandAsGlob(testDir+"/d1/f1*", conf); @@ -147,18 +145,18 @@ public void testRelativeGlobBack() throws Exception { @Test public void testWithStringAndConfForBuggyPath() throws Exception { - dirString = "file:///tmp"; - testDir = new Path(dirString); - item = new PathData(dirString, conf); + String dirString = "file:///tmp"; + Path tmpDir = new Path(dirString); + PathData item = new PathData(dirString, conf); // this may fail some day if Path is fixed to not crunch the uri // if the authority is null, however we need to test that the PathData // toString() returns the given string, while Path toString() does // the crunching - assertEquals("file:/tmp", testDir.toString()); - checkPathData(); + assertEquals("file:/tmp", tmpDir.toString()); + checkPathData(dirString, item); } - public void checkPathData() throws Exception { + public void checkPathData(String dirString, PathData item) throws Exception { assertEquals("checking fs", fs, item.fs); assertEquals("checking string", dirString, item.toString()); assertEquals("checking path",