X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fpools%2Fabstract-pool.ts;h=670866069d97dfff46e817c29f54810370dec552;hb=33e6bb4c6f1061542693dbd996ffc08c62e8beeb;hp=dceef6decb534f083510d90a947a05861c2ec2df;hpb=a1763c54c962c69b5e02a30c0909724986495fcd;p=poolifier.git diff --git a/src/pools/abstract-pool.ts b/src/pools/abstract-pool.ts index dceef6de..67086606 100644 --- a/src/pools/abstract-pool.ts +++ b/src/pools/abstract-pool.ts @@ -122,6 +122,8 @@ export abstract class AbstractPool< this.checkAndEmitTaskExecutionEvents.bind(this) this.checkAndEmitTaskQueuingEvents = this.checkAndEmitTaskQueuingEvents.bind(this) + this.checkAndEmitDynamicWorkerCreationEvents = + this.checkAndEmitDynamicWorkerCreationEvents.bind(this) if (this.opts.enableEvents === true) { this.emitter = new PoolEmitter() @@ -749,7 +751,7 @@ export abstract class AbstractPool< await this.destroyWorkerNode(workerNodeKey) }) ) - this.emitter?.emit(PoolEvents.destroy) + this.emitter?.emit(PoolEvents.destroy, this.info) } protected async sendKillMessageToWorker ( @@ -1061,6 +1063,7 @@ export abstract class AbstractPool< if (this.workerChoiceStrategyContext.getStrategyPolicy().useDynamicWorker) { workerInfo.ready = true } + this.checkAndEmitDynamicWorkerCreationEvents() return workerNodeKey } @@ -1227,13 +1230,8 @@ export abstract class AbstractPool< } private checkAndEmitTaskExecutionEvents (): void { - if (this.emitter != null) { - if (this.busy) { - this.emitter.emit(PoolEvents.busy, this.info) - } - if (this.type === PoolTypes.dynamic && this.full) { - this.emitter.emit(PoolEvents.full, this.info) - } + if (this.busy) { + this.emitter?.emit(PoolEvents.busy, this.info) } } @@ -1243,6 +1241,14 @@ export abstract class AbstractPool< } } + private checkAndEmitDynamicWorkerCreationEvents (): void { + if (this.type === PoolTypes.dynamic) { + if (this.full) { + this.emitter?.emit(PoolEvents.full, this.info) + } + } + } + /** * Gets the worker information given its worker node key. *