fix: properly size the pools in benchmarking code
[poolifier.git] / benchmarks / versus-external-pools / dynamic-workerpool.mjs
CommitLineData
144f78e0 1// IMPORT LIBRARIES
8fca9288 2import workerpool from 'workerpool'
144f78e0 3// FINISH IMPORT LIBRARIES
6bd72cd0
JB
4const size = parseInt(process.env.POOL_SIZE)
5const iterations = parseInt(process.env.NUM_ITERATIONS)
6const dataArray = [
7 'MYBENCH',
8 process.env.TASK_TYPE,
9 parseInt(process.env.TASK_SIZE)
10]
144f78e0
JB
11
12const workerPool = workerpool.pool(
8fca9288 13 './workers/workerpool/function-to-bench-worker.mjs',
144f78e0 14 {
02749105
JB
15 minWorkers: Math.floor(size / 2),
16 maxWorkers: size,
144f78e0
JB
17 workerType: 'thread'
18 }
19)
20
21async function run () {
22 const promises = []
23 for (let i = 0; i < iterations; i++) {
24 promises.push(workerPool.exec('functionToBench', dataArray))
25 }
26 await Promise.all(promises)
2f8c5b5c 27 // eslint-disable-next-line n/no-process-exit
144f78e0
JB
28 process.exit()
29}
30
8fca9288 31await run()