refactor: refine benchmark namespace
[poolifier.git] / src / worker / cluster-worker.ts
index 2a3961b37f02836d52c7972f98ee150c02904281..4c1e118789d53f7228e51a5b974b80575985705f 100644 (file)
@@ -13,8 +13,8 @@ import type { TaskFunctions, WorkerFunction } from './worker-functions'
  * If you use a `DynamicClusterPool` the extra workers that were created will be terminated,
  * but the minimum number of workers will be guaranteed.
  *
- * @typeParam Data - Type of data this worker receives from pool's execution. This can only be serializable data.
- * @typeParam Response - Type of response the worker sends back to the main worker. This can only be serializable data.
+ * @typeParam Data - Type of data this worker receives from pool's execution. This can only be structured-cloneable data.
+ * @typeParam Response - Type of response the worker sends back to the main worker. This can only be structured-cloneable data.
  * @author [Christopher Quadflieg](https://github.com/Shinigami92)
  * @since 2.0.0
  */
@@ -37,19 +37,27 @@ export class ClusterWorker<
     super(
       'worker-cluster-pool:poolifier',
       cluster.isPrimary,
+      cluster.worker as Worker,
       taskFunctions,
-      cluster.worker,
       opts
     )
   }
 
   /** @inheritDoc */
-  protected sendToMainWorker (message: MessageValue<Response>): void {
-    this.getMainWorker().send(message)
+  protected handleReadyMessage (message: MessageValue<Data>): void {
+    if (!this.isMain && message.workerId === this.id && message.ready != null) {
+      this.getMainWorker()?.on('message', this.messageListener.bind(this))
+      this.sendToMainWorker({ ready: true, workerId: this.id })
+    }
   }
 
   /** @inheritDoc */
-  protected handleError (e: Error | string): string {
-    return e instanceof Error ? e.message : e
+  protected get id (): number {
+    return this.getMainWorker().id
+  }
+
+  /** @inheritDoc */
+  protected sendToMainWorker (message: MessageValue<Response>): void {
+    this.getMainWorker().send(message)
   }
 }