diff options
author | andy finch <andyfinch7@gmail.com> | 2019-04-05 15:57:59 -0400 |
---|---|---|
committer | Ryan Dahl <ry@tinyclouds.org> | 2019-04-05 22:57:59 +0300 |
commit | 7a3df0a18465ceebe43f3183daa2f9397c4e5ebb (patch) | |
tree | 64fb338c99cda0be406c9fb0788c88fc97c0a7be /tests/workers_startup_bench.ts | |
parent | 031411b449b1990241c0ff0565e01e60f30b769a (diff) |
Add worker benchmarks (#2059)
Diffstat (limited to 'tests/workers_startup_bench.ts')
-rw-r--r-- | tests/workers_startup_bench.ts | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/tests/workers_startup_bench.ts b/tests/workers_startup_bench.ts new file mode 100644 index 000000000..46b2b2801 --- /dev/null +++ b/tests/workers_startup_bench.ts @@ -0,0 +1,25 @@ +// 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 (var i = 1; i <= workerCount; ++i) { + const worker = new Worker("tests/subdir/bench_worker.ts"); + const promise = new Promise(resolve => { + worker.onmessage = e => { + if (e.data.cmdId === 0) resolve(); + }; + }); + worker.postMessage({ cmdId: 0, action: 2 }); + await promise; + workers.push(worker); + } + console.log("Done creating workers closing workers!"); + for (const worker of workers) { + worker.postMessage({ action: 3 }); + await worker.closed; // Required to avoid a cmdId not in table error. + } + console.log("Finished!"); +} + +bench(); |