Fix testDelayVariabilityAppliesToFutureTasks (#50667)

This test seems to be bogus as it was confusing a nominal execution time with a
delay (i.e. an elapsed time). This commit reworks the test to address this.

Fixes #50650
This commit is contained in:
David Turner 2020-01-07 09:02:35 +00:00
parent a3ab7eb95d
commit 2039cc813b
1 changed files with 6 additions and 7 deletions

View File

@ -376,20 +376,19 @@ public class DeterministicTaskQueueTests extends ESTestCase {
public void testDelayVariabilityAppliesToFutureTasks() { public void testDelayVariabilityAppliesToFutureTasks() {
final DeterministicTaskQueue deterministicTaskQueue = newTaskQueue(); final DeterministicTaskQueue deterministicTaskQueue = newTaskQueue();
advanceToRandomTime(deterministicTaskQueue); advanceToRandomTime(deterministicTaskQueue);
final long delayMillis = randomLongBetween(30000, 60000); final long nominalExecutionTime = randomLongBetween(0, 60000);
final long variabilityMillis = randomLongBetween(100, 500); final long variabilityMillis = randomLongBetween(1, 500);
final long startTime = deterministicTaskQueue.getCurrentTimeMillis();
deterministicTaskQueue.setExecutionDelayVariabilityMillis(variabilityMillis); deterministicTaskQueue.setExecutionDelayVariabilityMillis(variabilityMillis);
for (int i = 0; i < 100; i++) { for (int i = 0; i < 100; i++) {
deterministicTaskQueue.scheduleAt(delayMillis, () -> {}); deterministicTaskQueue.scheduleAt(nominalExecutionTime, () -> {});
} }
final long expectedEndTime = deterministicTaskQueue.getLatestDeferredExecutionTime(); final long expectedEndTime = deterministicTaskQueue.getLatestDeferredExecutionTime();
assertThat(expectedEndTime, greaterThan(nominalExecutionTime)); // fails if every task has zero variability -- vanishingly unlikely
assertThat(expectedEndTime, lessThanOrEqualTo(Math.max(startTime, nominalExecutionTime + variabilityMillis)));
final long startTime = deterministicTaskQueue.getCurrentTimeMillis();
deterministicTaskQueue.runAllTasks(); deterministicTaskQueue.runAllTasks();
final long elapsedTime = deterministicTaskQueue.getCurrentTimeMillis() - startTime;
assertThat(deterministicTaskQueue.getCurrentTimeMillis(), is(expectedEndTime)); assertThat(deterministicTaskQueue.getCurrentTimeMillis(), is(expectedEndTime));
assertThat(elapsedTime, greaterThan(delayMillis)); // fails with negligible probability
assertThat(elapsedTime, lessThanOrEqualTo(delayMillis + variabilityMillis));
} }
public void testThreadPoolSchedulesPeriodicFutureTasks() { public void testThreadPoolSchedulesPeriodicFutureTasks() {