b369e89f98
PerformPromiseAll doesn't set iteratorRecord.[[Done]] to true if Promise.resolve is not callable. This makes Promise.all call IteratorClose. BUG=v8:10452 Change-Id: Icbe17416a733f68ef09f1c610d715f544c2a3b8a Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2164789 Reviewed-by: Shu-yu Guo <syg@chromium.org> Commit-Queue: Marja Hölttä <marja@chromium.org> Cr-Commit-Position: refs/heads/master@{#67416}
31 lines
706 B
JavaScript
31 lines
706 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
|
|
|
|
load('test/mjsunit/test-async.js');
|
|
|
|
// Promise.allSettled should call IteratorClose if Promise.resolve is not callable.
|
|
|
|
let returnCount = 0;
|
|
let iter = {
|
|
[Symbol.iterator]() {
|
|
return {
|
|
return() {
|
|
returnCount++;
|
|
}
|
|
};
|
|
}
|
|
};
|
|
|
|
Promise.resolve = "certainly not callable";
|
|
|
|
testAsync(assert => {
|
|
assert.plan(2);
|
|
Promise.allSettled(iter).then(assert.unreachable, reason => {
|
|
assert.equals(true, reason instanceof TypeError);
|
|
assert.equals(1, returnCount);
|
|
});
|
|
});
|