-// IMPORT LIBRARIES
import { DynamicPool } from 'node-worker-threads-pool'
-// FINISH IMPORT LIBRARIES
-// IMPORT FUNCTION TO BENCH
+import { executeAsyncFn } from './utils.mjs'
import functionToBench from './functions/function-to-bench.js'
-// FINISH IMPORT FUNCTION TO BENCH
+
const size = parseInt(process.env.POOL_SIZE)
const iterations = parseInt(process.env.NUM_ITERATIONS)
const data = {
taskSize: parseInt(process.env.TASK_SIZE)
}
-const pool = new DynamicPool(size)
+const dynamicPool = new DynamicPool(size)
async function run () {
- const promises = []
+ const promises = new Set()
for (let i = 0; i < iterations; i++) {
- promises.push(
- pool.exec({
+ promises.add(
+ dynamicPool.exec({
task: functionToBench,
param: data,
timeout: 60000 // this is the same as poolifier default
process.exit()
}
-await run()
+await executeAsyncFn(run)