X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=tests%2Ftest-utils.js;h=24b01e442ef7b0c63afd1a28d3e5261e82c34d6d;hb=2c039e4373e86714cdf27e77440b12ee8eb2e4db;hp=e63e14f2987748d61030ad964588df864958f3a6;hpb=d94bee6fb7e3c48b2490cc4fdd1fe2c205c33f2a;p=poolifier.git diff --git a/tests/test-utils.js b/tests/test-utils.js index e63e14f2..24b01e44 100644 --- a/tests/test-utils.js +++ b/tests/test-utils.js @@ -1,14 +1,34 @@ +const { WorkerFunctions } = require('./test-types') + class TestUtils { - static async waitExits (pool, numberOfExitEventsToWait) { - let exitEvents = 0 + static async waitWorkerEvents (pool, workerEvent, numberOfEventsToWait) { return new Promise(resolve => { - pool.workers.forEach(w => { - w.on('exit', () => { - exitEvents++ - if (exitEvents === numberOfExitEventsToWait) { - resolve(exitEvents) + let events = 0 + if (numberOfEventsToWait === 0) { + resolve(events) + } + for (const workerNode of pool.workerNodes) { + workerNode.worker.on(workerEvent, () => { + ++events + if (events === numberOfEventsToWait) { + resolve(events) } }) + } + }) + } + + static async waitPoolEvents (pool, poolEvent, numberOfEventsToWait) { + return new Promise(resolve => { + let events = 0 + if (numberOfEventsToWait === 0) { + resolve(events) + } + pool.emitter.on(poolEvent, () => { + ++events + if (events === numberOfEventsToWait) { + resolve(events) + } }) }) } @@ -17,7 +37,7 @@ class TestUtils { return new Promise(resolve => setTimeout(resolve, ms)) } - static async workerSleepFunction ( + static async sleepWorkerFunction ( data, ms, rejection = false, @@ -34,6 +54,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 = { @@ -45,9 +77,8 @@ class TestUtils { /** * Intentionally inefficient implementation. - * - * @param {number} n - * @returns {number} + * @param {number} n - The number of fibonacci numbers to generate. + * @returns {number} - The nth fibonacci number. */ static fibonacci (n) { if (n <= 1) return 1 @@ -56,15 +87,26 @@ class TestUtils { /** * Intentionally inefficient implementation. - * - * @param {number} n - * @returns {number} + * @param {number} n - The number to calculate the factorial of. + * @returns {number} - The factorial of n. */ static factorial (n) { if (n === 0) { return 1 - } else { - return TestUtils.factorial(n - 1) * n + } + return TestUtils.factorial(n - 1) * n + } + + static executeWorkerFunction (data) { + switch (data.function) { + case WorkerFunctions.jsonIntegerSerialization: + return TestUtils.jsonIntegerSerialization(data.n || 100) + case WorkerFunctions.fibonacci: + return TestUtils.fibonacci(data.n || 25) + case WorkerFunctions.factorial: + return TestUtils.factorial(data.n || 100) + default: + throw new Error('Unknown worker function') } } }