Merge branch 'master' of github.com:poolifier/poolifier into feature/task-functions
[poolifier.git] / benchmarks / versus-external-pools / dynamic-worker-nodes.js
CommitLineData
589f0f1c 1'use strict'
bea2d6e3 2const WorkerNodes = require('worker-nodes')
479ba9f6 3
6bd72cd0
JB
4const size = parseInt(process.env.POOL_SIZE)
5const iterations = parseInt(process.env.NUM_ITERATIONS)
6c063733
JB
6const data = {
7 test: 'MYBENCH',
7a6a0a96 8 taskType: process.env.TASK_TYPE,
6bd72cd0 9 taskSize: parseInt(process.env.TASK_SIZE)
6c063733
JB
10}
11
12const workerNodes = new WorkerNodes(
bea2d6e3 13 require.resolve('./workers/worker-nodes/function-to-bench-worker'),
6c063733 14 {
02749105
JB
15 minWorkers: Math.floor(size / 2),
16 maxWorkers: size,
6c063733
JB
17 taskTimeout: 60000 // this is the same as poolifier default
18 }
19)
20
21async function run () {
1655b92e 22 const promises = new Set()
6c063733 23 for (let i = 0; i < iterations; i++) {
1655b92e 24 promises.add(workerNodes.call.functionToBench(data))
6c063733
JB
25 }
26 await Promise.all(promises)
2f8c5b5c 27 // eslint-disable-next-line n/no-process-exit
6c063733
JB
28 process.exit()
29}
30
bea2d6e3
JB
31(async () => {
32 try {
33 await run()
34 } catch (e) {
35 console.error(e)
36 // eslint-disable-next-line n/no-process-exit
37 process.exit(1)
38 }
39})()