-import { AsyncResource } from 'async_hooks'
-import type { Worker } from 'cluster'
-import type { MessagePort } from 'worker_threads'
+import { AsyncResource } from 'node:async_hooks'
+import type { Worker } from 'node:cluster'
+import type { MessagePort } from 'node:worker_threads'
import type { MessageValue } from '../utility-types'
import { EMPTY_FUNCTION } from '../utils'
import type { KillBehavior, WorkerOptions } from './worker-options'
/**
* Timestamp of the last task processed by this worker.
*/
- protected lastTaskTimestamp: number
+ protected lastTaskTimestamp!: number
/**
* Handler Id of the `aliveInterval` worker alive check.
*/
*/
public constructor (
type: string,
- isMain: boolean,
+ protected readonly isMain: boolean,
fn: (data: Data) => Response,
protected mainWorker: MainWorker | undefined | null,
opts: WorkerOptions = {
this.opts = opts
this.checkFunctionInput(fn)
this.checkWorkerOptions(this.opts)
- this.lastTaskTimestamp = Date.now()
- // Keep the worker active
- if (!isMain) {
+ if (!this.isMain) {
+ this.lastTaskTimestamp = Date.now()
this.aliveInterval = setInterval(
this.checkAlive.bind(this),
(this.opts.maxInactiveTime ?? DEFAULT_MAX_INACTIVE_TIME) / 2
this.mainWorker = value.parent
} else if (value.kill !== undefined) {
// Here is time to kill this worker, just clearing the interval
- if (this.aliveInterval != null) clearInterval(this.aliveInterval)
+ this.aliveInterval != null && clearInterval(this.aliveInterval)
this.emitDestroy()
}
}
const err = this.handleError(e as Error)
this.sendToMainWorker({ error: err, id: value.id })
} finally {
- this.lastTaskTimestamp = Date.now()
+ !this.isMain && (this.lastTaskTimestamp = Date.now())
}
}
this.sendToMainWorker({ error: err, id: value.id })
})
.finally(() => {
- this.lastTaskTimestamp = Date.now()
+ !this.isMain && (this.lastTaskTimestamp = Date.now())
})
.catch(EMPTY_FUNCTION)
}