2020-03-24 22:22:11 +01:00
|
|
|
// Copyright (C) 2019 Leo Balter, 2020 Rick Waldron. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
/*---
|
|
|
|
description: >
|
|
|
|
Error thrown when accesing the instance's `then` method (closing iterator)
|
|
|
|
esid: sec-promise.any
|
|
|
|
info: |
|
|
|
|
5. Let result be PerformPromiseAny(iteratorRecord, C, promiseCapability).
|
|
|
|
6. If result is an abrupt completion, then
|
|
|
|
a. If iteratorRecord.[[Done]] is false, set result to IteratorClose(iteratorRecord, result).
|
|
|
|
b. IfAbruptRejectPromise(result, promiseCapability).
|
|
|
|
|
|
|
|
Runtime Semantics: PerformPromiseAny
|
|
|
|
|
|
|
|
r. Perform ? Invoke(nextPromise, "then", « resultCapability.[[Resolve]], rejectElement »).
|
|
|
|
|
|
|
|
flags: [async]
|
2020-03-25 14:43:22 +01:00
|
|
|
features: [Promise.any, Symbol.iterator, arrow-function, computed-property-names, Symbol]
|
2020-03-24 22:22:11 +01:00
|
|
|
---*/
|
|
|
|
let error = new Test262Error();
|
2020-03-25 14:42:35 +01:00
|
|
|
let promise = Promise.resolve();
|
2020-03-24 22:22:11 +01:00
|
|
|
let returnCount = 0;
|
|
|
|
let iter = {
|
|
|
|
[Symbol.iterator]() {
|
|
|
|
return {
|
|
|
|
next() {
|
|
|
|
return {
|
|
|
|
done: false,
|
|
|
|
value: promise
|
|
|
|
};
|
|
|
|
},
|
|
|
|
return() {
|
|
|
|
returnCount += 1;
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Object.defineProperty(promise, 'then', {
|
|
|
|
get() {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Promise.any(iter).then(() => {
|
|
|
|
$DONE('The promise should be rejected, but was resolved');
|
|
|
|
}, (reason) => {
|
|
|
|
assert.sameValue(returnCount, 1);
|
|
|
|
assert.sameValue(reason, error);
|
|
|
|
}).then($DONE, $DONE);
|