yield-star-next-then-get-abrupt.js (3169B)
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-expr-static-private-method.template 5 /*--- 6 description: Return abrupt after getting next().then (Static async generator method as a ClassExpression element) 7 esid: prod-AsyncGeneratorPrivateMethod 8 features: [Symbol.iterator, Symbol.asyncIterator, async-iteration, class-static-methods-private] 9 flags: [generated, async] 10 info: | 11 ClassElement : 12 static 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 var C = class { 75 static async *#gen() { 76 callCount += 1; 77 yield* obj; 78 throw new Test262Error('abrupt completion closes iter'); 79 80 } 81 static get gen() { return this.#gen; } 82 } 83 84 // Test the private fields do not appear as properties before set to value 85 assert( 86 !Object.prototype.hasOwnProperty.call(C.prototype, "#gen"), 87 "#gen does not appear as an own property on C prototype" 88 ); 89 assert( 90 !Object.prototype.hasOwnProperty.call(C, "#gen"), 91 "#gen does not appear as an own property on C constructor" 92 ); 93 94 var iter = C.gen(); 95 96 iter.next().then(() => { 97 throw new Test262Error('Promise incorrectly fulfilled.'); 98 }, v => { 99 assert.sameValue(v, reason, 'reject reason'); 100 101 iter.next().then(({ done, value }) => { 102 assert.sameValue(done, true, 'the iterator is completed'); 103 assert.sameValue(value, undefined, 'value is undefined'); 104 }).then($DONE, $DONE); 105 }).catch($DONE); 106 107 assert.sameValue(callCount, 1); 108 109 // Test the private fields do not appear as properties after set to value 110 assert( 111 !Object.prototype.hasOwnProperty.call(C.prototype, "#gen"), 112 "#gen does not appear as an own property on C prototype" 113 ); 114 assert( 115 !Object.prototype.hasOwnProperty.call(C, "#gen"), 116 "#gen does not appear as an own property on C constructor" 117 );