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/allSettled/capability-resolve-throws-no-close.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/allSettled/capability-resolve-throws-no-close.js')
-rw-r--r-- | js/src/tests/test262/built-ins/Promise/allSettled/capability-resolve-throws-no-close.js | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Promise/allSettled/capability-resolve-throws-no-close.js b/js/src/tests/test262/built-ins/Promise/allSettled/capability-resolve-throws-no-close.js new file mode 100644 index 0000000000..e59ca8916e --- /dev/null +++ b/js/src/tests/test262/built-ins/Promise/allSettled/capability-resolve-throws-no-close.js @@ -0,0 +1,66 @@ +// Copyright (C) 2019 Leo Balter. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-promise.allsettled +description: > + Iterator is not closed when the "resolve" capability returns an abrupt + completion. +info: | + ... + 3. Let promiseCapability be ? NewPromiseCapability(C). + ... + 6. Let result be PerformPromiseAllSettled(iteratorRecord, C, promiseCapability). + 7. If result is an abrupt completion, then + a. If iteratorRecord.[[Done]] is false, set result to IteratorClose(iteratorRecord, result). + b. IfAbruptRejectPromise(result, promiseCapability). + 8. Return Completion(result). + + Runtime Semantics: PerformPromiseAllSettled + + ... + 6. Repeat + ... + d. If next is false, then + ... + iii. If remainingElementsCount.[[Value]] is 0, then + 1. Let valuesArray be CreateArrayFromList(values). + 2. Perform ? Call(resultCapability.[[Resolve]], undefined, « valuesArray »). + + IfAbruptRejectPromise + + 1. IfAbruptRejectPromise(value, capability). +features: [Promise.allSettled, Symbol.iterator] +---*/ + +var returnCount = 0; +var iter = {}; +iter[Symbol.iterator] = function() { + return { + next() { + return { + done: true + }; + }, + return() { + returnCount += 1; + return {}; + } + }; +}; +var P = function(executor) { + return new Promise(function(_, reject) { + executor(function() { + throw new Test262Error(); + }, reject); + }); +}; + +P.resolve = function() { + throw new Test262Error(); +}; + +Promise.allSettled.call(P, iter); + +assert.sameValue(returnCount, 0); + +reportCompare(0, 0); |