build(deps-dev): bump typescript
[poolifier.git] / examples / typescript / pool.ts
index 3d9d9e6f482723cdb634e98bd02a9bbd46df3314..3965e1f0a1cd4c8e2632b59018972e79fa5b798e 100644 (file)
@@ -1,40 +1,52 @@
 import { dirname, extname, join } from 'node:path'
 import { fileURLToPath } from 'node:url'
-import type { MyData, MyResponse } from './worker'
+
 import {
+  availableParallelism,
   DynamicThreadPool,
-  FixedThreadPool,
-  availableParallelism
+  FixedThreadPool
 } from 'poolifier'
 
+import type { MyData, MyResponse } from './worker.js'
+
 const workerFile = join(
   dirname(fileURLToPath(import.meta.url)),
   `worker${extname(fileURLToPath(import.meta.url))}`
 )
 
-export const fixedPool = new FixedThreadPool<MyData, Promise<MyResponse>>(
+const fixedPool = new FixedThreadPool<MyData, MyResponse>(
   availableParallelism(),
   workerFile,
   {
-    errorHandler: (e: Error) => {
-      console.error(e)
-    },
     onlineHandler: () => {
       console.info('Worker is online')
+    },
+    errorHandler: (e: Error) => {
+      console.error(e)
     }
   }
 )
 
-export const dynamicPool = new DynamicThreadPool<MyData, Promise<MyResponse>>(
+await fixedPool.execute()
+
+const dynamicPool = new DynamicThreadPool<MyData, MyResponse>(
   Math.floor(availableParallelism() / 2),
   availableParallelism(),
   workerFile,
   {
-    errorHandler: (e: Error) => {
-      console.error(e)
-    },
     onlineHandler: () => {
       console.info('Worker is online')
+    },
+    errorHandler: (e: Error) => {
+      console.error(e)
     }
   }
 )
+
+await dynamicPool.execute()
+
+// eslint-disable-next-line @typescript-eslint/no-misused-promises
+setTimeout(async () => {
+  await fixedPool.destroy()
+  await dynamicPool.destroy()
+}, 3000)