Reset all internal statistics at worker choice strategy change
[poolifier.git] / tests / test-utils.js
index ab57685eb58fc000099fe4beec1287c01fcff14a..78218e2668c34bbfef44e680e1e9676eccf7b7cd 100644 (file)
@@ -1,7 +1,9 @@
+const { WorkerFunctions } = require('./test-types')
+
 class TestUtils {
   static async waitExits (pool, numberOfExitEventsToWait) {
     let exitEvents = 0
-    return new Promise(function (resolve, reject) {
+    return new Promise(resolve => {
       pool.workers.forEach(w => {
         w.on('exit', () => {
           exitEvents++
@@ -17,7 +19,7 @@ class TestUtils {
     return new Promise(resolve => setTimeout(resolve, ms))
   }
 
-  static async workerSleepFunction (
+  static async sleepWorkerFunction (
     data,
     ms,
     rejection = false,
@@ -46,8 +48,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
@@ -57,8 +59,8 @@ 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) {
@@ -67,6 +69,19 @@ class TestUtils {
       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')
+    }
+  }
 }
 
 module.exports = TestUtils