ary-ptrn-elem-id-iter-val-err.js (2286B)
1 // This file was procedurally generated from the following sources: 2 // - src/dstr-binding/ary-ptrn-elem-id-iter-val-err.case 3 // - src/dstr-binding/error/func-decl.template 4 /*--- 5 description: Error forwarding when IteratorValue returns an abrupt completion (function declaration) 6 esid: sec-function-definitions-runtime-semantics-instantiatefunctionobject 7 features: [Symbol.iterator, destructuring-binding] 8 flags: [generated] 9 info: | 10 FunctionDeclaration : 11 function BindingIdentifier ( FormalParameters ) { FunctionBody } 12 13 [...] 14 3. Let F be FunctionCreate(Normal, FormalParameters, FunctionBody, 15 scope, strict). 16 [...] 17 18 9.2.1 [[Call]] ( thisArgument, argumentsList) 19 20 [...] 21 7. Let result be OrdinaryCallEvaluateBody(F, argumentsList). 22 [...] 23 24 9.2.1.3 OrdinaryCallEvaluateBody ( F, argumentsList ) 25 26 1. Let status be FunctionDeclarationInstantiation(F, argumentsList). 27 [...] 28 29 9.2.12 FunctionDeclarationInstantiation(func, argumentsList) 30 31 [...] 32 23. Let iteratorRecord be Record {[[iterator]]: 33 CreateListIterator(argumentsList), [[done]]: false}. 34 24. If hasDuplicates is true, then 35 [...] 36 25. Else, 37 b. Let formalStatus be IteratorBindingInitialization for formals with 38 iteratorRecord and env as arguments. 39 [...] 40 41 13.3.3.6 Runtime Semantics: IteratorBindingInitialization 42 43 SingleNameBinding : BindingIdentifier Initializeropt 44 45 [...] 46 4. If iteratorRecord.[[done]] is false, then 47 a. Let next be IteratorStep(iteratorRecord.[[iterator]]). 48 b. If next is an abrupt completion, set iteratorRecord.[[done]] to true. 49 c. ReturnIfAbrupt(next). 50 d. If next is false, set iteratorRecord.[[done]] to true. 51 e. Else, 52 i. Let v be IteratorValue(next). 53 ii. If v is an abrupt completion, set iteratorRecord.[[done]] to 54 true. 55 iii. ReturnIfAbrupt(v). 56 57 ---*/ 58 var poisonedValue = Object.defineProperty({}, 'value', { 59 get: function() { 60 throw new Test262Error(); 61 } 62 }); 63 var g = {}; 64 g[Symbol.iterator] = function() { 65 return { 66 next: function() { 67 return poisonedValue; 68 } 69 }; 70 }; 71 72 function f([x]) {} 73 74 assert.throws(Test262Error, function() { 75 f(g); 76 }); 77 78 reportCompare(0, 0);