array-elision-iter-abpt.js (1825B)
1 // This file was procedurally generated from the following sources: 2 // - src/dstr-assignment/array-elision-iter-abpt.case 3 // - src/dstr-assignment/error/for-of.template 4 /*--- 5 description: IteratorClose is not called when iteration produces an abrupt completion (For..of statement) 6 esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation 7 features: [Symbol.iterator, destructuring-binding] 8 flags: [generated] 9 info: | 10 IterationStatement : 11 for ( LeftHandSideExpression of AssignmentExpression ) Statement 12 13 1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« », 14 AssignmentExpression, iterate). 15 2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement, 16 keyResult, assignment, labelSet). 17 18 13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation 19 20 [...] 21 4. If destructuring is true and if lhsKind is assignment, then 22 a. Assert: lhs is a LeftHandSideExpression. 23 b. Let assignmentPattern be the parse of the source text corresponding to 24 lhs using AssignmentPattern as the goal symbol. 25 [...] 26 27 ArrayAssignmentPattern : [ Elision ] 28 29 1. Let iterator be GetIterator(value). 30 [...] 31 5. If iteratorRecord.[[done]] is false, return IteratorClose(iterator, 32 result). 33 [...] 34 35 ---*/ 36 var nextCount = 0; 37 var returnCount = 0; 38 var iterable = {}; 39 var iterator = { 40 next: function() { 41 nextCount += 1; 42 throw new Test262Error(); 43 }, 44 return: function() { 45 returnCount += 1; 46 } 47 }; 48 iterable[Symbol.iterator] = function() { 49 return iterator; 50 }; 51 52 var counter = 0; 53 54 assert.throws(Test262Error, function() { 55 for ([ , ] of [iterable]) { 56 counter += 1; 57 } 58 counter += 1; 59 }); 60 61 assert.sameValue(counter, 0); 62 63 assert.sameValue(nextCount, 1); 64 assert.sameValue(returnCount, 0); 65 66 reportCompare(0, 0);