const { WorkerFunctions } = require('./test-types')
class TestUtils {
- static async waitExits (pool, numberOfExitEventsToWait) {
+ static async waitWorkerEvents (pool, workerEvent, numberOfEventsToWait) {
return new Promise(resolve => {
- let exitEvents = 0
- 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)
+ }
})
})
}
/**
* Intentionally inefficient implementation.
- *
* @param {number} n - The number of fibonacci numbers to generate.
* @returns {number} - The nth fibonacci number.
*/
static fibonacci (n) {
- if (n <= 1) return 1
+ if (n <= 1) return n
return TestUtils.fibonacci(n - 1) + TestUtils.fibonacci(n - 2)
}
/**
* Intentionally inefficient implementation.
- *
* @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) {