-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'
+import {
+ isKillBehavior,
+ type KillBehavior,
+ type WorkerOptions
+} from './worker-options'
import { KillBehaviors } from './worker-options'
const DEFAULT_MAX_INACTIVE_TIME = 60000
/**
* Timestamp of the last task processed by this worker.
*/
- protected lastTaskTimestamp: number
+ protected lastTaskTimestamp!: number
/**
* Handler Id of the `aliveInterval` worker alive check.
*/
this.opts = opts
this.checkFunctionInput(fn)
this.checkWorkerOptions(this.opts)
- this.lastTaskTimestamp = Date.now()
- // Keep the worker active
- if (!isMain) {
+ if (!isMain && isKillBehavior(KillBehaviors.HARD, this.opts.killBehavior)) {
+ 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()
+ isKillBehavior(KillBehaviors.HARD, this.opts.killBehavior) &&
+ (this.lastTaskTimestamp = Date.now())
}
}
this.sendToMainWorker({ error: err, id: value.id })
})
.finally(() => {
- this.lastTaskTimestamp = Date.now()
+ isKillBehavior(KillBehaviors.HARD, this.opts.killBehavior) &&
+ (this.lastTaskTimestamp = Date.now())
})
.catch(EMPTY_FUNCTION)
}