refactor: remove unneeded worker choice strategy storage in intermediate
[poolifier.git] / tests / utils.test.mjs
index 2d1ee9e6f3c70d70bf103793fea14d0dbadb80d2..5e089e291f07877506ff12a3373ca407ee2b5c51 100644 (file)
@@ -9,8 +9,9 @@ import {
   EMPTY_FUNCTION,
   availableParallelism,
   average,
-  buildInternalWorkerChoiceStrategyOptions,
+  buildWorkerChoiceStrategyOptions,
   exponentialDelay,
+  getWorkerChoiceStrategyRetries,
   getWorkerId,
   getWorkerType,
   isAsyncFunction,
@@ -24,7 +25,12 @@ import {
   secureRandom,
   sleep
 } from '../lib/utils.cjs'
-import { KillBehaviors, WorkerTypes } from '../lib/index.cjs'
+import {
+  FixedClusterPool,
+  FixedThreadPool,
+  KillBehaviors,
+  WorkerTypes
+} from '../lib/index.cjs'
 
 describe('Utils test suite', () => {
   it('Verify DEFAULT_TASK_NAME value', () => {
@@ -231,22 +237,32 @@ describe('Utils test suite', () => {
     expect(max(1, 1)).toBe(1)
   })
 
-  it('Verify buildInternalWorkerChoiceStrategyOptions() behavior', () => {
-    const poolMaxSize = 10
-    const internalWorkerChoiceStrategyOptions =
-      buildInternalWorkerChoiceStrategyOptions(poolMaxSize)
-    expect(internalWorkerChoiceStrategyOptions).toStrictEqual({
-      retries:
-        poolMaxSize +
-        Object.keys(internalWorkerChoiceStrategyOptions.weights).length,
+  it('Verify getWorkerChoiceStrategyRetries() behavior', async () => {
+    const numberOfThreads = 4
+    const pool = new FixedThreadPool(
+      numberOfThreads,
+      './tests/worker-files/thread/testWorker.mjs'
+    )
+    expect(getWorkerChoiceStrategyRetries(pool)).toBe(pool.info.maxSize * 2)
+    await pool.destroy()
+  })
+
+  it('Verify buildWorkerChoiceStrategyOptions() behavior', async () => {
+    const numberOfWorkers = 4
+    const pool = new FixedClusterPool(
+      numberOfWorkers,
+      './tests/worker-files/cluster/testWorker.cjs'
+    )
+    expect(buildWorkerChoiceStrategyOptions(pool)).toStrictEqual({
       runTime: { median: false },
       waitTime: { median: false },
       elu: { median: false },
       weights: expect.objectContaining({
         0: expect.any(Number),
-        [poolMaxSize - 1]: expect.any(Number)
+        [pool.info.maxSize - 1]: expect.any(Number)
       })
     })
+    await pool.destroy()
   })
 
   // it('Verify once()', () => {