perf: add benchmark defaults to external pools benchmark
[poolifier.git] / benchmarks / versus-external-pools / fixed-poolifier.mjs
1 import { FixedThreadPool } from 'poolifier'
2 import { BenchmarkDefaults, executeAsyncFn } from './utils.mjs'
3
4 const size = parseInt(process.env.POOL_SIZE) || BenchmarkDefaults.poolSize
5 const numIterations =
6 parseInt(process.env.NUM_ITERATIONS) || BenchmarkDefaults.numIterations
7 const data = {
8 test: 'MYBENCH',
9 taskType: process.env.TASK_TYPE || BenchmarkDefaults.taskType,
10 taskSize: parseInt(process.env.TASK_SIZE) || BenchmarkDefaults.taskSize
11 }
12
13 const fixedThreadPool = new FixedThreadPool(
14 size,
15 './workers/poolifier/function-to-bench-worker.mjs',
16 {
17 enableTasksQueue: false
18 }
19 )
20
21 async function run () {
22 const promises = new Set()
23 for (let i = 0; i < numIterations; i++) {
24 promises.add(fixedThreadPool.execute(data))
25 }
26 await Promise.all(promises)
27 // eslint-disable-next-line n/no-process-exit
28 process.exit()
29 }
30
31 await executeAsyncFn(run)