X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=tests%2Ftest-utils.js;h=84bec7e560f7eae6a7bd9a420338b63ff866bec5;hb=2a7a130c34fd72177a967316e3ed0471522789c5;hp=31a33c627eec12c671872e3e2acf8c89d6bfe34c;hpb=6db75ad932064c1415ff6f03645929530209a5fe;p=poolifier.git diff --git a/tests/test-utils.js b/tests/test-utils.js index 31a33c62..84bec7e5 100644 --- a/tests/test-utils.js +++ b/tests/test-utils.js @@ -1,17 +1,17 @@ -const WorkerFunctions = require('./test-types') +const { WorkerFunctions } = require('./test-types') class TestUtils { static async waitExits (pool, numberOfExitEventsToWait) { - let exitEvents = 0 return new Promise(resolve => { - pool.workers.forEach(w => { - w.on('exit', () => { + let exitEvents = 0 + for (const worker of pool.workers) { + worker.on('exit', () => { exitEvents++ if (exitEvents === numberOfExitEventsToWait) { resolve(exitEvents) } }) - }) + } }) } @@ -36,6 +36,18 @@ class TestUtils { }) } + static generateRandomInteger (max = Number.MAX_SAFE_INTEGER, min = 0) { + if (max < min || max < 0 || min < 0) { + throw new RangeError('Invalid interval') + } + max = Math.floor(max) + if (min != null && min !== 0) { + min = Math.ceil(min) + return Math.floor(Math.random() * (max - min + 1)) + min + } + return Math.floor(Math.random() * (max + 1)) + } + static jsonIntegerSerialization (n) { for (let i = 0; i < n; i++) { const o = {