1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-11-23 15:16:54 -05:00
denoland-deno/cli/tests/workers_startup_bench.ts

34 lines
952 B
TypeScript
Raw Normal View History

2019-04-05 15:57:59 -04:00
// Benchmark measures time it takes to start and stop a number of workers.
const workerCount = 50;
async function bench(): Promise<void> {
const workers: Worker[] = [];
for (let i = 1; i <= workerCount; ++i) {
const worker = new Worker(
new URL("workers/bench_worker.ts", import.meta.url).href,
{ type: "module" },
);
const promise = new Promise<void>((resolve): void => {
worker.onmessage = (e): void => {
if (e.data.cmdId === 0) resolve();
};
});
2019-04-05 15:57:59 -04:00
worker.postMessage({ cmdId: 0, action: 2 });
await promise;
workers.push(worker);
}
console.log("Done creating workers closing workers!");
for (const worker of workers) {
const promise = new Promise<void>((resolve): void => {
worker.onmessage = (e): void => {
if (e.data.cmdId === 3) resolve();
};
});
2019-04-05 15:57:59 -04:00
worker.postMessage({ action: 3 });
await promise;
2019-04-05 15:57:59 -04:00
}
console.log("Finished!");
}
bench();