fix: ensure reservation expiration internal is > 0
[e-mobility-charging-stations-simulator.git] / src / worker / WorkerAbstract.ts
index 0ef5470649c2e943e0ff7134cb89b9a3ed29ae3a..75fc2f6bed5baaf47a9e2aae9f52d1992253eec3 100644 (file)
@@ -1,8 +1,8 @@
-import type EventEmitterAsyncResource from 'node:events';
-import fs from 'node:fs';
+import type { EventEmitter } from 'node:events';
+import { existsSync } from 'node:fs';
 import type { Worker } from 'node:worker_threads';
 
-import type { ErrorHandler, ExitHandler, PoolInfo } from 'poolifier';
+import type { ErrorHandler, ExitHandler, PoolEmitter, PoolInfo } from 'poolifier';
 
 import { WorkerConstants } from './WorkerConstants';
 import type { SetInfo, WorkerData, WorkerOptions } from './WorkerTypes';
@@ -14,7 +14,7 @@ export abstract class WorkerAbstract<T extends WorkerData> {
   public abstract readonly info: PoolInfo | SetInfo;
   public abstract readonly size: number;
   public abstract readonly maxElementsPerWorker: number | undefined;
-  public abstract readonly emitter: EventEmitterAsyncResource | undefined;
+  public abstract readonly emitter: EventEmitter | PoolEmitter | undefined;
 
   /**
    * `WorkerAbstract` constructor.
@@ -31,7 +31,7 @@ export abstract class WorkerAbstract<T extends WorkerData> {
       poolMaxSize: WorkerConstants.DEFAULT_POOL_MAX_SIZE,
       elementsPerWorker: WorkerConstants.DEFAULT_ELEMENTS_PER_WORKER,
       poolOptions: {},
-    }
+    },
   ) {
     if (workerScript === null || workerScript === undefined) {
       throw new Error('Worker script is not defined');
@@ -39,31 +39,31 @@ export abstract class WorkerAbstract<T extends WorkerData> {
     if (typeof workerScript === 'string' && workerScript.trim().length === 0) {
       throw new Error('Worker script is empty');
     }
-    if (!fs.existsSync(workerScript)) {
+    if (!existsSync(workerScript)) {
       throw new Error('Worker script file does not exist');
     }
     this.workerScript = workerScript;
     this.workerOptions = workerOptions;
     this.workerOptions.poolOptions?.messageHandler?.bind(this);
-    this.workerOptions.poolOptions.errorHandler = (
+    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 = (
       this.workerOptions?.poolOptions?.exitHandler ?? defaultExitHandler
     ).bind(this) as ExitHandler<Worker>;
   }
 
   /**
-   * Start the worker pool/set.
+   * Starts the worker pool/set.
    */
   public abstract start(): Promise<void>;
   /**
-   * Stop the worker pool/set.
+   * Stops the worker pool/set.
    */
   public abstract stop(): Promise<void>;
   /**
-   * Add a task element to the worker pool/set.
+   * Adds a task element to the worker pool/set.
    *
    * @param elementData -
    */