X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fworker%2FWorkerAbstract.ts;h=f6713f8976d2cdda47d74f5951880f8d1fdfd48d;hb=8fb8f42ace8b9295865adebaeb7845e064c05e71;hp=32319ab2ee87d6faf8af97a2dfcd9c74babaa9fc;hpb=4a3807d16c54137840a60af41877f3b21de12950;p=e-mobility-charging-stations-simulator.git diff --git a/src/worker/WorkerAbstract.ts b/src/worker/WorkerAbstract.ts index 32319ab2..f6713f89 100644 --- a/src/worker/WorkerAbstract.ts +++ b/src/worker/WorkerAbstract.ts @@ -1,18 +1,17 @@ -import type { EventEmitter } from 'node:events'; -import { existsSync } from 'node:fs'; +import type { EventEmitterAsyncResource } from 'node:events' +import { existsSync } from 'node:fs' -import type { PoolEmitter, PoolInfo } from 'poolifier'; +import type { PoolInfo } from 'poolifier' -import type { SetInfo, WorkerData, WorkerOptions } from './WorkerTypes'; -import { defaultErrorHandler, defaultExitHandler } from './WorkerUtils'; +import type { SetInfo, WorkerData, WorkerOptions } from './WorkerTypes.js' -export abstract class WorkerAbstract { - protected readonly workerScript: string; - protected readonly workerOptions: WorkerOptions; - public abstract readonly info: PoolInfo | SetInfo; - public abstract readonly size: number; - public abstract readonly maxElementsPerWorker: number | undefined; - public abstract readonly emitter: EventEmitter | PoolEmitter | undefined; +export abstract class WorkerAbstract { + protected readonly workerScript: string + protected readonly workerOptions: WorkerOptions + public abstract readonly info: PoolInfo | SetInfo + public abstract readonly size: number + public abstract readonly maxElementsPerWorker: number | undefined + public abstract readonly emitter: EventEmitterAsyncResource | undefined /** * `WorkerAbstract` constructor. @@ -20,36 +19,35 @@ export abstract class WorkerAbstract { * @param workerScript - * @param workerOptions - */ - constructor(workerScript: string, workerOptions: WorkerOptions) { - if (workerScript === null || workerScript === undefined) { - throw new Error('Worker script is not defined'); + constructor (workerScript: string | undefined, workerOptions: WorkerOptions) { + if (workerScript == null) { + throw new TypeError('Worker script is not defined') } - if (typeof workerScript === 'string' && workerScript.trim().length === 0) { - throw new Error('Worker script is empty'); + if (typeof workerScript !== 'string') { + throw new TypeError('Worker script must be a string') + } + if (workerScript.trim().length === 0) { + throw new Error('Worker script is an empty string') } if (!existsSync(workerScript)) { - throw new Error('Worker script file does not exist'); + throw new Error('Worker script file does not exist') } - this.workerScript = workerScript; - this.workerOptions = workerOptions; - this.workerOptions.poolOptions!.errorHandler = - this.workerOptions.poolOptions?.errorHandler ?? defaultErrorHandler; - this.workerOptions.poolOptions!.exitHandler = - this.workerOptions.poolOptions?.exitHandler ?? defaultExitHandler; + this.workerScript = workerScript + this.workerOptions = workerOptions } /** * Starts the worker pool/set. */ - public abstract start(): Promise; + public abstract start (): void | Promise /** * Stops the worker pool/set. */ - public abstract stop(): Promise; + public abstract stop (): Promise /** * Adds a task element to the worker pool/set. * * @param elementData - */ - public abstract addElement(elementData: T): Promise; + public abstract addElement (elementData: D): Promise }