HDFS-11178. TestAddStripedBlockInFBR#testAddBlockInFullBlockReport fails frequently in trunk. Contributed By Yiqun Lin.
This commit is contained in:
parent
4dd4f3a4bb
commit
ed89856755
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user