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