X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fpools%2Fselection-strategies%2Fless-recently-used-worker-choice-strategy.ts;h=e62d9cdf83bd9a5ae472bc08296dfbe18b96e806;hb=38e795c12f0e9daeff7b025147f36f85f486366e;hp=a7892c4036e3b6e9ef742cad0bdc02eb16dbdbf3;hpb=bdaf31cd0e637aa466c78d54a49f157899a2cb3f;p=poolifier.git diff --git a/src/pools/selection-strategies/less-recently-used-worker-choice-strategy.ts b/src/pools/selection-strategies/less-recently-used-worker-choice-strategy.ts index a7892c40..e62d9cdf 100644 --- a/src/pools/selection-strategies/less-recently-used-worker-choice-strategy.ts +++ b/src/pools/selection-strategies/less-recently-used-worker-choice-strategy.ts @@ -1,31 +1,35 @@ -import type { AbstractPoolWorker } from '../abstract-pool-worker' +import type { IPoolWorker } from '../pool-worker' import { AbstractWorkerChoiceStrategy } from './abstract-worker-choice-strategy' /** * Selects the less recently used worker. * - * @template Worker Type of worker which manages the strategy. - * @template Data Type of data sent to the worker. This can only be serializable data. - * @template Response Type of response of execution. This can only be serializable data. + * @typeParam Worker - Type of worker which manages the strategy. + * @typeParam Data - Type of data sent to the worker. This can only be serializable data. + * @typeParam Response - Type of response of execution. This can only be serializable data. */ export class LessRecentlyUsedWorkerChoiceStrategy< - Worker extends AbstractPoolWorker, + Worker extends IPoolWorker, Data, Response > extends AbstractWorkerChoiceStrategy { - /** @inheritdoc */ + /** {@inheritDoc} */ + public reset (): boolean { + return true + } + + /** {@inheritDoc} */ public choose (): Worker { let minNumberOfRunningTasks = Infinity // A worker is always found because it picks the one with fewer tasks let lessRecentlyUsedWorker!: Worker for (const worker of this.pool.workers) { - const workerRunningTasks = this.pool.getWorkerRunningTasks(worker) + const workerRunningTasks = this.pool.getWorkerRunningTasks( + worker + ) as number if (!this.isDynamicPool && workerRunningTasks === 0) { return worker - } else if ( - workerRunningTasks !== undefined && - workerRunningTasks < minNumberOfRunningTasks - ) { + } else if (workerRunningTasks < minNumberOfRunningTasks) { lessRecentlyUsedWorker = worker minNumberOfRunningTasks = workerRunningTasks }