From dd6e62fa9f66cce1f6feafc1d4931e764524f4c6 Mon Sep 17 00:00:00 2001 From: jazelly Date: Mon, 16 Sep 2024 20:43:27 +0930 Subject: [PATCH] lib: validate signals with interface converter --- lib/internal/abort_controller.js | 19 +++++++++---------- test/parallel/test-abortsignal-any.mjs | 13 +++++++++++++ 2 files changed, 22 insertions(+), 10 deletions(-) diff --git a/lib/internal/abort_controller.js b/lib/internal/abort_controller.js index ce05571c067398f..ec7a10e6ff69c7c 100644 --- a/lib/internal/abort_controller.js +++ b/lib/internal/abort_controller.js @@ -41,12 +41,11 @@ const { } = require('internal/errors'); const { converters, + createInterfaceConverter, createSequenceConverter, } = require('internal/webidl'); const { - validateAbortSignal, - validateAbortSignalArray, validateObject, validateUint32, kValidateObjectAllowObjects, @@ -229,11 +228,11 @@ class AbortSignal extends EventTarget { * @returns {AbortSignal} */ static any(signals) { - const signalsArray = createSequenceConverter( - converters.any, - )(signals); + const signalsArray = converters['sequence']( + signals, + { __proto__: null, context: 'signals' }, + ); - validateAbortSignalArray(signalsArray, 'signals'); const resultSignal = new AbortSignal(kDontThrowSymbol, { composite: true }); if (!signalsArray.length) { return resultSignal; @@ -353,6 +352,9 @@ class AbortSignal extends EventTarget { } } +converters.AbortSignal = createInterfaceConverter('AbortSignal', AbortSignal.prototype); +converters['sequence'] = createSequenceConverter(converters.AbortSignal); + function ClonedAbortSignal() { return new AbortSignal(kDontThrowSymbol, { transferable: true }); } @@ -442,10 +444,7 @@ function transferableAbortController() { * @returns {Promise} */ async function aborted(signal, resource) { - if (signal === undefined) { - throw new ERR_INVALID_ARG_TYPE('signal', 'AbortSignal', signal); - } - validateAbortSignal(signal, 'signal'); + converters.AbortSignal(signal, { __proto__: null, context: 'signal' }); validateObject(resource, 'resource', kValidateObjectAllowObjects); if (signal.aborted) return PromiseResolve(); diff --git a/test/parallel/test-abortsignal-any.mjs b/test/parallel/test-abortsignal-any.mjs index 4378c44d987f50c..19b5569c4779d1a 100644 --- a/test/parallel/test-abortsignal-any.mjs +++ b/test/parallel/test-abortsignal-any.mjs @@ -118,4 +118,17 @@ describe('AbortSignal.any()', { concurrency: !process.env.TEST_PARALLEL }, () => controller.abort(); assert.strictEqual(result, 1); }); + + it('throws TypeError if any value does not implement AbortSignal', () => { + const expectedError = { code: 'ERR_INVALID_ARG_TYPE' }; + assert.throws(() => AbortSignal.any([ null ]), expectedError); + assert.throws(() => AbortSignal.any([ undefined ]), expectedError); + assert.throws(() => AbortSignal.any([ '123' ]), expectedError); + assert.throws(() => AbortSignal.any([ 123 ]), expectedError); + assert.throws(() => AbortSignal.any([{}]), expectedError); + assert.throws(() => AbortSignal.any([{ aborted: true }]), expectedError); + assert.throws(() => AbortSignal.any([{ + aborted: true, reason: '', throwIfAborted: null, + }]), expectedError); + }); });