Fix off-by-one error in chunks coordinator (#31147)

This commit fixes an off-by-error in the chunks coordinator where the
batches would be of size one more than the batch size.
This commit is contained in:
Jason Tedor 2018-06-06 19:53:49 -04:00 committed by GitHub
parent bf1152fcc6
commit 20a2f646e2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 34 additions and 28 deletions

View File

@ -234,11 +234,17 @@ public class ShardFollowTasksExecutor extends PersistentTasksExecutor<ShardFollo
this.countDown = new CountDown(concurrentProcessors); this.countDown = new CountDown(concurrentProcessors);
} }
void createChucks(long from, long to) { /**
* Creates chunks of the specified range, inclusive.
*
* @param from the lower end of the range (inclusive)
* @param to the upper end of the range (inclusive)
*/
void createChucks(final long from, final long to) {
LOGGER.debug("{} Creating chunks for operation range [{}] to [{}]", leaderShard, from, to); LOGGER.debug("{} Creating chunks for operation range [{}] to [{}]", leaderShard, from, to);
for (long i = from; i < to; i += batchSize) { for (long i = from; i < to; i += batchSize) {
long v2 = i + batchSize < to ? i + batchSize : to; long v2 = i + batchSize <= to ? i + batchSize - 1 : to;
chunks.add(new long[]{i == from ? i : i + 1, v2}); chunks.add(new long[]{i, v2});
} }
} }

View File

@ -58,47 +58,47 @@ public class ChunksCoordinatorTests extends ESTestCase {
followShardId.getIndex(), client, client); followShardId.getIndex(), client, client);
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1024, 1, ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1024, 1,
Long.MAX_VALUE, leaderShardId, followShardId, e -> {}); Long.MAX_VALUE, leaderShardId, followShardId, e -> {});
coordinator.createChucks(0, 1024); coordinator.createChucks(0, 1023);
List<long[]> result = new ArrayList<>(coordinator.getChunks()); List<long[]> result = new ArrayList<>(coordinator.getChunks());
assertThat(result.size(), equalTo(1)); assertThat(result.size(), equalTo(1));
assertThat(result.get(0)[0], equalTo(0L)); assertThat(result.get(0)[0], equalTo(0L));
assertThat(result.get(0)[1], equalTo(1024L)); assertThat(result.get(0)[1], equalTo(1023L));
coordinator.getChunks().clear(); coordinator.getChunks().clear();
coordinator.createChucks(0, 2048); coordinator.createChucks(0, 2047);
result = new ArrayList<>(coordinator.getChunks()); result = new ArrayList<>(coordinator.getChunks());
assertThat(result.size(), equalTo(2)); assertThat(result.size(), equalTo(2));
assertThat(result.get(0)[0], equalTo(0L)); assertThat(result.get(0)[0], equalTo(0L));
assertThat(result.get(0)[1], equalTo(1024L)); assertThat(result.get(0)[1], equalTo(1023L));
assertThat(result.get(1)[0], equalTo(1025L)); assertThat(result.get(1)[0], equalTo(1024L));
assertThat(result.get(1)[1], equalTo(2048L)); assertThat(result.get(1)[1], equalTo(2047L));
coordinator.getChunks().clear(); coordinator.getChunks().clear();
coordinator.createChucks(0, 4096); coordinator.createChucks(0, 4095);
result = new ArrayList<>(coordinator.getChunks()); result = new ArrayList<>(coordinator.getChunks());
assertThat(result.size(), equalTo(4)); assertThat(result.size(), equalTo(4));
assertThat(result.get(0)[0], equalTo(0L)); assertThat(result.get(0)[0], equalTo(0L));
assertThat(result.get(0)[1], equalTo(1024L)); assertThat(result.get(0)[1], equalTo(1023L));
assertThat(result.get(1)[0], equalTo(1025L)); assertThat(result.get(1)[0], equalTo(1024L));
assertThat(result.get(1)[1], equalTo(2048L)); assertThat(result.get(1)[1], equalTo(2047L));
assertThat(result.get(2)[0], equalTo(2049L)); assertThat(result.get(2)[0], equalTo(2048L));
assertThat(result.get(2)[1], equalTo(3072L)); assertThat(result.get(2)[1], equalTo(3071L));
assertThat(result.get(3)[0], equalTo(3073L)); assertThat(result.get(3)[0], equalTo(3072L));
assertThat(result.get(3)[1], equalTo(4096L)); assertThat(result.get(3)[1], equalTo(4095L));
coordinator.getChunks().clear(); coordinator.getChunks().clear();
coordinator.createChucks(4096, 8196); coordinator.createChucks(4096, 8196);
result = new ArrayList<>(coordinator.getChunks()); result = new ArrayList<>(coordinator.getChunks());
assertThat(result.size(), equalTo(5)); assertThat(result.size(), equalTo(5));
assertThat(result.get(0)[0], equalTo(4096L)); assertThat(result.get(0)[0], equalTo(4096L));
assertThat(result.get(0)[1], equalTo(5120L)); assertThat(result.get(0)[1], equalTo(5119L));
assertThat(result.get(1)[0], equalTo(5121L)); assertThat(result.get(1)[0], equalTo(5120L));
assertThat(result.get(1)[1], equalTo(6144L)); assertThat(result.get(1)[1], equalTo(6143L));
assertThat(result.get(2)[0], equalTo(6145L)); assertThat(result.get(2)[0], equalTo(6144L));
assertThat(result.get(2)[1], equalTo(7168L)); assertThat(result.get(2)[1], equalTo(7167L));
assertThat(result.get(3)[0], equalTo(7169L)); assertThat(result.get(3)[0], equalTo(7168L));
assertThat(result.get(3)[1], equalTo(8192L)); assertThat(result.get(3)[1], equalTo(8191L));
assertThat(result.get(4)[0], equalTo(8193L)); assertThat(result.get(4)[0], equalTo(8192L));
assertThat(result.get(4)[1], equalTo(8196L)); assertThat(result.get(4)[1], equalTo(8196L));
} }
@ -121,7 +121,7 @@ public class ChunksCoordinatorTests extends ESTestCase {
int numberOfOps = randomIntBetween(batchSize, batchSize * 20); int numberOfOps = randomIntBetween(batchSize, batchSize * 20);
long from = randomInt(1000); long from = randomInt(1000);
long to = from + numberOfOps; long to = from + numberOfOps - 1;
coordinator.createChucks(from, to); coordinator.createChucks(from, to);
int expectedNumberOfChunks = numberOfOps / batchSize; int expectedNumberOfChunks = numberOfOps / batchSize;
if (numberOfOps % batchSize > 0) { if (numberOfOps % batchSize > 0) {
@ -163,7 +163,7 @@ public class ChunksCoordinatorTests extends ESTestCase {
followShardId.getIndex(), client, client); followShardId.getIndex(), client, client);
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 10, 1, Long.MAX_VALUE, ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 10, 1, Long.MAX_VALUE,
leaderShardId, followShardId, handler); leaderShardId, followShardId, handler);
coordinator.createChucks(0, 20); coordinator.createChucks(0, 19);
assertThat(coordinator.getChunks().size(), equalTo(2)); assertThat(coordinator.getChunks().size(), equalTo(2));
coordinator.start(); coordinator.start();
@ -196,7 +196,7 @@ public class ChunksCoordinatorTests extends ESTestCase {
followShardId.getIndex(), client, client); followShardId.getIndex(), client, client);
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1000, 4, Long.MAX_VALUE, ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1000, 4, Long.MAX_VALUE,
leaderShardId, followShardId, handler); leaderShardId, followShardId, handler);
coordinator.createChucks(0, 1000000); coordinator.createChucks(0, 999999);
assertThat(coordinator.getChunks().size(), equalTo(1000)); assertThat(coordinator.getChunks().size(), equalTo(1000));
coordinator.start(); coordinator.start();