From 2aa4a82499d4becd2284cdb482213d541b8804dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 28 Apr 2024 16:29:10 +0200 Subject: Adding upstream version 86.0.1. Signed-off-by: Daniel Baumann --- .../built-ins/Promise/all/resolve-non-thenable.js | 76 ++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 js/src/tests/test262/built-ins/Promise/all/resolve-non-thenable.js (limited to 'js/src/tests/test262/built-ins/Promise/all/resolve-non-thenable.js') diff --git a/js/src/tests/test262/built-ins/Promise/all/resolve-non-thenable.js b/js/src/tests/test262/built-ins/Promise/all/resolve-non-thenable.js new file mode 100644 index 0000000000..76c1781fd5 --- /dev/null +++ b/js/src/tests/test262/built-ins/Promise/all/resolve-non-thenable.js @@ -0,0 +1,76 @@ +// |reftest| async +// Copyright (C) 2016 the V8 project authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +description: Resolving with a non-thenable object value +es6id: 25.4.4.1 +info: | + [...] + 6. Let promiseCapability be NewPromiseCapability(C). + [...] + 11. Let result be PerformPromiseAll(iteratorRecord, C, promiseCapability). + [...] + + 25.4.4.1.1 Runtime Semantics: PerformPromiseAll + [...] + 6. Repeat + [...] + d. If next is false, + [...] + iii. If remainingElementsCount.[[value]] is 0, + 1. Let valuesArray be CreateArrayFromList(values). + 2. Let resolveResult be Call(resultCapability.[[Resolve]], + undefined, «valuesArray»). + 3. ReturnIfAbrupt(resolveResult) + iv. Return resultCapability.[[Promise]]. + + 25.4.1.3.2 Promise Resolve Functions + [...] + 8. Let then be Get(resolution, "then"). + 9. If then is an abrupt completion, then + [...] + 10. Let thenAction be then.[[value]]. + 11. If IsCallable(thenAction) is false, then + a. Return FulfillPromise(promise, resolution). +flags: [async] +---*/ + +var v1 = {}; +var v2 = {}; +var v3 = {}; + +Promise.all([v1, v2, v3]) + .then(function(values) { + if (!values) { + $DONE('The promise should be resolved with a value.'); + return; + } + if (values.constructor !== Array) { + $DONE('The promise should be resolved with an Array instance.'); + return; + } + + if (values.length !== 3) { + $DONE('The promise should be resolved with an array of proper length.'); + return; + } + + if (values[0] !== v1) { + $DONE('The promise should be resolved with the correct element values (#1)'); + return; + } + + if (values[1] !== v2) { + $DONE('The promise should be resolved with the correct element values (#2)'); + return; + } + + if (values[2] !== v3) { + $DONE('The promise should be resolved with the correct element values (#3)'); + return; + } + + $DONE(); + }, function() { + $DONE('The promise should not be rejected.'); + }); -- cgit v1.2.3