From ca5607bbc8ad5bc6bbb78643be5fb41394625c83 Mon Sep 17 00:00:00 2001 From: sinkhaha <1468709106@qq.com> Date: Mon, 13 May 2024 02:16:09 +0800 Subject: [PATCH] events: update MaxListenersExceededWarning message log PR-URL: https://github.com/nodejs/node/pull/51921 Reviewed-By: Moshe Atlow Reviewed-By: Benjamin Gruenbaum Reviewed-By: Luigi Pinca --- lib/events.js | 2 +- lib/internal/event_target.js | 2 +- .../test-event-emitter-max-listeners-warning-for-null.js | 2 +- .../test-event-emitter-max-listeners-warning-for-symbol.js | 2 +- test/parallel/test-event-emitter-max-listeners-warning.js | 2 +- test/parallel/test-eventtarget-memoryleakwarning.js | 5 ++++- 6 files changed, 9 insertions(+), 6 deletions(-) diff --git a/lib/events.js b/lib/events.js index 8b30b13272a..4d8b5bbb1e6 100644 --- a/lib/events.js +++ b/lib/events.js @@ -593,7 +593,7 @@ function _addListener(target, type, listener, prepend) { // No error code for this since it is a Warning const w = genericNodeError( `Possible EventEmitter memory leak detected. ${existing.length} ${String(type)} listeners ` + - `added to ${inspect(target, { depth: -1 })}. Use emitter.setMaxListeners() to increase limit`, + `added to ${inspect(target, { depth: -1 })}. MaxListeners is ${m}. Use emitter.setMaxListeners() to increase limit`, { name: 'MaxListenersExceededWarning', emitter: target, type: type, count: existing.length }); process.emitWarning(w); } diff --git a/lib/internal/event_target.js b/lib/internal/event_target.js index 77a28b21507..1c7fd9dedb4 100644 --- a/lib/internal/event_target.js +++ b/lib/internal/event_target.js @@ -561,7 +561,7 @@ class EventTarget { // eslint-disable-next-line no-restricted-syntax const w = new Error('Possible EventTarget memory leak detected. ' + `${size} ${type} listeners ` + - `added to ${inspect(this, { depth: -1 })}. Use ` + + `added to ${inspect(this, { depth: -1 })}. MaxListeners is ${this[kMaxEventTargetListeners]}. Use ` + 'events.setMaxListeners() to increase limit'); w.name = 'MaxListenersExceededWarning'; w.target = this; diff --git a/test/parallel/test-event-emitter-max-listeners-warning-for-null.js b/test/parallel/test-event-emitter-max-listeners-warning-for-null.js index 40b5f798cba..81cfc96f43a 100644 --- a/test/parallel/test-event-emitter-max-listeners-warning-for-null.js +++ b/test/parallel/test-event-emitter-max-listeners-warning-for-null.js @@ -16,7 +16,7 @@ process.on('warning', common.mustCall((warning) => { assert.strictEqual(warning.count, 2); assert.strictEqual(warning.type, null); assert.ok(warning.message.includes( - '2 null listeners added to [EventEmitter].')); + '2 null listeners added to [EventEmitter]. MaxListeners is 1.')); })); e.on(null, () => {}); diff --git a/test/parallel/test-event-emitter-max-listeners-warning-for-symbol.js b/test/parallel/test-event-emitter-max-listeners-warning-for-symbol.js index c27b38c2523..212f9fb1b27 100644 --- a/test/parallel/test-event-emitter-max-listeners-warning-for-symbol.js +++ b/test/parallel/test-event-emitter-max-listeners-warning-for-symbol.js @@ -18,7 +18,7 @@ process.on('warning', common.mustCall((warning) => { assert.strictEqual(warning.count, 2); assert.strictEqual(warning.type, symbol); assert.ok(warning.message.includes( - '2 Symbol(symbol) listeners added to [EventEmitter].')); + '2 Symbol(symbol) listeners added to [EventEmitter]. MaxListeners is 1.')); })); e.on(symbol, () => {}); diff --git a/test/parallel/test-event-emitter-max-listeners-warning.js b/test/parallel/test-event-emitter-max-listeners-warning.js index 3d047766b38..fc23355349e 100644 --- a/test/parallel/test-event-emitter-max-listeners-warning.js +++ b/test/parallel/test-event-emitter-max-listeners-warning.js @@ -23,7 +23,7 @@ process.on('warning', common.mustCall((warning) => { assert.strictEqual(warning.count, 2); assert.strictEqual(warning.type, 'event-type'); assert.ok(warning.message.includes( - '2 event-type listeners added to [FakeInput].')); + '2 event-type listeners added to [FakeInput]. MaxListeners is 1.')); })); e.on('event-type', () => {}); diff --git a/test/parallel/test-eventtarget-memoryleakwarning.js b/test/parallel/test-eventtarget-memoryleakwarning.js index 36fe068fb80..b2da553ab4c 100644 --- a/test/parallel/test-eventtarget-memoryleakwarning.js +++ b/test/parallel/test-eventtarget-memoryleakwarning.js @@ -12,18 +12,21 @@ const { setTimeout } = require('timers/promises'); common.expectWarning({ MaxListenersExceededWarning: [ ['Possible EventTarget memory leak detected. 3 foo listeners added to ' + - 'EventTarget. Use events.setMaxListeners() ' + + 'EventTarget. MaxListeners is 2. Use events.setMaxListeners() ' + 'to increase limit'], ['Possible EventTarget memory leak detected. 3 foo listeners added to ' + '[MessagePort [EventTarget]]. ' + + 'MaxListeners is 2. ' + 'Use events.setMaxListeners() to increase ' + 'limit'], ['Possible EventTarget memory leak detected. 3 foo listeners added to ' + '[MessagePort [EventTarget]]. ' + + 'MaxListeners is 2. ' + 'Use events.setMaxListeners() to increase ' + 'limit'], ['Possible EventTarget memory leak detected. 3 foo listeners added to ' + '[AbortSignal]. ' + + 'MaxListeners is 2. ' + 'Use events.setMaxListeners() to increase ' + 'limit'], ],