Merge branch 'master' of github.com:jerome-benoit/poolifier
[poolifier.git] / benchmarks / versus-external-pools / dynamic-poolifier.mjs
... / ...
CommitLineData
1// IMPORT LIBRARIES
2import { DynamicThreadPool } from 'poolifier'
3// FINISH IMPORT LIBRARIES
4const size = parseInt(process.env.POOL_SIZE)
5const iterations = parseInt(process.env.NUM_ITERATIONS)
6const data = {
7 test: 'MYBENCH',
8 taskType: process.env.TASK_TYPE,
9 taskSize: parseInt(process.env.TASK_SIZE)
10}
11
12const dynamicPool = new DynamicThreadPool(
13 Math.floor(size / 2),
14 size,
15 './workers/poolifier/function-to-bench-worker.mjs'
16)
17
18async function run () {
19 const promises = new Set()
20 for (let i = 0; i < iterations; i++) {
21 promises.add(dynamicPool.execute(data))
22 }
23 await Promise.all(promises)
24 // eslint-disable-next-line n/no-process-exit
25 process.exit()
26}
27
28await run()