Improve benchmarks: add IO intensive task workload, add task size option, integrate...
[poolifier.git] / examples / dynamicExample.js
CommitLineData
60fbd6d6 1const { DynamicThreadPool } = require('poolifier')
bf962cba 2let resolved = 0
3let maxReached = 0
cf9aa6c3 4const pool = new DynamicThreadPool(10, 20, './yourWorker.js', {
5 errorHandler: e => console.error(e),
6 onlineHandler: () => console.log('worker is online')
7})
330c983e 8pool.emitter.on('busy', () => maxReached++)
bf962cba 9
10const start = Date.now()
11const iterations = 1000
292ad316 12for (let i = 1; i <= iterations; i++) {
583a27ce
JB
13 pool
14 .execute({})
7a6a0a96 15 .then(() => {
583a27ce
JB
16 resolved++
17 if (resolved === iterations) {
18 console.log('Time take is ' + (Date.now() - start))
a72f2599 19 return console.log('The pool was busy for ' + maxReached + ' times')
583a27ce
JB
20 }
21 return null
22 })
23 .catch(err => console.error(err))
bf962cba 24}