-import {
- DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS,
- buildWorkerChoiceStrategyOptions
-} from '../../utils.js'
import type { IPool } from '../pool.js'
+import { DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS } from '../utils.js'
import type { IWorker } from '../worker.js'
import type {
IWorkerChoiceStrategy,
- MeasurementStatisticsRequirements,
StrategyPolicy,
TaskStatisticsRequirements,
WorkerChoiceStrategyOptions
} from './selection-strategies-types.js'
+import {
+ buildWorkerChoiceStrategyOptions,
+ toggleMedianMeasurementStatisticsRequirements
+} from './selection-strategies-utils.js'
/**
* Worker choice strategy abstract base class.
protected setTaskStatisticsRequirements (
opts: WorkerChoiceStrategyOptions | undefined
): void {
- this.toggleMedianMeasurementStatisticsRequirements(
+ toggleMedianMeasurementStatisticsRequirements(
this.taskStatisticsRequirements.runTime,
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
opts!.runTime!.median
)
- this.toggleMedianMeasurementStatisticsRequirements(
+ toggleMedianMeasurementStatisticsRequirements(
this.taskStatisticsRequirements.waitTime,
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
opts!.waitTime!.median
)
- this.toggleMedianMeasurementStatisticsRequirements(
+ toggleMedianMeasurementStatisticsRequirements(
this.taskStatisticsRequirements.elu,
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
opts!.elu!.median
)
}
- private toggleMedianMeasurementStatisticsRequirements (
- measurementStatisticsRequirements: MeasurementStatisticsRequirements,
- toggleMedian: boolean
- ): void {
- if (measurementStatisticsRequirements.average && toggleMedian) {
- measurementStatisticsRequirements.average = false
- measurementStatisticsRequirements.median = toggleMedian
- }
- if (measurementStatisticsRequirements.median && !toggleMedian) {
- measurementStatisticsRequirements.average = true
- measurementStatisticsRequirements.median = toggleMedian
- }
- }
-
protected resetWorkerNodeKeyProperties (): void {
this.nextWorkerNodeKey = 0
this.previousWorkerNodeKey = 0
}
/**
- * Check the next worker node readiness.
+ * Check the next worker node key.
*/
- protected checkNextWorkerNodeReadiness (): void {
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
- if (!this.isWorkerNodeReady(this.nextWorkerNodeKey!)) {
+ protected checkNextWorkerNodeKey (): void {
+ if (
+ this.nextWorkerNodeKey != null &&
+ (this.nextWorkerNodeKey < 0 ||
+ !this.isWorkerNodeReady(this.nextWorkerNodeKey))
+ ) {
delete this.nextWorkerNodeKey
}
}
/**
* Gets the worker node task runtime.
* If the task statistics require the average runtime, the average runtime is returned.
- * If the task statistics require the median runtime , the median runtime is returned.
+ * If the task statistics require the median runtime, the median runtime is returned.
*
* @param workerNodeKey - The worker node key.
* @returns The worker node task runtime.
* @param workerNodeKey - The worker node key.
*/
protected setPreviousWorkerNodeKey (workerNodeKey: number | undefined): void {
- this.previousWorkerNodeKey = workerNodeKey ?? this.previousWorkerNodeKey
+ this.previousWorkerNodeKey =
+ workerNodeKey != null && workerNodeKey >= 0
+ ? workerNodeKey
+ : this.previousWorkerNodeKey
}
}