async-func-dstr-let-ary-ptrn-elem-obj-prop-id.js (2457B)
1 // |reftest| async 2 // This file was procedurally generated from the following sources: 3 // - src/dstr-binding-for-await/ary-ptrn-elem-obj-prop-id.case 4 // - src/dstr-binding-for-await/default/for-await-of-async-func-let.template 5 /*--- 6 description: BindingElement with object binding pattern and initializer is not used (for-await-of statement) 7 esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation 8 features: [destructuring-binding, async-iteration] 9 flags: [generated, async] 10 info: | 11 IterationStatement : 12 for await ( ForDeclaration of AssignmentExpression ) Statement 13 14 [...] 15 2. Return ? ForIn/OfBodyEvaluation(ForDeclaration, Statement, keyResult, 16 lexicalBinding, labelSet, async). 17 18 13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation 19 20 [...] 21 4. Let destructuring be IsDestructuring of lhs. 22 [...] 23 6. Repeat 24 [...] 25 j. If destructuring is false, then 26 [...] 27 k. Else 28 i. If lhsKind is assignment, then 29 [...] 30 ii. Else if lhsKind is varBinding, then 31 [...] 32 iii. Else, 33 1. Assert: lhsKind is lexicalBinding. 34 2. Assert: lhs is a ForDeclaration. 35 3. Let status be the result of performing BindingInitialization 36 for lhs passing nextValue and iterationEnv as arguments. 37 [...] 38 39 13.3.3.6 Runtime Semantics: IteratorBindingInitialization 40 41 BindingElement : BindingPattern Initializer_opt 42 43 [...] 44 2. If iteratorRecord.[[done]] is true, let v be undefined. 45 3. If Initializer is present and v is undefined, then 46 a. Let defaultValue be the result of evaluating Initializer. 47 b. Let v be ? GetValue(defaultValue). 48 4. Return the result of performing BindingInitialization of BindingPattern 49 with v and environment as the arguments. 50 ---*/ 51 52 var iterCount = 0; 53 54 async function fn() { 55 for await (let [{ u: v, w: x, y: z } = { u: 444, w: 555, y: 666 }] of [[{ u: 777, w: 888, y: 999 }]]) { 56 assert.sameValue(v, 777); 57 assert.sameValue(x, 888); 58 assert.sameValue(z, 999); 59 60 assert.throws(ReferenceError, function() { 61 u; 62 }); 63 assert.throws(ReferenceError, function() { 64 w; 65 }); 66 assert.throws(ReferenceError, function() { 67 y; 68 }); 69 70 iterCount += 1; 71 } 72 } 73 74 fn() 75 .then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE) 76 .then($DONE, $DONE);