X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=tests%2Fpools%2Fthread%2Fdynamic.test.mjs;h=77c5aaeb5afd3893c8c7eb265a7d65ed4d3cdda6;hb=e9ed6eeed0f1c96d89c1506ee342b3000a95b4ba;hp=0a608a01f2d9d478b9fc4a17c388bcb1ac89b4dd;hpb=a074ffee1b46f43d0dcfba58128748c7492104dd;p=poolifier.git diff --git a/tests/pools/thread/dynamic.test.mjs b/tests/pools/thread/dynamic.test.mjs index 0a608a01..77c5aaeb 100644 --- a/tests/pools/thread/dynamic.test.mjs +++ b/tests/pools/thread/dynamic.test.mjs @@ -1,7 +1,11 @@ import { expect } from 'expect' -import { DynamicThreadPool, PoolEvents } from '../../../lib/index.js' -import { TaskFunctions } from '../../test-types.js' -import { sleep, waitWorkerEvents } from '../../test-utils.js' +import { + DynamicThreadPool, + PoolEvents, + WorkerChoiceStrategies +} from '../../../lib/index.cjs' +import { TaskFunctions } from '../../test-types.cjs' +import { sleep, waitPoolEvents, waitWorkerEvents } from '../../test-utils.cjs' describe('Dynamic thread pool test suite', () => { const min = 1 @@ -9,7 +13,7 @@ describe('Dynamic thread pool test suite', () => { const pool = new DynamicThreadPool( min, max, - './tests/worker-files/thread/testWorker.js', + './tests/worker-files/thread/testWorker.mjs', { errorHandler: e => console.error(e) } @@ -37,10 +41,10 @@ describe('Dynamic thread pool test suite', () => { expect(poolBusy).toBe(1) const numberOfExitEvents = await waitWorkerEvents(pool, 'exit', max - min) expect(numberOfExitEvents).toBe(max - min) + expect(pool.workerNodes.length).toBe(min) }) it('Verify scale thread up and down is working', async () => { - expect(pool.workerNodes.length).toBe(min) for (let i = 0; i < max * 2; i++) { pool.execute() } @@ -67,14 +71,16 @@ describe('Dynamic thread pool test suite', () => { await pool.destroy() const numberOfExitEvents = await exitPromise expect(pool.started).toBe(false) + expect(pool.emitter.eventNames()).toStrictEqual([]) + expect(pool.readyEventEmitted).toBe(false) expect(pool.workerNodes.length).toBe(0) expect(numberOfExitEvents).toBe(min) expect(poolDestroy).toBe(1) }) it('Validation of inputs test', () => { - expect(() => new DynamicThreadPool(min)).toThrowError( - 'Please specify a file with a worker implementation' + expect(() => new DynamicThreadPool(min)).toThrow( + 'The worker file path must be specified' ) }) @@ -82,7 +88,7 @@ describe('Dynamic thread pool test suite', () => { const pool = new DynamicThreadPool( min, max, - './tests/worker-files/thread/testWorker.js' + './tests/worker-files/thread/testWorker.mjs' ) const res = await pool.execute() expect(res).toStrictEqual({ ok: 1 }) @@ -94,7 +100,7 @@ describe('Dynamic thread pool test suite', () => { const longRunningPool = new DynamicThreadPool( min, max, - './tests/worker-files/thread/longRunningWorkerHardBehavior.js', + './tests/worker-files/thread/longRunningWorkerHardBehavior.mjs', { errorHandler: e => console.error(e), onlineHandler: () => console.info('long executing worker is online'), @@ -121,7 +127,7 @@ describe('Dynamic thread pool test suite', () => { const longRunningPool = new DynamicThreadPool( min, max, - './tests/worker-files/thread/longRunningWorkerSoftBehavior.js', + './tests/worker-files/thread/longRunningWorkerSoftBehavior.mjs', { errorHandler: e => console.error(e), onlineHandler: () => console.info('long executing worker is online'), @@ -144,10 +150,43 @@ describe('Dynamic thread pool test suite', () => { const pool = new DynamicThreadPool( 0, max, - './tests/worker-files/thread/testWorker.js' + './tests/worker-files/thread/testWorker.mjs' ) expect(pool).toBeInstanceOf(DynamicThreadPool) // We need to clean up the resources after our test await pool.destroy() }) + + it('Verify that a pool with zero worker works', async () => { + for (const workerChoiceStrategy of Object.values(WorkerChoiceStrategies)) { + const pool = new DynamicThreadPool( + 0, + max, + './tests/worker-files/thread/testWorker.mjs', + { + workerChoiceStrategy + } + ) + expect(pool.starting).toBe(false) + expect(pool.readyEventEmitted).toBe(false) + for (let run = 0; run < 2; run++) { + run % 2 !== 0 && pool.enableTasksQueue(true) + const maxMultiplier = 4 + const promises = new Set() + expect(pool.workerNodes.length).toBe(pool.info.minSize) + for (let i = 0; i < max * maxMultiplier; i++) { + promises.add(pool.execute()) + } + await Promise.all(promises) + expect(pool.readyEventEmitted).toBe(true) + expect(pool.workerNodes.length).toBeGreaterThan(pool.info.minSize) + expect(pool.workerNodes.length).toBeLessThanOrEqual(pool.info.maxSize) + await waitPoolEvents(pool, PoolEvents.empty, 1) + expect(pool.readyEventEmitted).toBe(false) + expect(pool.workerNodes.length).toBe(pool.info.minSize) + } + // We need to clean up the resources after our test + await pool.destroy() + } + }) })