|
@@ -18,9 +18,10 @@
|
|
package org.apache.hadoop.hdfs.server.namenode;
|
|
package org.apache.hadoop.hdfs.server.namenode;
|
|
|
|
|
|
import static org.apache.hadoop.hdfs.server.common.Util.fileAsURI;
|
|
import static org.apache.hadoop.hdfs.server.common.Util.fileAsURI;
|
|
-
|
|
|
|
-import static org.junit.Assert.*;
|
|
|
|
-
|
|
|
|
|
|
+import static org.junit.Assert.assertEquals;
|
|
|
|
+import static org.junit.Assert.assertNotNull;
|
|
|
|
+import static org.junit.Assert.assertTrue;
|
|
|
|
+import static org.junit.Assert.fail;
|
|
import static org.mockito.Matchers.anyObject;
|
|
import static org.mockito.Matchers.anyObject;
|
|
import static org.mockito.Matchers.anyLong;
|
|
import static org.mockito.Matchers.anyLong;
|
|
import static org.mockito.Mockito.doAnswer;
|
|
import static org.mockito.Mockito.doAnswer;
|
|
@@ -29,21 +30,25 @@ import static org.mockito.Mockito.spy;
|
|
|
|
|
|
import java.io.File;
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
import java.io.IOException;
|
|
|
|
+import java.io.OutputStream;
|
|
|
|
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
import org.apache.commons.logging.LogFactory;
|
|
import org.apache.commons.logging.impl.Log4JLogger;
|
|
import org.apache.commons.logging.impl.Log4JLogger;
|
|
import org.apache.hadoop.conf.Configuration;
|
|
import org.apache.hadoop.conf.Configuration;
|
|
import org.apache.hadoop.fs.FileSystem;
|
|
import org.apache.hadoop.fs.FileSystem;
|
|
|
|
+import org.apache.hadoop.fs.Path;
|
|
import org.apache.hadoop.fs.permission.FsPermission;
|
|
import org.apache.hadoop.fs.permission.FsPermission;
|
|
import org.apache.hadoop.fs.permission.PermissionStatus;
|
|
import org.apache.hadoop.fs.permission.PermissionStatus;
|
|
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
|
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
|
import org.apache.hadoop.hdfs.DFSTestUtil;
|
|
import org.apache.hadoop.hdfs.DFSTestUtil;
|
|
|
|
+import org.apache.hadoop.hdfs.DistributedFileSystem;
|
|
import org.apache.hadoop.hdfs.HdfsConfiguration;
|
|
import org.apache.hadoop.hdfs.HdfsConfiguration;
|
|
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
|
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
|
import org.apache.hadoop.hdfs.protocol.HdfsConstants.SafeModeAction;
|
|
import org.apache.hadoop.hdfs.protocol.HdfsConstants.SafeModeAction;
|
|
import org.apache.hadoop.hdfs.server.common.HdfsServerConstants.NamenodeRole;
|
|
import org.apache.hadoop.hdfs.server.common.HdfsServerConstants.NamenodeRole;
|
|
import org.apache.hadoop.hdfs.server.common.Storage.StorageDirectory;
|
|
import org.apache.hadoop.hdfs.server.common.Storage.StorageDirectory;
|
|
|
|
+import org.apache.hadoop.io.IOUtils;
|
|
import org.apache.log4j.Level;
|
|
import org.apache.log4j.Level;
|
|
import org.junit.Test;
|
|
import org.junit.Test;
|
|
import org.mockito.Mockito;
|
|
import org.mockito.Mockito;
|
|
@@ -475,6 +480,34 @@ public class TestSaveNamespace {
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * Test for save namespace should succeed when parent directory renamed with
|
|
|
|
+ * open lease and destination directory exist.
|
|
|
|
+ * This test is a regression for HDFS-2827
|
|
|
|
+ */
|
|
|
|
+ @Test
|
|
|
|
+ public void testSaveNamespaceWithRenamedLease() throws Exception {
|
|
|
|
+ MiniDFSCluster cluster = new MiniDFSCluster.Builder(new Configuration())
|
|
|
|
+ .numDataNodes(1).build();
|
|
|
|
+ cluster.waitActive();
|
|
|
|
+ DistributedFileSystem fs = (DistributedFileSystem) cluster.getFileSystem();
|
|
|
|
+ OutputStream out = null;
|
|
|
|
+ try {
|
|
|
|
+ fs.mkdirs(new Path("/test-target"));
|
|
|
|
+ out = fs.create(new Path("/test-source/foo")); // don't close
|
|
|
|
+ fs.rename(new Path("/test-source/"), new Path("/test-target/"));
|
|
|
|
+
|
|
|
|
+ fs.setSafeMode(SafeModeAction.SAFEMODE_ENTER);
|
|
|
|
+ cluster.getNameNodeRpc().saveNamespace();
|
|
|
|
+ fs.setSafeMode(SafeModeAction.SAFEMODE_LEAVE);
|
|
|
|
+ } finally {
|
|
|
|
+ IOUtils.cleanup(LOG, out, fs);
|
|
|
|
+ if (cluster != null) {
|
|
|
|
+ cluster.shutdown();
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
private void doAnEdit(FSNamesystem fsn, int id) throws IOException {
|
|
private void doAnEdit(FSNamesystem fsn, int id) throws IOException {
|
|
// Make an edit
|
|
// Make an edit
|
|
fsn.mkdirs(
|
|
fsn.mkdirs(
|