Merge branch 'master' of github.com:jerome-benoit/poolifier
[poolifier.git] / benchmarks / versus-external-pools / static-node-worker-threads-pool.mjs
CommitLineData
be0676b3 1// IMPORT LIBRARIES
8fca9288 2import { StaticPool } from 'node-worker-threads-pool'
be0676b3
APA
3// FINISH IMPORT LIBRARIES
4// IMPORT FUNCTION TO BENCH
bea2d6e3 5import functionToBench from './functions/function-to-bench.js'
be0676b3 6// FINISH IMPORT FUNCTION TO BENCH
6bd72cd0
JB
7const size = parseInt(process.env.POOL_SIZE)
8const iterations = parseInt(process.env.NUM_ITERATIONS)
be0676b3 9const data = {
9f7e7a99 10 test: 'MYBENCH',
7a6a0a96 11 taskType: process.env.TASK_TYPE,
6bd72cd0 12 taskSize: parseInt(process.env.TASK_SIZE)
be0676b3
APA
13}
14
15const pool = new StaticPool({
7a6a0a96 16 size,
be0676b3
APA
17 task: functionToBench
18})
19
20async function run () {
1655b92e 21 const promises = new Set()
be0676b3 22 for (let i = 0; i < iterations; i++) {
1655b92e 23 promises.add(pool.exec(data))
be0676b3
APA
24 }
25 await Promise.all(promises)
2f8c5b5c 26 // eslint-disable-next-line n/no-process-exit
be0676b3
APA
27 process.exit()
28}
29
8fca9288 30await run()