build: cleanup code extensions recommendation
[e-mobility-charging-stations-simulator.git] / src / worker / WorkerTypes.ts
index 653cfedf66d58c4855387da0393f03b97e9b8af8..205cec42969796a6e70d58b1935762aec0e19d65 100644 (file)
@@ -1,52 +1,57 @@
-import type { Worker } from 'node:worker_threads';
+import type { Worker } from 'node:worker_threads'
 
-import { type PoolEvent, PoolEvents, type ThreadPoolOptions } from 'poolifier';
+import { type PoolEvent, PoolEvents, type ThreadPoolOptions } from 'poolifier'
 
 export enum WorkerProcessType {
   workerSet = 'workerSet',
   /** @experimental */
   dynamicPool = 'dynamicPool',
-  staticPool = 'staticPool',
+  fixedPool = 'fixedPool',
 }
 
 export interface SetInfo {
-  version: string;
-  type: string;
-  worker: string;
-  size: number;
-  elementsExecuting: number;
-  elementsPerWorker: number;
+  version: string
+  type: string
+  worker: string
+  size: number
+  elementsExecuting: number
+  elementsPerWorker: number
 }
 
 export enum WorkerSetEvents {
+  started = 'started',
+  stopped = 'stopped',
   error = 'error',
+  elementStarted = 'elementStarted',
+  elementError = 'elementError',
 }
 
 export const WorkerEvents = {
   ...PoolEvents,
-  ...WorkerSetEvents,
-} as const;
-export type WorkerEvents = PoolEvent | WorkerSetEvents;
+  ...WorkerSetEvents
+} as const
+// eslint-disable-next-line @typescript-eslint/no-redeclare
+export type WorkerEvents = PoolEvent | WorkerSetEvents
 
 export interface WorkerOptions {
-  workerStartDelay?: number;
-  elementStartDelay?: number;
-  poolMaxSize: number;
-  poolMinSize: number;
-  elementsPerWorker?: number;
-  poolOptions?: ThreadPoolOptions;
+  workerStartDelay?: number
+  elementStartDelay?: number
+  poolMaxSize: number
+  poolMinSize: number
+  elementsPerWorker?: number
+  poolOptions?: ThreadPoolOptions
 }
 
-export type WorkerData = Record<string, unknown>;
+export type WorkerData = Record<string, unknown>
 
 export interface WorkerSetElement {
-  worker: Worker;
-  numberOfWorkerElements: number;
+  worker: Worker
+  numberOfWorkerElements: number
 }
 
 export interface WorkerMessage<T extends WorkerData> {
-  event: WorkerMessageEvents;
-  data: T;
+  event: WorkerMessageEvents
+  data: T
 }
 
 export enum WorkerMessageEvents {