Bump @typescript-eslint/eslint-plugin from 5.31.0 to 5.32.0 (#500)
[poolifier.git] / src / pools / pool.ts
index e8f391cc4dc3c6f399194d82d93e92ec00c22dfc..752045829214f76681f92d36fce414c581fd0c95 100644 (file)
@@ -1,4 +1,27 @@
+import type { WorkerChoiceStrategy } from './selection-strategies'
+
+/**
+ * Contract definition for a poolifier pool.
+ *
+ * @template Data Type of data sent to the worker. This can only be serializable data.
+ * @template Response Type of response of execution. This can only be serializable data.
+ */
 export interface IPool<Data = unknown, Response = unknown> {
-  destroy(): Promise<void>
+  /**
+   * Perform the task specified in the constructor with the data parameter.
+   *
+   * @param data The input for the specified task. This can only be serializable data.
+   * @returns Promise that will be resolved when the task is successfully completed.
+   */
   execute(data: Data): Promise<Response>
+  /**
+   * Shut down every current worker in this pool.
+   */
+  destroy(): Promise<void>
+  /**
+   * Set the worker choice strategy in this pool.
+   *
+   * @param workerChoiceStrategy The worker choice strategy.
+   */
+  setWorkerChoiceStrategy(workerChoiceStrategy: WorkerChoiceStrategy): void
 }