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[] = [];
|
2019-09-07 12:27:18 -04:00
|
|
|
for (let i = 1; i <= workerCount; ++i) {
|
2020-06-09 08:33:52 -04:00
|
|
|
const worker = new Worker(
|
|
|
|
new URL("subdir/bench_worker.ts", import.meta.url).href,
|
|
|
|
{ type: "module" }
|
|
|
|
);
|
2019-11-13 13:42:34 -05:00
|
|
|
const promise = new Promise((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) {
|
2020-01-21 03:49:47 -05:00
|
|
|
const promise = new Promise((resolve): void => {
|
|
|
|
worker.onmessage = (e): void => {
|
|
|
|
if (e.data.cmdId === 3) resolve();
|
|
|
|
};
|
|
|
|
});
|
2019-04-05 15:57:59 -04:00
|
|
|
worker.postMessage({ action: 3 });
|
2020-01-21 03:49:47 -05:00
|
|
|
await promise;
|
2019-04-05 15:57:59 -04:00
|
|
|
}
|
|
|
|
console.log("Finished!");
|
|
|
|
}
|
|
|
|
|
|
|
|
bench();
|