HDFS-11178. TestAddStripedBlockInFBR#testAddBlockInFullBlockReport fails frequently in trunk. Contributed By Yiqun Lin.

This commit is contained in:
Brahma Reddy Battula 2016-12-06 22:30:43 +05:30
parent 4dd4f3a4bb
commit ed89856755

View File

@ -30,9 +30,8 @@
import org.apache.hadoop.hdfs.server.blockmanagement.BlockManager; import org.apache.hadoop.hdfs.server.blockmanagement.BlockManager;
import org.apache.hadoop.hdfs.server.blockmanagement.NumberReplicas; import org.apache.hadoop.hdfs.server.blockmanagement.NumberReplicas;
import org.apache.hadoop.hdfs.server.datanode.DataNode; import org.apache.hadoop.hdfs.server.datanode.DataNode;
import org.apache.hadoop.hdfs.server.datanode.DataNodeTestUtils; import org.apache.hadoop.test.GenericTestUtils;
import org.junit.After; import org.junit.After;
import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule; import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
@ -40,6 +39,8 @@
import org.mockito.Mockito; import org.mockito.Mockito;
import org.mockito.internal.util.reflection.Whitebox; import org.mockito.internal.util.reflection.Whitebox;
import com.google.common.base.Supplier;
import java.io.IOException; import java.io.IOException;
public class TestAddStripedBlockInFBR { public class TestAddStripedBlockInFBR {
@ -98,14 +99,27 @@ public void testAddBlockInFullBlockReport() throws Exception {
DFSTestUtil.createFile(dfs, ecFile, DFSTestUtil.createFile(dfs, ecFile,
cellSize * dataBlocks, (short) 1, 0L); cellSize * dataBlocks, (short) 1, 0L);
// trigger dn's FBR. The FBR will add block-dn mapping. GenericTestUtils.waitFor(new Supplier<Boolean>() {
DataNodeTestUtils.triggerBlockReport(dn);
// make sure NN has correct block-dn mapping @Override
BlockInfoStriped blockInfo = (BlockInfoStriped) cluster.getNamesystem() public Boolean get() {
.getFSDirectory().getINode(ecFile.toString()).asFile().getLastBlock(); try {
NumberReplicas nr = spy.countNodes(blockInfo); // trigger dn's FBR. The FBR will add block-dn mapping.
Assert.assertEquals(groupSize, nr.liveReplicas()); cluster.triggerBlockReports();
Assert.assertEquals(0, nr.excessReplicas());
// make sure NN has correct block-dn mapping
BlockInfoStriped blockInfo = (BlockInfoStriped) cluster
.getNamesystem().getFSDirectory().getINode(ecFile.toString())
.asFile().getLastBlock();
NumberReplicas nr = spy.countNodes(blockInfo);
return nr.excessReplicas() == 0 && nr.liveReplicas() == groupSize;
} catch (Exception ignored) {
// Ignore the exception
}
return false;
}
}, 3000, 60000);
} }
} }