refactor: cleanup performance statistics code
[e-mobility-charging-stations-simulator.git] / src / worker / WorkerAbstract.ts
index 16d566bde2ae60049fe401c7f13f830af4ce17dd..7d8eebd55204d129a0d25f554ab71dad017414a9 100644 (file)
@@ -1,13 +1,20 @@
+import type EventEmitterAsyncResource from 'node:events';
 import fs from 'node:fs';
+import type { Worker } from 'node:worker_threads';
+
+import type { ErrorHandler, ExitHandler, PoolInfo } from 'poolifier';
 
 import { WorkerConstants } from './WorkerConstants';
-import type { WorkerData, WorkerOptions } from './WorkerTypes';
+import type { SetInfo, WorkerData, WorkerOptions } from './WorkerTypes';
+import { defaultErrorHandler, defaultExitHandler } from './WorkerUtils';
 
 export abstract class WorkerAbstract<T extends WorkerData> {
   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.
@@ -24,7 +31,6 @@ export abstract class WorkerAbstract<T extends WorkerData> {
       poolMaxSize: WorkerConstants.DEFAULT_POOL_MAX_SIZE,
       elementsPerWorker: WorkerConstants.DEFAULT_ELEMENTS_PER_WORKER,
       poolOptions: {},
-      messageHandler: WorkerConstants.EMPTY_FUNCTION,
     }
   ) {
     if (workerScript === null || workerScript === undefined) {
@@ -38,9 +44,28 @@ export abstract class WorkerAbstract<T extends WorkerData> {
     }
     this.workerScript = workerScript;
     this.workerOptions = workerOptions;
+    this.workerOptions.poolOptions?.messageHandler?.bind(this);
+    this.workerOptions.poolOptions.errorHandler = (
+      this.workerOptions?.poolOptions?.errorHandler ?? defaultErrorHandler
+    ).bind(this) as ErrorHandler<Worker>;
+    this.workerOptions.poolOptions?.onlineHandler?.bind(this);
+    this.workerOptions.poolOptions.exitHandler = (
+      this.workerOptions?.poolOptions?.exitHandler ?? defaultExitHandler
+    ).bind(this) as ExitHandler<Worker>;
   }
 
+  /**
+   * Starts the worker pool/set.
+   */
   public abstract start(): Promise<void>;
+  /**
+   * Stops the worker pool/set.
+   */
   public abstract stop(): Promise<void>;
+  /**
+   * Adds a task element to the worker pool/set.
+   *
+   * @param elementData -
+   */
   public abstract addElement(elementData: T): Promise<void>;
 }