HDFS-13004. TestLeaseRecoveryStriped.testLeaseRecovery is failing when safeLength is 0MB or larger than the test file. (Zsolt Venczel via lei)

This commit is contained in:
Lei Xu 2018-01-16 15:15:11 -08:00
parent 370f1c6283
commit 3bd9ea63df
2 changed files with 11 additions and 7 deletions

View File

@ -363,11 +363,12 @@ static void checkData(DistributedFileSystem dfs, Path srcPath, int length,
List<List<LocatedBlock>> blockGroupList = new ArrayList<>(); List<List<LocatedBlock>> blockGroupList = new ArrayList<>();
LocatedBlocks lbs = dfs.getClient().getLocatedBlocks(srcPath.toString(), 0L, LocatedBlocks lbs = dfs.getClient().getLocatedBlocks(srcPath.toString(), 0L,
Long.MAX_VALUE); Long.MAX_VALUE);
int expectedNumGroup = 0;
if (length > 0) { if (length > 0) {
expectedNumGroup = (length - 1) / blkGroupSize + 1; int expectedNumGroup = (length - 1) / blkGroupSize + 1;
}
assertEquals(expectedNumGroup, lbs.getLocatedBlocks().size()); assertEquals(expectedNumGroup, lbs.getLocatedBlocks().size());
}
final ErasureCodingPolicy ecPolicy = dfs.getErasureCodingPolicy(srcPath); final ErasureCodingPolicy ecPolicy = dfs.getErasureCodingPolicy(srcPath);
final int cellSize = ecPolicy.getCellSize(); final int cellSize = ecPolicy.getCellSize();

View File

@ -85,6 +85,7 @@ public class TestLeaseRecoveryStriped {
private Configuration conf; private Configuration conf;
private final Path dir = new Path("/" + this.getClass().getSimpleName()); private final Path dir = new Path("/" + this.getClass().getSimpleName());
final Path p = new Path(dir, "testfile"); final Path p = new Path(dir, "testfile");
private final int testFileLength = (stripesPerBlock - 1) * stripeSize;
@Before @Before
public void setup() throws IOException { public void setup() throws IOException {
@ -191,17 +192,20 @@ public void testLeaseRecovery() throws Exception {
private void runTest(int[] blockLengths, long safeLength) throws Exception { private void runTest(int[] blockLengths, long safeLength) throws Exception {
writePartialBlocks(blockLengths); writePartialBlocks(blockLengths);
int checkDataLength = Math.min(testFileLength, (int)safeLength);
recoverLease(); recoverLease();
List<Long> oldGS = new ArrayList<>(); List<Long> oldGS = new ArrayList<>();
oldGS.add(1001L); oldGS.add(1001L);
StripedFileTestUtil.checkData(dfs, p, (int)safeLength, StripedFileTestUtil.checkData(dfs, p, checkDataLength,
new ArrayList<DatanodeInfo>(), oldGS, blockGroupSize); new ArrayList<DatanodeInfo>(), oldGS, blockGroupSize);
// After recovery, storages are reported by primary DN. we should verify // After recovery, storages are reported by primary DN. we should verify
// storages reported by blockReport. // storages reported by blockReport.
cluster.restartNameNode(true); cluster.restartNameNode(true);
cluster.waitFirstBRCompleted(0, 10000); cluster.waitFirstBRCompleted(0, 10000);
StripedFileTestUtil.checkData(dfs, p, (int)safeLength, StripedFileTestUtil.checkData(dfs, p, checkDataLength,
new ArrayList<DatanodeInfo>(), oldGS, blockGroupSize); new ArrayList<DatanodeInfo>(), oldGS, blockGroupSize);
} }
@ -219,12 +223,11 @@ private void writePartialBlocks(int[] blockLengths) throws Exception {
final FSDataOutputStream out = dfs.create(p); final FSDataOutputStream out = dfs.create(p);
final DFSStripedOutputStream stripedOut = (DFSStripedOutputStream) out final DFSStripedOutputStream stripedOut = (DFSStripedOutputStream) out
.getWrappedStream(); .getWrappedStream();
int length = (stripesPerBlock - 1) * stripeSize;
int[] posToKill = getPosToKill(blockLengths); int[] posToKill = getPosToKill(blockLengths);
int checkingPos = nextCheckingPos(posToKill, 0); int checkingPos = nextCheckingPos(posToKill, 0);
Set<Integer> stoppedStreamerIndexes = new HashSet<>(); Set<Integer> stoppedStreamerIndexes = new HashSet<>();
try { try {
for (int pos = 0; pos < length; pos++) { for (int pos = 0; pos < testFileLength; pos++) {
out.write(StripedFileTestUtil.getByte(pos)); out.write(StripedFileTestUtil.getByte(pos));
if (pos == checkingPos) { if (pos == checkingPos) {
for (int index : getIndexToStop(posToKill, pos)) { for (int index : getIndexToStop(posToKill, pos)) {