Files
bun.sh/test/js/web/timers/setInterval.test.js
Jarred Sumner 45d0c1432b rewrite timers for setTimeout, setInterval, setImmediate (#11419)
Co-authored-by: Jarred-Sumner <Jarred-Sumner@users.noreply.github.com>
Co-authored-by: Georgijs Vilums <=>
Co-authored-by: Georgijs <48869301+gvilums@users.noreply.github.com>
Co-authored-by: Georgijs Vilums <georgijs.vilums@gmail.com>
Co-authored-by: gvilums <gvilums@users.noreply.github.com>
2024-05-30 02:11:12 -07:00

118 lines
2.6 KiB
JavaScript

import { it, expect } from "bun:test";
import { join } from "path";
import "harness";
it("setInterval", async () => {
var counter = 0;
var start;
const result = await new Promise((resolve, reject) => {
start = performance.now();
var id = setInterval(
(...args) => {
counter++;
if (counter === 10) {
resolve(counter);
clearInterval(id);
}
try {
expect(args).toStrictEqual(["foo"]);
} catch (err) {
reject(err);
clearInterval(id);
}
},
1,
"foo",
);
});
expect(result).toBe(10);
expect(performance.now() - start > 9).toBe(true);
});
it("clearInterval", async () => {
var called = false;
const id = setInterval(() => {
called = true;
expect.unreachable();
}, 1);
clearInterval(id);
await new Promise((resolve, reject) => {
setInterval(() => {
resolve();
}, 10);
});
expect(called).toBe(false);
});
it("async setInterval", async () => {
var remaining = 5;
await new Promise((resolve, reject) => {
queueMicrotask(() => {
var id = setInterval(async () => {
await 1;
remaining--;
if (remaining === 0) {
clearInterval(id);
resolve();
}
}, 1);
});
});
});
it("refreshed setInterval should not reschedule again", async () => {
let relative = performance.now();
let runCount = 0;
let timer = setInterval(() => {
let end = performance.now();
// loop for 100
const spinloop = end;
while (performance.now() - spinloop < 100) {
end = performance.now();
}
timer.refresh();
const elapsed = Math.round(end - relative);
console.log("Time since last run", elapsed);
runCount++;
switch (runCount) {
case 1: {
if (elapsed < 180) {
throw new Error("Expected elapsed time to be greater than 180");
}
break;
}
case 3:
case 2: {
if (elapsed > 180) {
throw new Error("Expected elapsed time to be less than 180");
}
break;
}
}
relative = end;
if (runCount === 3) {
clearInterval(timer);
}
}, 100);
});
it("setInterval runs with at least the delay time", () => {
expect([`run`, join(import.meta.dir, "setInterval-fixture.js")]).toRun();
});
it("setInterval doesn't leak memory", () => {
expect([`run`, join(import.meta.dir, "setInterval-leak-fixture.js")]).toRun();
}, 30_000);
it("setInterval doesn't run when cancelled after being scheduled", () => {
expect([`run`, join(import.meta.dir, "setInterval-cancel-fixture.js")]).toRun();
}, 30_000);