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-08 01:27:18 +09:00
|
|
|
for (let i = 1; i <= workerCount; ++i) {
|
2020-01-21 09:49:47 +01:00
|
|
|
const worker = new Worker("./subdir/bench_worker.ts", { type: "module" });
|
2019-11-14 05:42:34 +11: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 09:49:47 +01: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 09:49:47 +01:00
|
|
|
await promise;
|
2019-04-05 15:57:59 -04:00
|
|
|
}
|
|
|
|
console.log("Finished!");
|
|
|
|
}
|
|
|
|
|
|
|
|
bench();
|