yield-star-next-then-get-abrupt.js (3384B)
1 // |reftest| async 2 // This file was procedurally generated from the following sources: 3 // - src/async-generators/yield-star-next-then-get-abrupt.case 4 // - src/async-generators/default/async-class-decl-private-method.template 5 /*--- 6 description: Return abrupt after getting next().then (Async Generator method as a ClassDeclaration element) 7 esid: prod-AsyncGeneratorPrivateMethod 8 features: [Symbol.iterator, Symbol.asyncIterator, async-iteration, class-methods-private] 9 flags: [generated, async] 10 info: | 11 ClassElement : 12 PrivateMethodDefinition 13 14 MethodDefinition : 15 AsyncGeneratorMethod 16 17 Async Generator Function Definitions 18 19 AsyncGeneratorMethod : 20 async [no LineTerminator here] * PropertyName ( UniqueFormalParameters ) { AsyncGeneratorBody } 21 22 23 YieldExpression: yield * AssignmentExpression 24 ... 25 6. Repeat 26 a. If received.[[Type]] is normal, then 27 ii. Let innerResult be ? Invoke(iterator, "next", 28 « received.[[Value]] »). 29 iii. If generatorKind is async, then set innerResult to 30 ? Await(innerResult). 31 ... 32 33 Await 34 35 ... 36 2. Let promiseCapability be ! NewPromiseCapability(%Promise%). 37 3. Perform ! Call(promiseCapability.[[Resolve]], undefined, « promise »). 38 ... 39 40 Promise Resolve Functions 41 42 ... 43 8. Let then be Get(resolution, "then"). 44 ... 45 10. Get thenAction be then.[[Value]]. 46 ... 47 12. Perform EnqueueJob("PromiseJobs", PromiseResolveThenableJob, « promise, 48 resolution, thenAction »). 49 ... 50 51 ---*/ 52 var reason = {}; 53 var obj = { 54 get [Symbol.iterator]() { 55 throw new Test262Error('it should not get Symbol.iterator'); 56 }, 57 [Symbol.asyncIterator]() { 58 return { 59 next() { 60 return { 61 get then() { 62 throw reason; 63 } 64 }; 65 } 66 }; 67 } 68 }; 69 70 71 72 var callCount = 0; 73 74 class C { 75 async *#gen() { 76 callCount += 1; 77 yield* obj; 78 throw new Test262Error('abrupt completion closes iter'); 79 80 } 81 get gen() { return this.#gen; } 82 } 83 84 const c = new C(); 85 86 // Test the private fields do not appear as properties before set to value 87 assert( 88 !Object.prototype.hasOwnProperty.call(C.prototype, "#gen"), 89 "#gen does not appear as an own property on C prototype" 90 ); 91 assert( 92 !Object.prototype.hasOwnProperty.call(C, "#gen"), 93 "#gen does not appear as an own property on C constructor" 94 ); 95 assert( 96 !Object.prototype.hasOwnProperty.call(c, "#gen"), 97 "#gen does not appear as an own property on C instance" 98 ); 99 100 var iter = c.gen(); 101 102 iter.next().then(() => { 103 throw new Test262Error('Promise incorrectly fulfilled.'); 104 }, v => { 105 assert.sameValue(v, reason, 'reject reason'); 106 107 iter.next().then(({ done, value }) => { 108 assert.sameValue(done, true, 'the iterator is completed'); 109 assert.sameValue(value, undefined, 'value is undefined'); 110 }).then($DONE, $DONE); 111 }).catch($DONE); 112 113 assert.sameValue(callCount, 1); 114 115 // Test the private fields do not appear as properties after set to value 116 assert( 117 !Object.prototype.hasOwnProperty.call(C.prototype, "#gen"), 118 "#gen does not appear as an own property on C prototype" 119 ); 120 assert( 121 !Object.prototype.hasOwnProperty.call(C, "#gen"), 122 "#gen does not appear as an own property on C constructor" 123 ); 124 assert( 125 !Object.prototype.hasOwnProperty.call(c, "#gen"), 126 "#gen does not appear as an own property on C instance" 127 );