diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /js/src/tests/test262/built-ins/Promise/any/capability-resolve-throws-reject.js | |
parent | Initial commit. (diff) | |
download | firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/tests/test262/built-ins/Promise/any/capability-resolve-throws-reject.js')
-rw-r--r-- | js/src/tests/test262/built-ins/Promise/any/capability-resolve-throws-reject.js | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Promise/any/capability-resolve-throws-reject.js b/js/src/tests/test262/built-ins/Promise/any/capability-resolve-throws-reject.js new file mode 100644 index 0000000000..0022473869 --- /dev/null +++ b/js/src/tests/test262/built-ins/Promise/any/capability-resolve-throws-reject.js @@ -0,0 +1,50 @@ +// |reftest| async +// Copyright (C) 2020 Rick Waldron. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-promise.any +description: > + Iterator is not closed when the "resolve" capability returns an abrupt + completion. +info: | + Let C be the this value. + Let promiseCapability be ? NewPromiseCapability(C). + Let iteratorRecord be GetIterator(iterable). + IfAbruptRejectPromise(iteratorRecord, promiseCapability). + Let result be PerformPromiseAny(iteratorRecord, C, promiseCapability). + If result is an abrupt completion, then + If iteratorRecord.[[Done]] is false, set result to IteratorClose(iteratorRecord, result). + IfAbruptRejectPromise(result, promiseCapability). + Return Completion(result). + +features: [Promise.any, Symbol.iterator] +flags: [async] +---*/ +let callCount = 0; +let thrown = new Test262Error(); +function P(executor) { + callCount++; + return new Promise((_, reject) => { + callCount++; + executor(() => { + callCount++; + throw thrown; + }, (...args) => { + callCount++; + reject(...args); + }); + }); +}; +P.resolve = Promise.resolve; + +Promise.any.call(P, [1]) + .then(() => { + $DONE('Promise incorrectly fulfilled.'); + }, (error) => { + // The error was not the result of promise + // resolution, so will not be an AggregateError + assert.sameValue(thrown, error); + assert.sameValue(callCount, 6); + }).then($DONE, $DONE); + + |