X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fworker%2FWorkerTypes.ts;h=b180983e8a9594c3e1308fa12679a4fc2cfd4493;hb=6c0215d2bf5a098aceed9e9d94d75d50ff2630db;hp=1b7cbb300cf95a7ac5c9ba22bc4e8ac4a622afe6;hpb=721646e902fa12d165d4a1da06fb963fb30dc9f2;p=e-mobility-charging-stations-simulator.git diff --git a/src/worker/WorkerTypes.ts b/src/worker/WorkerTypes.ts index 1b7cbb30..b180983e 100644 --- a/src/worker/WorkerTypes.ts +++ b/src/worker/WorkerTypes.ts @@ -1,37 +1,70 @@ -import type { Worker } from 'node:worker_threads'; +import type { Worker } from 'node:worker_threads' -import type { PoolOptions } from 'poolifier'; +import { type PoolEvent, PoolEvents, type ThreadPoolOptions } from 'poolifier' export enum WorkerProcessType { workerSet = 'workerSet', - dynamicPool = 'dynamicPool', - staticPool = 'staticPool', + fixedPool = 'fixedPool', + /** @experimental */ + dynamicPool = 'dynamicPool' } -export type MessageHandler = (this: T, message: unknown) => void; +export interface SetInfo { + version: string + type: string + worker: string + started: boolean + size: number + elementsExecuting: number + elementsPerWorker: number +} -export type WorkerOptions = { - workerStartDelay?: number; - elementStartDelay?: number; - poolMaxSize: number; - poolMinSize: number; - elementsPerWorker?: number; - poolOptions?: PoolOptions; - messageHandler?: MessageHandler; -}; +export enum WorkerSetEvents { + started = 'started', + stopped = 'stopped', + error = 'error', + elementAdded = 'elementAdded', + elementError = 'elementError' +} -export type WorkerData = Record; +export const WorkerEvents = { + ...PoolEvents, + ...WorkerSetEvents +} as const +// eslint-disable-next-line @typescript-eslint/no-redeclare +export type WorkerEvents = PoolEvent | WorkerSetEvents -export type WorkerSetElement = { - worker: Worker; - numberOfWorkerElements: number; -}; +export interface WorkerOptions { + workerStartDelay?: number + elementAddDelay?: number + poolMaxSize: number + poolMinSize: number + elementsPerWorker?: number + poolOptions?: ThreadPoolOptions +} -export type WorkerMessage = { - id: WorkerMessageEvents; - data: T; -}; +export type WorkerData = Record + +export interface WorkerDataError extends WorkerData { + event: WorkerMessageEvents + name: string + message: string + stack?: string +} + +export interface WorkerSetElement { + worker: Worker + numberOfWorkerElements: number +} + +export interface WorkerMessage { + uuid: `${string}-${string}-${string}-${string}` + event: WorkerMessageEvents + data: T +} export enum WorkerMessageEvents { - startWorkerElement = 'startWorkerElement', + addWorkerElement = 'addWorkerElement', + addedWorkerElement = 'addedWorkerElement', + workerElementError = 'workerElementError' }