Skip to content

Commit

Permalink
events: remove error listener on signal abort
Browse files Browse the repository at this point in the history
Fixes: nodejs#36949

PR-URL: nodejs#36969
Reviewed-By: Antoine du Hamel <[email protected]>
Reviewed-By: Benjamin Gruenbaum <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Luigi Pinca <[email protected]>
  • Loading branch information
Lxxyx authored and jasnell committed Jan 18, 2021
1 parent 9d7fb22 commit 06c4693
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/events.js
Original file line number Diff line number Diff line change
Expand Up @@ -736,7 +736,7 @@ async function once(emitter, name, options = {}) {
}
function abortListener() {
eventTargetAgnosticRemoveListener(emitter, name, resolver);
eventTargetAgnosticRemoveListener(emitter, 'error', resolver);
eventTargetAgnosticRemoveListener(emitter, 'error', errorListener);
reject(lazyDOMException('The operation was aborted', 'AbortError'));
}
if (signal != null) {
Expand Down
14 changes: 14 additions & 0 deletions test/parallel/test-events-once.js
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,19 @@ async function abortSignalAfterEvent() {
await once(ee, 'foo', { signal: ac.signal });
}

async function abortSignalRemoveListener() {
const ee = new EventEmitter();
const ac = new AbortController();

try {
process.nextTick(() => ac.abort());
await once(ee, 'test', { signal: ac.signal });
} catch {
strictEqual(ee.listeners('test').length, 0);
strictEqual(ee.listeners('error').length, 0);
}
}

async function eventTargetAbortSignalBefore() {
const et = new EventTarget();
const ac = new AbortController();
Expand Down Expand Up @@ -218,6 +231,7 @@ Promise.all([
abortSignalBefore(),
abortSignalAfter(),
abortSignalAfterEvent(),
abortSignalRemoveListener(),
eventTargetAbortSignalBefore(),
eventTargetAbortSignalAfter(),
eventTargetAbortSignalAfterEvent(),
Expand Down

0 comments on commit 06c4693

Please sign in to comment.