+ it('Verify FAIR_SHARE strategy statistics are resets after setting it', async () => {
+ let pool = new FixedThreadPool(
+ max,
+ './tests/worker-files/thread/testWorker.js'
+ )
+ expect(
+ pool.workerChoiceStrategyContext.getWorkerChoiceStrategy()
+ .workerLastVirtualTaskTimestamp
+ ).toBeUndefined()
+ pool.setWorkerChoiceStrategy(WorkerChoiceStrategies.FAIR_SHARE)
+ for (const worker of pool.workerChoiceStrategyContext
+ .getWorkerChoiceStrategy()
+ .workerLastVirtualTaskTimestamp.keys()) {
+ expect(
+ pool.workerChoiceStrategyContext
+ .getWorkerChoiceStrategy()
+ .workerLastVirtualTaskTimestamp.get(worker).start
+ ).toBe(0)
+ expect(
+ pool.workerChoiceStrategyContext
+ .getWorkerChoiceStrategy()
+ .workerLastVirtualTaskTimestamp.get(worker).end
+ ).toBe(0)
+ }
+ await pool.destroy()
+ pool = new DynamicThreadPool(
+ min,
+ max,
+ './tests/worker-files/thread/testWorker.js'
+ )
+ expect(
+ pool.workerChoiceStrategyContext.getWorkerChoiceStrategy()
+ .workerChoiceStrategy.workerLastVirtualTaskTimestamp
+ ).toBeUndefined()
+ pool.setWorkerChoiceStrategy(WorkerChoiceStrategies.FAIR_SHARE)
+ for (const worker of pool.workerChoiceStrategyContext
+ .getWorkerChoiceStrategy()
+ .workerChoiceStrategy.workerLastVirtualTaskTimestamp.keys()) {
+ expect(
+ pool.workerChoiceStrategyContext
+ .getWorkerChoiceStrategy()
+ .workerChoiceStrategy.workerLastVirtualTaskTimestamp.get(worker).start
+ ).toBe(0)
+ expect(
+ pool.workerChoiceStrategyContext
+ .getWorkerChoiceStrategy()
+ .workerChoiceStrategy.workerLastVirtualTaskTimestamp.get(worker).end
+ ).toBe(0)
+ }
+ // We need to clean up the resources after our test
+ await pool.destroy()
+ })
+