6f994a0bdf
CL adopted from joshualitt@: https://chromium-review.googlesource.com/c/v8/v8/+/2002932 Link to explainer is here: https://github.com/tc39/proposal-promise-any Co-authored-by: Joshua Litt <joshualitt@chromium.org> Bug: v8:9808 Change-Id: I6872020e857d4b131d5663f95fd58e6271ccb067 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2124834 Commit-Queue: Marja Hölttä <marja@chromium.org> Reviewed-by: Jakob Gruber <jgruber@chromium.org> Reviewed-by: Igor Sheludko <ishell@chromium.org> Reviewed-by: Sathya Gunasekaran <gsathya@chromium.org> Reviewed-by: Shu-yu Guo <syg@chromium.org> Cr-Commit-Position: refs/heads/master@{#67502}
22 lines
764 B
JavaScript
22 lines
764 B
JavaScript
// Copyright 2020 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --allow-natives-syntax --harmony-promise-any
|
|
|
|
load('test/mjsunit/test-async.js');
|
|
|
|
// Make sure we properly throw a RangeError when overflowing the maximum
|
|
// number of elements for Promise.any, which is capped at 2^21 bits right
|
|
// now, since we store the indices as identity hash on the resolve element
|
|
// closures.
|
|
const a = new Array(2 ** 21 - 1);
|
|
const p = Promise.resolve(1);
|
|
for (let i = 0; i < a.length; ++i) a[i] = p;
|
|
testAsync(assert => {
|
|
assert.plan(1);
|
|
Promise.any(a).then(assert.unreachable, reason => {
|
|
assert.equals(true, reason instanceof RangeError);
|
|
});
|
|
});
|