mirror of https://github.com/tc39/test262.git
63 lines
1.8 KiB
JavaScript
63 lines
1.8 KiB
JavaScript
|
// This file was procedurally generated from the following sources:
|
||
|
// - src/dstr-binding/ary-ptrn-elem-id-iter-step-err.case
|
||
|
// - src/dstr-binding/error/for-of-const.template
|
||
|
/*---
|
||
|
description: Error forwarding when IteratorStep returns an abrupt completion (for-of statement)
|
||
|
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
||
|
es6id: 13.7.5.11
|
||
|
features: [destructuring-binding]
|
||
|
flags: [generated]
|
||
|
info: |
|
||
|
IterationStatement :
|
||
|
for ( ForDeclaration of AssignmentExpression ) Statement
|
||
|
|
||
|
[...]
|
||
|
3. Return ForIn/OfBodyEvaluation(ForDeclaration, Statement, keyResult,
|
||
|
lexicalBinding, labelSet).
|
||
|
|
||
|
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
||
|
|
||
|
[...]
|
||
|
3. Let destructuring be IsDestructuring of lhs.
|
||
|
[...]
|
||
|
5. Repeat
|
||
|
[...]
|
||
|
h. If destructuring is false, then
|
||
|
[...]
|
||
|
i. Else
|
||
|
i. If lhsKind is assignment, then
|
||
|
[...]
|
||
|
ii. Else if lhsKind is varBinding, then
|
||
|
[...]
|
||
|
iii. Else,
|
||
|
1. Assert: lhsKind is lexicalBinding.
|
||
|
2. Assert: lhs is a ForDeclaration.
|
||
|
3. Let status be the result of performing BindingInitialization
|
||
|
for lhs passing nextValue and iterationEnv as arguments.
|
||
|
[...]
|
||
|
|
||
|
13.3.3.6 Runtime Semantics: IteratorBindingInitialization
|
||
|
|
||
|
SingleNameBinding : BindingIdentifier Initializeropt
|
||
|
|
||
|
[...]
|
||
|
4. If iteratorRecord.[[done]] is false, then
|
||
|
a. Let next be IteratorStep(iteratorRecord.[[iterator]]).
|
||
|
b. If next is an abrupt completion, set iteratorRecord.[[done]] to true.
|
||
|
c. ReturnIfAbrupt(next).
|
||
|
---*/
|
||
|
var g = {};
|
||
|
g[Symbol.iterator] = function() {
|
||
|
return {
|
||
|
next: function() {
|
||
|
throw new Test262Error();
|
||
|
}
|
||
|
};
|
||
|
};
|
||
|
|
||
|
assert.throws(Test262Error, function() {
|
||
|
for (const [x] of [g]) {
|
||
|
return;
|
||
|
}
|
||
|
});
|