docs: update benchmarks vs. external pools
[poolifier.git] / benchmarks / versus-external-pools / dynamic-tinypool.mjs
index 18e3866b460bf941b760ca27fece771c27ddbc74..77b5d1114a613522174713751586b1e347e9af8b 100644 (file)
@@ -1,6 +1,6 @@
-// IMPORT LIBRARIES
 import Tinypool from 'tinypool'
-// FINISH IMPORT LIBRARIES
+import { executeAsyncFn } from '../benchmarks-utils.mjs'
+
 const size = parseInt(process.env.POOL_SIZE)
 const iterations = parseInt(process.env.NUM_ITERATIONS)
 const data = {
@@ -10,23 +10,20 @@ const data = {
 }
 
 const tinypool = new Tinypool({
-  filename: './workers/tinypool/function-to-bench-worker.js',
-  minThreads: size,
-  maxThreads: size * 3,
+  filename: './workers/tinypool/function-to-bench-worker.mjs',
+  minThreads: Math.floor(size / 2),
+  maxThreads: size,
   idleTimeout: 60000 // this is the same as poolifier default
 })
 
-/**
- *
- */
 async function run () {
-  const promises = []
+  const promises = new Set()
   for (let i = 0; i < iterations; i++) {
-    promises.push(tinypool.run(data))
+    promises.add(tinypool.run(data))
   }
   await Promise.all(promises)
   // eslint-disable-next-line n/no-process-exit
   process.exit()
 }
 
-run()
+await executeAsyncFn(run)