mirror of
https://github.com/denoland/deno.git
synced 2024-12-24 08:09:08 -05:00
fix(ext/timers): some timers are not resolved (#20055)
Fixes https://github.com/denoland/deno/issues/19866
This commit is contained in:
parent
2507d6fa10
commit
8f854782b1
2 changed files with 31 additions and 1 deletions
|
@ -727,3 +727,32 @@ Deno.test({
|
|||
assertEquals(output, "");
|
||||
},
|
||||
});
|
||||
|
||||
// Regression test for https://github.com/denoland/deno/issues/19866
|
||||
Deno.test({
|
||||
name: "regression for #19866",
|
||||
fn: async () => {
|
||||
const timeoutsFired = [];
|
||||
|
||||
// deno-lint-ignore require-await
|
||||
async function start(n: number) {
|
||||
let i = 0;
|
||||
const intervalId = setInterval(() => {
|
||||
i++;
|
||||
if (i > 2) {
|
||||
clearInterval(intervalId!);
|
||||
}
|
||||
timeoutsFired.push(n);
|
||||
}, 20);
|
||||
}
|
||||
|
||||
for (let n = 0; n < 100; n++) {
|
||||
start(n);
|
||||
}
|
||||
|
||||
// 3s should be plenty of time for all the intervals to fire
|
||||
// but it might still be flaky on CI.
|
||||
await new Promise((resolve) => setTimeout(resolve, 3000));
|
||||
assertEquals(timeoutsFired.length, 300);
|
||||
},
|
||||
});
|
||||
|
|
|
@ -243,6 +243,7 @@ function runAfterTimeout(task, millis, timerInfo) {
|
|||
resolved: false,
|
||||
prev: scheduledTimers.tail,
|
||||
next: null,
|
||||
task,
|
||||
};
|
||||
|
||||
// Add timerObject to the end of the list.
|
||||
|
@ -286,7 +287,7 @@ function runAfterTimeout(task, millis, timerInfo) {
|
|||
while (currentEntry !== null) {
|
||||
if (currentEntry.millis <= timerObject.millis) {
|
||||
currentEntry.resolved = true;
|
||||
ArrayPrototypePush(timerTasks, task);
|
||||
ArrayPrototypePush(timerTasks, currentEntry.task);
|
||||
removeFromScheduledTimers(currentEntry);
|
||||
|
||||
if (currentEntry === timerObject) {
|
||||
|
|
Loading…
Reference in a new issue