HDFS-3711. Manually convert remaining tests to JUnit4. Contributed by Andrew Wang.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/branch-2@1365125 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
74e514f59a
commit
4fdf282b6a
|
@ -170,6 +170,8 @@ Release 2.0.1-alpha - UNRELEASED
|
||||||
|
|
||||||
HDFS-3583. Convert remaining tests to Junit4. (Andrew Wang via atm)
|
HDFS-3583. Convert remaining tests to Junit4. (Andrew Wang via atm)
|
||||||
|
|
||||||
|
HDFS-3711. Manually convert remaining tests to JUnit4. (Andrew Wang via atm)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
HDFS-2982. Startup performance suffers when there are many edit log
|
HDFS-2982. Startup performance suffers when there are many edit log
|
||||||
|
|
|
@ -332,13 +332,12 @@ package org.apache.hadoop.fs;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
public class DemoFiTest extends TestCase {
|
public class DemoFiTest {
|
||||||
public static final String BLOCK_RECEIVER_FAULT="hdfs.datanode.BlockReceiver";
|
public static final String BLOCK_RECEIVER_FAULT="hdfs.datanode.BlockReceiver";
|
||||||
@Override
|
@Override
|
||||||
@Before
|
@Before
|
||||||
public void setUp(){
|
public void setUp() {
|
||||||
//Setting up the test's environment as required
|
//Setting up the test's environment as required
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,10 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.hdfs;
|
package org.apache.hadoop.hdfs;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.DataInputStream;
|
import java.io.DataInputStream;
|
||||||
|
@ -29,8 +33,6 @@ import java.net.Socket;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
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.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
@ -67,7 +69,7 @@ import org.mockito.Mockito;
|
||||||
* This tests data transfer protocol handling in the Datanode. It sends
|
* This tests data transfer protocol handling in the Datanode. It sends
|
||||||
* various forms of wrong data and verifies that Datanode handles it well.
|
* various forms of wrong data and verifies that Datanode handles it well.
|
||||||
*/
|
*/
|
||||||
public class TestDataTransferProtocol extends TestCase {
|
public class TestDataTransferProtocol {
|
||||||
|
|
||||||
private static final Log LOG = LogFactory.getLog(
|
private static final Log LOG = LogFactory.getLog(
|
||||||
"org.apache.hadoop.hdfs.TestDataTransferProtocol");
|
"org.apache.hadoop.hdfs.TestDataTransferProtocol");
|
||||||
|
@ -205,7 +207,8 @@ public class TestDataTransferProtocol extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test public void testOpWrite() throws IOException {
|
@Test
|
||||||
|
public void testOpWrite() throws IOException {
|
||||||
int numDataNodes = 1;
|
int numDataNodes = 1;
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf).numDataNodes(numDataNodes).build();
|
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf).numDataNodes(numDataNodes).build();
|
||||||
|
@ -333,7 +336,8 @@ public class TestDataTransferProtocol extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test public void testDataTransferProtocol() throws IOException {
|
@Test
|
||||||
|
public void testDataTransferProtocol() throws IOException {
|
||||||
Random random = new Random();
|
Random random = new Random();
|
||||||
int oneMil = 1024*1024;
|
int oneMil = 1024*1024;
|
||||||
Path file = new Path("dataprotocol.dat");
|
Path file = new Path("dataprotocol.dat");
|
||||||
|
|
|
@ -16,6 +16,10 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.hdfs;
|
package org.apache.hadoop.hdfs;
|
||||||
|
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 java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
@ -37,13 +41,17 @@ import org.apache.hadoop.io.IOUtils;
|
||||||
import org.apache.hadoop.util.StringUtils;
|
import org.apache.hadoop.util.StringUtils;
|
||||||
import org.apache.log4j.Level;
|
import org.apache.log4j.Level;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Ignore;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class tests the cases of a concurrent reads/writes to a file;
|
* This class tests the cases of a concurrent reads/writes to a file;
|
||||||
* ie, one writer and one or more readers can see unfinsihed blocks
|
* ie, one writer and one or more readers can see unfinsihed blocks
|
||||||
*/
|
*/
|
||||||
public class TestFileConcurrentReader extends junit.framework.TestCase {
|
public class TestFileConcurrentReader {
|
||||||
|
|
||||||
private enum SyncType {
|
private enum SyncType {
|
||||||
SYNC,
|
SYNC,
|
||||||
|
@ -69,18 +77,16 @@ public class TestFileConcurrentReader extends junit.framework.TestCase {
|
||||||
private FileSystem fileSystem;
|
private FileSystem fileSystem;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Before
|
||||||
protected void setUp() throws IOException {
|
public void setUp() throws IOException {
|
||||||
conf = new Configuration();
|
conf = new Configuration();
|
||||||
init(conf);
|
init(conf);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@After
|
||||||
protected void tearDown() throws Exception {
|
public void tearDown() throws Exception {
|
||||||
cluster.shutdown();
|
cluster.shutdown();
|
||||||
cluster = null;
|
cluster = null;
|
||||||
|
|
||||||
super.tearDown();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void init(Configuration conf) throws IOException {
|
private void init(Configuration conf) throws IOException {
|
||||||
|
@ -145,6 +151,7 @@ public class TestFileConcurrentReader extends junit.framework.TestCase {
|
||||||
/**
|
/**
|
||||||
* Test that that writes to an incomplete block are available to a reader
|
* Test that that writes to an incomplete block are available to a reader
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testUnfinishedBlockRead()
|
public void testUnfinishedBlockRead()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
// create a new file in the root, write data, do no close
|
// create a new file in the root, write data, do no close
|
||||||
|
@ -167,6 +174,7 @@ public class TestFileConcurrentReader extends junit.framework.TestCase {
|
||||||
* would result in too small a buffer to do the buffer-copy needed
|
* would result in too small a buffer to do the buffer-copy needed
|
||||||
* for partial chunks.
|
* for partial chunks.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testUnfinishedBlockPacketBufferOverrun() throws IOException {
|
public void testUnfinishedBlockPacketBufferOverrun() throws IOException {
|
||||||
// check that / exists
|
// check that / exists
|
||||||
Path path = new Path("/");
|
Path path = new Path("/");
|
||||||
|
@ -192,6 +200,7 @@ public class TestFileConcurrentReader extends junit.framework.TestCase {
|
||||||
// use a small block size and a large write so that DN is busy creating
|
// use a small block size and a large write so that DN is busy creating
|
||||||
// new blocks. This makes it almost 100% sure we can reproduce
|
// new blocks. This makes it almost 100% sure we can reproduce
|
||||||
// case of client getting a DN that hasn't yet created the blocks
|
// case of client getting a DN that hasn't yet created the blocks
|
||||||
|
@Test
|
||||||
public void testImmediateReadOfNewFile()
|
public void testImmediateReadOfNewFile()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
final int blockSize = 64 * 1024;
|
final int blockSize = 64 * 1024;
|
||||||
|
@ -268,31 +277,39 @@ public class TestFileConcurrentReader extends junit.framework.TestCase {
|
||||||
|
|
||||||
// for some reason, using tranferTo evokes the race condition more often
|
// for some reason, using tranferTo evokes the race condition more often
|
||||||
// so test separately
|
// so test separately
|
||||||
|
@Test
|
||||||
public void testUnfinishedBlockCRCErrorTransferTo() throws IOException {
|
public void testUnfinishedBlockCRCErrorTransferTo() throws IOException {
|
||||||
runTestUnfinishedBlockCRCError(true, SyncType.SYNC, DEFAULT_WRITE_SIZE);
|
runTestUnfinishedBlockCRCError(true, SyncType.SYNC, DEFAULT_WRITE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testUnfinishedBlockCRCErrorTransferToVerySmallWrite()
|
public void testUnfinishedBlockCRCErrorTransferToVerySmallWrite()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
runTestUnfinishedBlockCRCError(true, SyncType.SYNC, SMALL_WRITE_SIZE);
|
runTestUnfinishedBlockCRCError(true, SyncType.SYNC, SMALL_WRITE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// fails due to issue w/append, disable
|
// fails due to issue w/append, disable
|
||||||
|
@Ignore
|
||||||
|
@Test
|
||||||
public void _testUnfinishedBlockCRCErrorTransferToAppend()
|
public void _testUnfinishedBlockCRCErrorTransferToAppend()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
runTestUnfinishedBlockCRCError(true, SyncType.APPEND, DEFAULT_WRITE_SIZE);
|
runTestUnfinishedBlockCRCError(true, SyncType.APPEND, DEFAULT_WRITE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testUnfinishedBlockCRCErrorNormalTransfer() throws IOException {
|
public void testUnfinishedBlockCRCErrorNormalTransfer() throws IOException {
|
||||||
runTestUnfinishedBlockCRCError(false, SyncType.SYNC, DEFAULT_WRITE_SIZE);
|
runTestUnfinishedBlockCRCError(false, SyncType.SYNC, DEFAULT_WRITE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testUnfinishedBlockCRCErrorNormalTransferVerySmallWrite()
|
public void testUnfinishedBlockCRCErrorNormalTransferVerySmallWrite()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
runTestUnfinishedBlockCRCError(false, SyncType.SYNC, SMALL_WRITE_SIZE);
|
runTestUnfinishedBlockCRCError(false, SyncType.SYNC, SMALL_WRITE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// fails due to issue w/append, disable
|
// fails due to issue w/append, disable
|
||||||
|
@Ignore
|
||||||
|
@Test
|
||||||
public void _testUnfinishedBlockCRCErrorNormalTransferAppend()
|
public void _testUnfinishedBlockCRCErrorNormalTransferAppend()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
runTestUnfinishedBlockCRCError(false, SyncType.APPEND, DEFAULT_WRITE_SIZE);
|
runTestUnfinishedBlockCRCError(false, SyncType.APPEND, DEFAULT_WRITE_SIZE);
|
||||||
|
@ -441,4 +458,4 @@ public class TestFileConcurrentReader extends junit.framework.TestCase {
|
||||||
inputStream.close();
|
inputStream.close();
|
||||||
return numRead + startPos - 1;
|
return numRead + startPos - 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,6 +72,7 @@ import org.apache.hadoop.hdfs.server.namenode.LeaseManager;
|
||||||
import org.apache.hadoop.io.IOUtils;
|
import org.apache.hadoop.io.IOUtils;
|
||||||
import org.apache.hadoop.util.Time;
|
import org.apache.hadoop.util.Time;
|
||||||
import org.apache.log4j.Level;
|
import org.apache.log4j.Level;
|
||||||
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -498,6 +499,8 @@ public class TestFileCreation {
|
||||||
* This test is currently not triggered because more HDFS work is
|
* This test is currently not triggered because more HDFS work is
|
||||||
* is needed to handle persistent leases.
|
* is needed to handle persistent leases.
|
||||||
*/
|
*/
|
||||||
|
@Ignore
|
||||||
|
@Test
|
||||||
public void xxxtestFileCreationNamenodeRestart() throws IOException {
|
public void xxxtestFileCreationNamenodeRestart() throws IOException {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
final int MAX_IDLE_TIME = 2000; // 2s
|
final int MAX_IDLE_TIME = 2000; // 2s
|
||||||
|
|
|
@ -80,6 +80,12 @@ import com.google.common.collect.Lists;
|
||||||
* Tests for {@link PBHelper}
|
* Tests for {@link PBHelper}
|
||||||
*/
|
*/
|
||||||
public class TestPBHelper {
|
public class TestPBHelper {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used for asserting equality on doubles.
|
||||||
|
*/
|
||||||
|
private static final double DELTA = 0.000001;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testConvertNamenodeRole() {
|
public void testConvertNamenodeRole() {
|
||||||
assertEquals(NamenodeRoleProto.BACKUP,
|
assertEquals(NamenodeRoleProto.BACKUP,
|
||||||
|
@ -284,11 +290,12 @@ public class TestPBHelper {
|
||||||
private void compare(DatanodeInfo dn1, DatanodeInfo dn2) {
|
private void compare(DatanodeInfo dn1, DatanodeInfo dn2) {
|
||||||
assertEquals(dn1.getAdminState(), dn2.getAdminState());
|
assertEquals(dn1.getAdminState(), dn2.getAdminState());
|
||||||
assertEquals(dn1.getBlockPoolUsed(), dn2.getBlockPoolUsed());
|
assertEquals(dn1.getBlockPoolUsed(), dn2.getBlockPoolUsed());
|
||||||
assertEquals(dn1.getBlockPoolUsedPercent(), dn2.getBlockPoolUsedPercent());
|
assertEquals(dn1.getBlockPoolUsedPercent(),
|
||||||
|
dn2.getBlockPoolUsedPercent(), DELTA);
|
||||||
assertEquals(dn1.getCapacity(), dn2.getCapacity());
|
assertEquals(dn1.getCapacity(), dn2.getCapacity());
|
||||||
assertEquals(dn1.getDatanodeReport(), dn2.getDatanodeReport());
|
assertEquals(dn1.getDatanodeReport(), dn2.getDatanodeReport());
|
||||||
assertEquals(dn1.getDfsUsed(), dn1.getDfsUsed());
|
assertEquals(dn1.getDfsUsed(), dn1.getDfsUsed());
|
||||||
assertEquals(dn1.getDfsUsedPercent(), dn1.getDfsUsedPercent());
|
assertEquals(dn1.getDfsUsedPercent(), dn1.getDfsUsedPercent(), DELTA);
|
||||||
assertEquals(dn1.getIpAddr(), dn2.getIpAddr());
|
assertEquals(dn1.getIpAddr(), dn2.getIpAddr());
|
||||||
assertEquals(dn1.getHostName(), dn2.getHostName());
|
assertEquals(dn1.getHostName(), dn2.getHostName());
|
||||||
assertEquals(dn1.getInfoPort(), dn2.getInfoPort());
|
assertEquals(dn1.getInfoPort(), dn2.getInfoPort());
|
||||||
|
|
|
@ -17,13 +17,16 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.hdfs.server.datanode;
|
package org.apache.hadoop.hdfs.server.datanode;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
import java.io.DataInputStream;
|
import java.io.DataInputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.hdfs.HdfsConfiguration;
|
import org.apache.hadoop.hdfs.HdfsConfiguration;
|
||||||
import org.apache.hadoop.hdfs.protocol.Block;
|
import org.apache.hadoop.hdfs.protocol.Block;
|
||||||
|
@ -33,27 +36,23 @@ import org.apache.hadoop.hdfs.server.datanode.fsdataset.FsDatasetSpi;
|
||||||
import org.apache.hadoop.hdfs.server.datanode.fsdataset.ReplicaOutputStreams;
|
import org.apache.hadoop.hdfs.server.datanode.fsdataset.ReplicaOutputStreams;
|
||||||
import org.apache.hadoop.hdfs.server.datanode.fsdataset.impl.FsDatasetFactory;
|
import org.apache.hadoop.hdfs.server.datanode.fsdataset.impl.FsDatasetFactory;
|
||||||
import org.apache.hadoop.util.DataChecksum;
|
import org.apache.hadoop.util.DataChecksum;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* this class tests the methods of the SimulatedFSDataset.
|
* this class tests the methods of the SimulatedFSDataset.
|
||||||
*/
|
*/
|
||||||
public class TestSimulatedFSDataset extends TestCase {
|
public class TestSimulatedFSDataset {
|
||||||
Configuration conf = null;
|
Configuration conf = null;
|
||||||
static final String bpid = "BP-TEST";
|
static final String bpid = "BP-TEST";
|
||||||
static final int NUMBLOCKS = 20;
|
static final int NUMBLOCKS = 20;
|
||||||
static final int BLOCK_LENGTH_MULTIPLIER = 79;
|
static final int BLOCK_LENGTH_MULTIPLIER = 79;
|
||||||
|
|
||||||
@Override
|
@Before
|
||||||
protected void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
super.setUp();
|
|
||||||
conf = new HdfsConfiguration();
|
conf = new HdfsConfiguration();
|
||||||
SimulatedFSDataset.setFactory(conf);
|
SimulatedFSDataset.setFactory(conf);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void tearDown() throws Exception {
|
|
||||||
super.tearDown();
|
|
||||||
}
|
|
||||||
|
|
||||||
long blockIdToLen(long blkid) {
|
long blockIdToLen(long blkid) {
|
||||||
return blkid*BLOCK_LENGTH_MULTIPLIER;
|
return blkid*BLOCK_LENGTH_MULTIPLIER;
|
||||||
|
@ -90,6 +89,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
return addSomeBlocks(fsdataset, 1);
|
return addSomeBlocks(fsdataset, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testFSDatasetFactory() {
|
public void testFSDatasetFactory() {
|
||||||
final Configuration conf = new Configuration();
|
final Configuration conf = new Configuration();
|
||||||
FsDatasetSpi.Factory<?> f = FsDatasetSpi.Factory.getFactory(conf);
|
FsDatasetSpi.Factory<?> f = FsDatasetSpi.Factory.getFactory(conf);
|
||||||
|
@ -102,6 +102,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
assertTrue(s.isSimulated());
|
assertTrue(s.isSimulated());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testGetMetaData() throws IOException {
|
public void testGetMetaData() throws IOException {
|
||||||
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
ExtendedBlock b = new ExtendedBlock(bpid, 1, 5, 0);
|
ExtendedBlock b = new ExtendedBlock(bpid, 1, 5, 0);
|
||||||
|
@ -123,6 +124,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testStorageUsage() throws IOException {
|
public void testStorageUsage() throws IOException {
|
||||||
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
assertEquals(fsdataset.getDfsUsed(), 0);
|
assertEquals(fsdataset.getDfsUsed(), 0);
|
||||||
|
@ -146,6 +148,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
assertEquals(expectedLen, lengthRead);
|
assertEquals(expectedLen, lengthRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testWriteRead() throws IOException {
|
public void testWriteRead() throws IOException {
|
||||||
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
addSomeBlocks(fsdataset);
|
addSomeBlocks(fsdataset);
|
||||||
|
@ -157,6 +160,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testGetBlockReport() throws IOException {
|
public void testGetBlockReport() throws IOException {
|
||||||
SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
BlockListAsLongs blockReport = fsdataset.getBlockReport(bpid);
|
BlockListAsLongs blockReport = fsdataset.getBlockReport(bpid);
|
||||||
|
@ -170,6 +174,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testInjectionEmpty() throws IOException {
|
public void testInjectionEmpty() throws IOException {
|
||||||
SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
BlockListAsLongs blockReport = fsdataset.getBlockReport(bpid);
|
BlockListAsLongs blockReport = fsdataset.getBlockReport(bpid);
|
||||||
|
@ -198,6 +203,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
assertEquals(sfsdataset.getCapacity()-bytesAdded, sfsdataset.getRemaining());
|
assertEquals(sfsdataset.getCapacity()-bytesAdded, sfsdataset.getRemaining());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testInjectionNonEmpty() throws IOException {
|
public void testInjectionNonEmpty() throws IOException {
|
||||||
SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
BlockListAsLongs blockReport = fsdataset.getBlockReport(bpid);
|
BlockListAsLongs blockReport = fsdataset.getBlockReport(bpid);
|
||||||
|
@ -271,6 +277,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testInValidBlocks() throws IOException {
|
public void testInValidBlocks() throws IOException {
|
||||||
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
ExtendedBlock b = new ExtendedBlock(bpid, 1, 5, 0);
|
ExtendedBlock b = new ExtendedBlock(bpid, 1, 5, 0);
|
||||||
|
@ -282,6 +289,7 @@ public class TestSimulatedFSDataset extends TestCase {
|
||||||
checkInvalidBlock(b);
|
checkInvalidBlock(b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testInvalidate() throws IOException {
|
public void testInvalidate() throws IOException {
|
||||||
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
final SimulatedFSDataset fsdataset = getSimulatedFSDataset();
|
||||||
int bytesAdded = addSomeBlocks(fsdataset);
|
int bytesAdded = addSomeBlocks(fsdataset);
|
||||||
|
|
|
@ -20,6 +20,12 @@ 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.apache.hadoop.hdfs.server.namenode.FSImageTestUtil.assertNNHasCheckpoints;
|
import static org.apache.hadoop.hdfs.server.namenode.FSImageTestUtil.assertNNHasCheckpoints;
|
||||||
import static org.apache.hadoop.hdfs.server.namenode.FSImageTestUtil.getNameNodeCurrentDirs;
|
import static org.apache.hadoop.hdfs.server.namenode.FSImageTestUtil.getNameNodeCurrentDirs;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.assertNull;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -31,8 +37,6 @@ import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
import org.apache.commons.cli.ParseException;
|
import org.apache.commons.cli.ParseException;
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
@ -69,6 +73,8 @@ import org.apache.hadoop.test.GenericTestUtils.DelayAnswer;
|
||||||
import org.apache.hadoop.test.GenericTestUtils.LogCapturer;
|
import org.apache.hadoop.test.GenericTestUtils.LogCapturer;
|
||||||
import org.apache.hadoop.util.StringUtils;
|
import org.apache.hadoop.util.StringUtils;
|
||||||
import org.apache.log4j.Level;
|
import org.apache.log4j.Level;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
import org.mockito.ArgumentMatcher;
|
import org.mockito.ArgumentMatcher;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
import org.mockito.invocation.InvocationOnMock;
|
import org.mockito.invocation.InvocationOnMock;
|
||||||
|
@ -84,7 +90,7 @@ import com.google.common.primitives.Ints;
|
||||||
/**
|
/**
|
||||||
* This class tests the creation and validation of a checkpoint.
|
* This class tests the creation and validation of a checkpoint.
|
||||||
*/
|
*/
|
||||||
public class TestCheckpoint extends TestCase {
|
public class TestCheckpoint {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
((Log4JLogger)FSImage.LOG).getLogger().setLevel(Level.ALL);
|
((Log4JLogger)FSImage.LOG).getLogger().setLevel(Level.ALL);
|
||||||
|
@ -100,7 +106,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
|
|
||||||
private CheckpointFaultInjector faultInjector;
|
private CheckpointFaultInjector faultInjector;
|
||||||
|
|
||||||
@Override
|
@Before
|
||||||
public void setUp() throws IOException {
|
public void setUp() throws IOException {
|
||||||
FileUtil.fullyDeleteContents(new File(MiniDFSCluster.getBaseDirectory()));
|
FileUtil.fullyDeleteContents(new File(MiniDFSCluster.getBaseDirectory()));
|
||||||
|
|
||||||
|
@ -139,6 +145,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/*
|
/*
|
||||||
* Verify that namenode does not startup if one namedir is bad.
|
* Verify that namenode does not startup if one namedir is bad.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testNameDirError() throws IOException {
|
public void testNameDirError() throws IOException {
|
||||||
LOG.info("Starting testNameDirError");
|
LOG.info("Starting testNameDirError");
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
@ -180,6 +187,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* correctly (by removing the storage directory)
|
* correctly (by removing the storage directory)
|
||||||
* See https://issues.apache.org/jira/browse/HDFS-2011
|
* See https://issues.apache.org/jira/browse/HDFS-2011
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testWriteTransactionIdHandlesIOE() throws Exception {
|
public void testWriteTransactionIdHandlesIOE() throws Exception {
|
||||||
LOG.info("Check IOException handled correctly by writeTransactionIdFile");
|
LOG.info("Check IOException handled correctly by writeTransactionIdFile");
|
||||||
ArrayList<URI> fsImageDirs = new ArrayList<URI>();
|
ArrayList<URI> fsImageDirs = new ArrayList<URI>();
|
||||||
|
@ -214,6 +222,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/*
|
/*
|
||||||
* Simulate namenode crashing after rolling edit log.
|
* Simulate namenode crashing after rolling edit log.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryNamenodeError1()
|
public void testSecondaryNamenodeError1()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
LOG.info("Starting testSecondaryNamenodeError1");
|
LOG.info("Starting testSecondaryNamenodeError1");
|
||||||
|
@ -279,6 +288,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/*
|
/*
|
||||||
* Simulate a namenode crash after uploading new image
|
* Simulate a namenode crash after uploading new image
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryNamenodeError2() throws IOException {
|
public void testSecondaryNamenodeError2() throws IOException {
|
||||||
LOG.info("Starting testSecondaryNamenodeError2");
|
LOG.info("Starting testSecondaryNamenodeError2");
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
@ -340,6 +350,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/*
|
/*
|
||||||
* Simulate a secondary namenode crash after rolling the edit log.
|
* Simulate a secondary namenode crash after rolling the edit log.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryNamenodeError3() throws IOException {
|
public void testSecondaryNamenodeError3() throws IOException {
|
||||||
LOG.info("Starting testSecondaryNamenodeError3");
|
LOG.info("Starting testSecondaryNamenodeError3");
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
@ -412,6 +423,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* back to the name-node.
|
* back to the name-node.
|
||||||
* Used to truncate primary fsimage file.
|
* Used to truncate primary fsimage file.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryFailsToReturnImage() throws IOException {
|
public void testSecondaryFailsToReturnImage() throws IOException {
|
||||||
Mockito.doThrow(new IOException("If this exception is not caught by the " +
|
Mockito.doThrow(new IOException("If this exception is not caught by the " +
|
||||||
"name-node, fs image will be truncated."))
|
"name-node, fs image will be truncated."))
|
||||||
|
@ -425,6 +437,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* before even setting the length header. This used to cause image
|
* before even setting the length header. This used to cause image
|
||||||
* truncation. Regression test for HDFS-3330.
|
* truncation. Regression test for HDFS-3330.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryFailsWithErrorBeforeSettingHeaders()
|
public void testSecondaryFailsWithErrorBeforeSettingHeaders()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
Mockito.doThrow(new Error("If this exception is not caught by the " +
|
Mockito.doThrow(new Error("If this exception is not caught by the " +
|
||||||
|
@ -497,6 +510,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* The length header in the HTTP transfer should prevent
|
* The length header in the HTTP transfer should prevent
|
||||||
* this from corrupting the NN.
|
* this from corrupting the NN.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testNameNodeImageSendFailWrongSize()
|
public void testNameNodeImageSendFailWrongSize()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
LOG.info("Starting testNameNodeImageSendFailWrongSize");
|
LOG.info("Starting testNameNodeImageSendFailWrongSize");
|
||||||
|
@ -511,6 +525,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* The digest header in the HTTP transfer should prevent
|
* The digest header in the HTTP transfer should prevent
|
||||||
* this from corrupting the NN.
|
* this from corrupting the NN.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testNameNodeImageSendFailWrongDigest()
|
public void testNameNodeImageSendFailWrongDigest()
|
||||||
throws IOException {
|
throws IOException {
|
||||||
LOG.info("Starting testNameNodeImageSendFailWrongDigest");
|
LOG.info("Starting testNameNodeImageSendFailWrongDigest");
|
||||||
|
@ -528,7 +543,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
private void doSendFailTest(String exceptionSubstring)
|
private void doSendFailTest(String exceptionSubstring)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
Path file1 = new Path("checkpoint-doSendFailTest-" + getName() + ".dat");
|
Path file1 = new Path("checkpoint-doSendFailTest-doSendFailTest.dat");
|
||||||
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf)
|
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf)
|
||||||
.numDataNodes(numDatanodes)
|
.numDataNodes(numDatanodes)
|
||||||
.build();
|
.build();
|
||||||
|
@ -574,6 +589,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* Test that the NN locks its storage and edits directories, and won't start up
|
* Test that the NN locks its storage and edits directories, and won't start up
|
||||||
* if the directories are already locked
|
* if the directories are already locked
|
||||||
**/
|
**/
|
||||||
|
@Test
|
||||||
public void testNameDirLocking() throws IOException {
|
public void testNameDirLocking() throws IOException {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf)
|
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf)
|
||||||
|
@ -603,6 +619,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* Test that, if the edits dir is separate from the name dir, it is
|
* Test that, if the edits dir is separate from the name dir, it is
|
||||||
* properly locked.
|
* properly locked.
|
||||||
**/
|
**/
|
||||||
|
@Test
|
||||||
public void testSeparateEditsDirLocking() throws IOException {
|
public void testSeparateEditsDirLocking() throws IOException {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
File editsDir = new File(MiniDFSCluster.getBaseDirectory() +
|
File editsDir = new File(MiniDFSCluster.getBaseDirectory() +
|
||||||
|
@ -638,6 +655,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/**
|
/**
|
||||||
* Test that the SecondaryNameNode properly locks its storage directories.
|
* Test that the SecondaryNameNode properly locks its storage directories.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryNameNodeLocking() throws Exception {
|
public void testSecondaryNameNodeLocking() throws Exception {
|
||||||
// Start a primary NN so that the secondary will start successfully
|
// Start a primary NN so that the secondary will start successfully
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
@ -687,6 +705,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* Test that, an attempt to lock a storage that is already locked by a nodename,
|
* Test that, an attempt to lock a storage that is already locked by a nodename,
|
||||||
* logs error message that includes JVM name of the namenode that locked it.
|
* logs error message that includes JVM name of the namenode that locked it.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testStorageAlreadyLockedErrorMessage() throws Exception {
|
public void testStorageAlreadyLockedErrorMessage() throws Exception {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf)
|
MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf)
|
||||||
|
@ -763,6 +782,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* 2. if the NN does not contain an image, importing a checkpoint
|
* 2. if the NN does not contain an image, importing a checkpoint
|
||||||
* succeeds and re-saves the image
|
* succeeds and re-saves the image
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testImportCheckpoint() throws Exception {
|
public void testImportCheckpoint() throws Exception {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
Path testPath = new Path("/testfile");
|
Path testPath = new Path("/testfile");
|
||||||
|
@ -861,6 +881,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/**
|
/**
|
||||||
* Tests checkpoint in HDFS.
|
* Tests checkpoint in HDFS.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testCheckpoint() throws IOException {
|
public void testCheckpoint() throws IOException {
|
||||||
Path file1 = new Path("checkpoint.dat");
|
Path file1 = new Path("checkpoint.dat");
|
||||||
Path file2 = new Path("checkpoint2.dat");
|
Path file2 = new Path("checkpoint2.dat");
|
||||||
|
@ -951,6 +972,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/**
|
/**
|
||||||
* Tests save namespace.
|
* Tests save namespace.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSaveNamespace() throws IOException {
|
public void testSaveNamespace() throws IOException {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
DistributedFileSystem fs = null;
|
DistributedFileSystem fs = null;
|
||||||
|
@ -1057,6 +1079,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
|
|
||||||
/* Test case to test CheckpointSignature */
|
/* Test case to test CheckpointSignature */
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testCheckpointSignature() throws IOException {
|
public void testCheckpointSignature() throws IOException {
|
||||||
|
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
|
@ -1091,6 +1114,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* - it then fails again for the same reason
|
* - it then fails again for the same reason
|
||||||
* - it then tries to checkpoint a third time
|
* - it then tries to checkpoint a third time
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testCheckpointAfterTwoFailedUploads() throws IOException {
|
public void testCheckpointAfterTwoFailedUploads() throws IOException {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
SecondaryNameNode secondary = null;
|
SecondaryNameNode secondary = null;
|
||||||
|
@ -1147,6 +1171,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
*
|
*
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testMultipleSecondaryNamenodes() throws IOException {
|
public void testMultipleSecondaryNamenodes() throws IOException {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
String nameserviceId1 = "ns1";
|
String nameserviceId1 = "ns1";
|
||||||
|
@ -1197,6 +1222,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* Test that the secondary doesn't have to re-download image
|
* Test that the secondary doesn't have to re-download image
|
||||||
* if it hasn't changed.
|
* if it hasn't changed.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryImageDownload() throws IOException {
|
public void testSecondaryImageDownload() throws IOException {
|
||||||
LOG.info("Starting testSecondaryImageDownload");
|
LOG.info("Starting testSecondaryImageDownload");
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
@ -1279,6 +1305,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* It verifies that this works even though the earlier-txid checkpoint gets
|
* It verifies that this works even though the earlier-txid checkpoint gets
|
||||||
* uploaded after the later-txid checkpoint.
|
* uploaded after the later-txid checkpoint.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testMultipleSecondaryNNsAgainstSameNN() throws Exception {
|
public void testMultipleSecondaryNNsAgainstSameNN() throws Exception {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
|
||||||
|
@ -1364,6 +1391,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* It verifies that one of the two gets an error that it's uploading a
|
* It verifies that one of the two gets an error that it's uploading a
|
||||||
* duplicate checkpoint, and the other one succeeds.
|
* duplicate checkpoint, and the other one succeeds.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testMultipleSecondaryNNsAgainstSameNN2() throws Exception {
|
public void testMultipleSecondaryNNsAgainstSameNN2() throws Exception {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
|
|
||||||
|
@ -1457,6 +1485,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* is running. The secondary should shut itself down if if talks to a NN
|
* is running. The secondary should shut itself down if if talks to a NN
|
||||||
* with the wrong namespace.
|
* with the wrong namespace.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testReformatNNBetweenCheckpoints() throws IOException {
|
public void testReformatNNBetweenCheckpoints() throws IOException {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
SecondaryNameNode secondary = null;
|
SecondaryNameNode secondary = null;
|
||||||
|
@ -1514,6 +1543,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* Test that the primary NN will not serve any files to a 2NN who doesn't
|
* Test that the primary NN will not serve any files to a 2NN who doesn't
|
||||||
* share its namespace ID, and also will not accept any files from one.
|
* share its namespace ID, and also will not accept any files from one.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testNamespaceVerifiedOnFileTransfer() throws IOException {
|
public void testNamespaceVerifiedOnFileTransfer() throws IOException {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
|
|
||||||
|
@ -1575,6 +1605,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* the non-failed storage directory receives the checkpoint.
|
* the non-failed storage directory receives the checkpoint.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testCheckpointWithFailedStorageDir() throws Exception {
|
public void testCheckpointWithFailedStorageDir() throws Exception {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
SecondaryNameNode secondary = null;
|
SecondaryNameNode secondary = null;
|
||||||
|
@ -1639,6 +1670,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testCheckpointWithSeparateDirsAfterNameFails() throws Exception {
|
public void testCheckpointWithSeparateDirsAfterNameFails() throws Exception {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
SecondaryNameNode secondary = null;
|
SecondaryNameNode secondary = null;
|
||||||
|
@ -1711,6 +1743,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
/**
|
/**
|
||||||
* Test that the 2NN triggers a checkpoint after the configurable interval
|
* Test that the 2NN triggers a checkpoint after the configurable interval
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testCheckpointTriggerOnTxnCount() throws Exception {
|
public void testCheckpointTriggerOnTxnCount() throws Exception {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
SecondaryNameNode secondary = null;
|
SecondaryNameNode secondary = null;
|
||||||
|
@ -1764,6 +1797,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
* logs that connect the 2NN's old checkpoint to the current txid
|
* logs that connect the 2NN's old checkpoint to the current txid
|
||||||
* get archived. Then, the 2NN tries to checkpoint again.
|
* get archived. Then, the 2NN tries to checkpoint again.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testSecondaryHasVeryOutOfDateImage() throws IOException {
|
public void testSecondaryHasVeryOutOfDateImage() throws IOException {
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
SecondaryNameNode secondary = null;
|
SecondaryNameNode secondary = null;
|
||||||
|
@ -1801,6 +1835,7 @@ public class TestCheckpoint extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testCommandLineParsing() throws ParseException {
|
public void testCommandLineParsing() throws ParseException {
|
||||||
SecondaryNameNode.CommandLineOpts opts =
|
SecondaryNameNode.CommandLineOpts opts =
|
||||||
new SecondaryNameNode.CommandLineOpts();
|
new SecondaryNameNode.CommandLineOpts();
|
||||||
|
|
|
@ -29,8 +29,6 @@ import java.util.Map;
|
||||||
import javax.management.MBeanServer;
|
import javax.management.MBeanServer;
|
||||||
import javax.management.ObjectName;
|
import javax.management.ObjectName;
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.fs.FileUtil;
|
import org.apache.hadoop.fs.FileUtil;
|
||||||
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
||||||
|
@ -42,6 +40,12 @@ import org.mortbay.util.ajax.JSON;
|
||||||
* Class for testing {@link NameNodeMXBean} implementation
|
* Class for testing {@link NameNodeMXBean} implementation
|
||||||
*/
|
*/
|
||||||
public class TestNameNodeMXBean {
|
public class TestNameNodeMXBean {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used to assert equality between doubles
|
||||||
|
*/
|
||||||
|
private static final double DELTA = 0.000001;
|
||||||
|
|
||||||
@SuppressWarnings({ "unchecked", "deprecation" })
|
@SuppressWarnings({ "unchecked", "deprecation" })
|
||||||
@Test
|
@Test
|
||||||
public void testNameNodeMXBeanInfo() throws Exception {
|
public void testNameNodeMXBeanInfo() throws Exception {
|
||||||
|
@ -59,36 +63,36 @@ public class TestNameNodeMXBean {
|
||||||
"Hadoop:service=NameNode,name=NameNodeInfo");
|
"Hadoop:service=NameNode,name=NameNodeInfo");
|
||||||
// get attribute "ClusterId"
|
// get attribute "ClusterId"
|
||||||
String clusterId = (String) mbs.getAttribute(mxbeanName, "ClusterId");
|
String clusterId = (String) mbs.getAttribute(mxbeanName, "ClusterId");
|
||||||
Assert.assertEquals(fsn.getClusterId(), clusterId);
|
assertEquals(fsn.getClusterId(), clusterId);
|
||||||
// get attribute "BlockPoolId"
|
// get attribute "BlockPoolId"
|
||||||
String blockpoolId = (String) mbs.getAttribute(mxbeanName,
|
String blockpoolId = (String) mbs.getAttribute(mxbeanName,
|
||||||
"BlockPoolId");
|
"BlockPoolId");
|
||||||
Assert.assertEquals(fsn.getBlockPoolId(), blockpoolId);
|
assertEquals(fsn.getBlockPoolId(), blockpoolId);
|
||||||
// get attribute "Version"
|
// get attribute "Version"
|
||||||
String version = (String) mbs.getAttribute(mxbeanName, "Version");
|
String version = (String) mbs.getAttribute(mxbeanName, "Version");
|
||||||
Assert.assertEquals(fsn.getVersion(), version);
|
assertEquals(fsn.getVersion(), version);
|
||||||
Assert.assertTrue(version.equals(VersionInfo.getVersion()
|
assertTrue(version.equals(VersionInfo.getVersion()
|
||||||
+ ", r" + VersionInfo.getRevision()));
|
+ ", r" + VersionInfo.getRevision()));
|
||||||
// get attribute "Used"
|
// get attribute "Used"
|
||||||
Long used = (Long) mbs.getAttribute(mxbeanName, "Used");
|
Long used = (Long) mbs.getAttribute(mxbeanName, "Used");
|
||||||
Assert.assertEquals(fsn.getUsed(), used.longValue());
|
assertEquals(fsn.getUsed(), used.longValue());
|
||||||
// get attribute "Total"
|
// get attribute "Total"
|
||||||
Long total = (Long) mbs.getAttribute(mxbeanName, "Total");
|
Long total = (Long) mbs.getAttribute(mxbeanName, "Total");
|
||||||
Assert.assertEquals(fsn.getTotal(), total.longValue());
|
assertEquals(fsn.getTotal(), total.longValue());
|
||||||
// get attribute "safemode"
|
// get attribute "safemode"
|
||||||
String safemode = (String) mbs.getAttribute(mxbeanName, "Safemode");
|
String safemode = (String) mbs.getAttribute(mxbeanName, "Safemode");
|
||||||
Assert.assertEquals(fsn.getSafemode(), safemode);
|
assertEquals(fsn.getSafemode(), safemode);
|
||||||
// get attribute nondfs
|
// get attribute nondfs
|
||||||
Long nondfs = (Long) (mbs.getAttribute(mxbeanName, "NonDfsUsedSpace"));
|
Long nondfs = (Long) (mbs.getAttribute(mxbeanName, "NonDfsUsedSpace"));
|
||||||
Assert.assertEquals(fsn.getNonDfsUsedSpace(), nondfs.longValue());
|
assertEquals(fsn.getNonDfsUsedSpace(), nondfs.longValue());
|
||||||
// get attribute percentremaining
|
// get attribute percentremaining
|
||||||
Float percentremaining = (Float) (mbs.getAttribute(mxbeanName,
|
Float percentremaining = (Float) (mbs.getAttribute(mxbeanName,
|
||||||
"PercentRemaining"));
|
"PercentRemaining"));
|
||||||
Assert.assertEquals(fsn.getPercentRemaining(), percentremaining
|
assertEquals(fsn.getPercentRemaining(), percentremaining
|
||||||
.floatValue());
|
.floatValue(), DELTA);
|
||||||
// get attribute Totalblocks
|
// get attribute Totalblocks
|
||||||
Long totalblocks = (Long) (mbs.getAttribute(mxbeanName, "TotalBlocks"));
|
Long totalblocks = (Long) (mbs.getAttribute(mxbeanName, "TotalBlocks"));
|
||||||
Assert.assertEquals(fsn.getTotalBlocks(), totalblocks.longValue());
|
assertEquals(fsn.getTotalBlocks(), totalblocks.longValue());
|
||||||
// get attribute alivenodeinfo
|
// get attribute alivenodeinfo
|
||||||
String alivenodeinfo = (String) (mbs.getAttribute(mxbeanName,
|
String alivenodeinfo = (String) (mbs.getAttribute(mxbeanName,
|
||||||
"LiveNodes"));
|
"LiveNodes"));
|
||||||
|
@ -103,15 +107,15 @@ public class TestNameNodeMXBean {
|
||||||
assertTrue(liveNode.containsKey("numBlocks"));
|
assertTrue(liveNode.containsKey("numBlocks"));
|
||||||
assertTrue(((Long)liveNode.get("numBlocks")) == 0);
|
assertTrue(((Long)liveNode.get("numBlocks")) == 0);
|
||||||
}
|
}
|
||||||
Assert.assertEquals(fsn.getLiveNodes(), alivenodeinfo);
|
assertEquals(fsn.getLiveNodes(), alivenodeinfo);
|
||||||
// get attribute deadnodeinfo
|
// get attribute deadnodeinfo
|
||||||
String deadnodeinfo = (String) (mbs.getAttribute(mxbeanName,
|
String deadnodeinfo = (String) (mbs.getAttribute(mxbeanName,
|
||||||
"DeadNodes"));
|
"DeadNodes"));
|
||||||
Assert.assertEquals(fsn.getDeadNodes(), deadnodeinfo);
|
assertEquals(fsn.getDeadNodes(), deadnodeinfo);
|
||||||
// get attribute NameDirStatuses
|
// get attribute NameDirStatuses
|
||||||
String nameDirStatuses = (String) (mbs.getAttribute(mxbeanName,
|
String nameDirStatuses = (String) (mbs.getAttribute(mxbeanName,
|
||||||
"NameDirStatuses"));
|
"NameDirStatuses"));
|
||||||
Assert.assertEquals(fsn.getNameDirStatuses(), nameDirStatuses);
|
assertEquals(fsn.getNameDirStatuses(), nameDirStatuses);
|
||||||
Map<String, Map<String, String>> statusMap =
|
Map<String, Map<String, String>> statusMap =
|
||||||
(Map<String, Map<String, String>>) JSON.parse(nameDirStatuses);
|
(Map<String, Map<String, String>>) JSON.parse(nameDirStatuses);
|
||||||
Collection<URI> nameDirUris = cluster.getNameDirs(0);
|
Collection<URI> nameDirUris = cluster.getNameDirs(0);
|
||||||
|
|
|
@ -26,8 +26,6 @@ import java.io.File;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import junit.framework.AssertionFailedError;
|
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.fs.FileStatus;
|
import org.apache.hadoop.fs.FileStatus;
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
|
@ -132,7 +130,7 @@ public class TestParallelImageWrite {
|
||||||
* @param fsn - the FSNamesystem being checked.
|
* @param fsn - the FSNamesystem being checked.
|
||||||
* @param numImageDirs - the configured number of StorageDirectory of type IMAGE.
|
* @param numImageDirs - the configured number of StorageDirectory of type IMAGE.
|
||||||
* @return - the md5 hash of the most recent FSImage files, which must all be the same.
|
* @return - the md5 hash of the most recent FSImage files, which must all be the same.
|
||||||
* @throws AssertionFailedError if image files are empty or different,
|
* @throws AssertionError if image files are empty or different,
|
||||||
* if less than two StorageDirectory are provided, or if the
|
* if less than two StorageDirectory are provided, or if the
|
||||||
* actual number of StorageDirectory is less than configured.
|
* actual number of StorageDirectory is less than configured.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -18,8 +18,8 @@
|
||||||
|
|
||||||
package org.apache.hadoop.hdfs.server.namenode;
|
package org.apache.hadoop.hdfs.server.namenode;
|
||||||
|
|
||||||
import static junit.framework.Assert.assertTrue;
|
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
import static org.junit.Assert.fail;
|
import static org.junit.Assert.fail;
|
||||||
import static org.mockito.Matchers.anyString;
|
import static org.mockito.Matchers.anyString;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
|
|
Loading…
Reference in New Issue