tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

array-elem-trlg-iter-elision-iter-nrml-close-err.js (2237B)


      1 // This file was procedurally generated from the following sources:
      2 // - src/dstr-assignment/array-elem-trlg-iter-elision-iter-nrml-close-err.case
      3 // - src/dstr-assignment/error/for-of.template
      4 /*---
      5 description: Abrupt completion returned from IteratorClose (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 :
     28        [ AssignmentElementList , Elisionopt AssignmentRestElementopt ]
     29 
     30    [...]
     31    6. If Elision is present, then
     32       a. Let status be the result of performing
     33          IteratorDestructuringAssignmentEvaluation of Elision with
     34          iteratorRecord as the argument.
     35       b. If status is an abrupt completion, then
     36          [...]
     37    8. If iteratorRecord.[[done]] is false, return IteratorClose(iterator,
     38       status).
     39 
     40 ---*/
     41 var nextCount = 0;
     42 var returnCount = 0;
     43 var iterable = {};
     44 var x;
     45 var iterator = {
     46  next: function() {
     47    nextCount += 1;
     48 
     49    // Set an upper-bound to limit unnecessary iteration in non-conformant
     50    // implementations
     51    return { done: nextCount > 10 };
     52  },
     53  return: function() {
     54    returnCount += 1;
     55    throw new Test262Error();
     56  }
     57 };
     58 iterable[Symbol.iterator] = function() {
     59  return iterator;
     60 };
     61 
     62 var counter = 0;
     63 
     64 assert.throws(Test262Error, function() {
     65  for ([ x , , ] of [iterable]) {
     66    counter += 1;
     67  }
     68  counter += 1;
     69 });
     70 
     71 assert.sameValue(counter, 0);
     72 
     73 assert.sameValue(nextCount, 2);
     74 assert.sameValue(returnCount, 1);
     75 
     76 reportCompare(0, 0);