From fbf10b26045c512d362f05718b4fc310d6a95a79 Mon Sep 17 00:00:00 2001 From: Suresh Srinivas Date: Sat, 27 Apr 2013 14:47:15 +0000 Subject: [PATCH] HDFS-4740. Fixes for a few test failures on Windows. Contributed by Arpit Agarwal. git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1476596 13f79535-47bb-0310-9956-ffa450edef68 --- hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt | 3 +++ .../org/apache/hadoop/hdfs/TestDFSUtil.java | 26 ++++++++++++------- .../apache/hadoop/hdfs/TestLargeBlock.java | 6 +++-- .../hadoop/hdfs/web/TestWebHdfsUrl.java | 10 +++---- 4 files changed, 28 insertions(+), 17 deletions(-) diff --git a/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt b/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt index 34d5c026b8..fdb0223dce 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt +++ b/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt @@ -317,6 +317,9 @@ Trunk (Unreleased) HDFS-4743. TestNNStorageRetentionManager fails on Windows. (Chris Nauroth via suresh) + HDFS-4740. Fixes for a few test failures on Windows. + (Arpit Agarwal via suresh) + BREAKDOWN OF HDFS-347 SUBTASKS AND RELATED JIRAS HDFS-4353. Encapsulate connections to peers in Peer and PeerServer classes. diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestDFSUtil.java b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestDFSUtil.java index 91a017a236..5143889fb7 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestDFSUtil.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestDFSUtil.java @@ -29,11 +29,11 @@ import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_SECONDARY_HTTP_A import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMENODE_SERVICE_RPC_ADDRESS_KEY; import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMESERVICES; import static org.apache.hadoop.hdfs.DFSConfigKeys.DFS_NAMESERVICE_ID; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertNull; -import static org.junit.Assert.assertTrue; -import static org.junit.Assert.fail; +import org.apache.hadoop.util.Shell; + +import static org.junit.Assert.*; +import org.junit.Assume; +import static org.hamcrest.CoreMatchers.*; import java.io.IOException; import java.net.InetSocketAddress; @@ -619,19 +619,25 @@ public class TestDFSUtil { assertEquals(1, uris.size()); assertTrue(uris.contains(new URI("hdfs://" + NN1_SRVC_ADDR))); + } + + @Test (timeout=15000) + public void testLocalhostReverseLookup() { + // 127.0.0.1 -> localhost reverse resolution does not happen on Windows. + Assume.assumeTrue(!Shell.WINDOWS); // Make sure when config FS_DEFAULT_NAME_KEY using IP address, // it will automatically convert it to hostname - conf = new HdfsConfiguration(); + HdfsConfiguration conf = new HdfsConfiguration(); conf.set(CommonConfigurationKeys.FS_DEFAULT_NAME_KEY, "hdfs://127.0.0.1:8020"); - uris = DFSUtil.getNameServiceUris(conf); + Collection uris = DFSUtil.getNameServiceUris(conf); assertEquals(1, uris.size()); for (URI uri : uris) { - assertFalse(uri.getHost().equals("127.0.0.1")); + assertThat(uri.getHost(), not("127.0.0.1")); } } - - @Test + + @Test (timeout=15000) public void testIsValidName() { assertFalse(DFSUtil.isValidName("/foo/../bar")); assertFalse(DFSUtil.isValidName("/foo/./bar")); diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestLargeBlock.java b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestLargeBlock.java index 64c5ef4c05..cdaf9c7893 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestLargeBlock.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestLargeBlock.java @@ -155,10 +155,12 @@ public class TestLargeBlock { } /** - * Test for block size of 2GB + 512B + * Test for block size of 2GB + 512B. This test can take a rather long time to + * complete on Windows (reading the file back can be slow) so we use a larger + * timeout here. * @throws IOException in case of errors */ - @Test(timeout = 120000) + @Test (timeout = 900000) public void testLargeBlockSize() throws IOException { final long blockSize = 2L * 1024L * 1024L * 1024L + 512L; // 2GB + 512B runTest(blockSize); diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/web/TestWebHdfsUrl.java b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/web/TestWebHdfsUrl.java index 551a37b5c0..b084a630a4 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/web/TestWebHdfsUrl.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/web/TestWebHdfsUrl.java @@ -54,7 +54,7 @@ public class TestWebHdfsUrl { UserGroupInformation.setConfiguration(new Configuration()); } - @Test(timeout=4000) + @Test(timeout=60000) public void testSimpleAuthParamsInUrl() throws IOException { Configuration conf = new Configuration(); @@ -75,7 +75,7 @@ public class TestWebHdfsUrl { fileStatusUrl); } - @Test(timeout=4000) + @Test(timeout=60000) public void testSimpleProxyAuthParamsInUrl() throws IOException { Configuration conf = new Configuration(); @@ -98,7 +98,7 @@ public class TestWebHdfsUrl { fileStatusUrl); } - @Test(timeout=4000) + @Test(timeout=60000) public void testSecureAuthParamsInUrl() throws IOException { Configuration conf = new Configuration(); // fake turning on security so api thinks it should use tokens @@ -178,7 +178,7 @@ public class TestWebHdfsUrl { fileStatusUrl); } - @Test(timeout=4000) + @Test(timeout=60000) public void testSecureProxyAuthParamsInUrl() throws IOException { Configuration conf = new Configuration(); // fake turning on security so api thinks it should use tokens @@ -290,7 +290,7 @@ public class TestWebHdfsUrl { return (WebHdfsFileSystem) FileSystem.get(uri, conf); } - @Test(timeout=4000) + @Test(timeout=60000) public void testSelectHdfsDelegationToken() throws Exception { SecurityUtilTestHelper.setTokenServiceUseIp(true);