| // This file was procedurally generated from the following sources: |
| // - src/async-generators/yield-star-getiter-sync-not-callable-symbol-throw.case |
| // - src/async-generators/default/async-class-decl-private-method.template |
| /*--- |
| description: Throws a TypeError on a non-callable [Symbol.iterator] (symbol) (Async Generator method as a ClassDeclaration element) |
| esid: prod-AsyncGeneratorPrivateMethod |
| features: [Symbol.iterator, Symbol.asyncIterator, async-iteration, class-methods-private] |
| flags: [generated, async] |
| info: | |
| ClassElement : |
| PrivateMethodDefinition |
| |
| MethodDefinition : |
| AsyncGeneratorMethod |
| |
| Async Generator Function Definitions |
| |
| AsyncGeneratorMethod : |
| async [no LineTerminator here] * PropertyName ( UniqueFormalParameters ) { AsyncGeneratorBody } |
| |
| |
| YieldExpression: yield * AssignmentExpression |
| |
| 1. Let exprRef be the result of evaluating AssignmentExpression. |
| 2. Let value be ? GetValue(exprRef). |
| 3. Let generatorKind be ! GetGeneratorKind(). |
| 4. Let iterator be ? GetIterator(value, generatorKind). |
| ... |
| |
| GetIterator ( obj [ , hint ] ) |
| |
| ... |
| 3. If hint is async, |
| a. Set method to ? GetMethod(obj, @@asyncIterator). |
| b. If method is undefined, |
| i. Let syncMethod be ? GetMethod(obj, @@iterator). |
| ... |
| |
| GetMethod ( V, P ) |
| |
| ... |
| 2. Let func be ? GetV(V, P). |
| ... |
| 4. If IsCallable(func) is false, throw a TypeError exception. |
| ... |
| |
| ---*/ |
| var obj = { |
| [Symbol.iterator]: Symbol.iterator |
| }; |
| |
| |
| |
| var callCount = 0; |
| |
| class C { |
| async *#gen() { |
| callCount += 1; |
| yield* obj; |
| throw new Test262Error('abrupt completion closes iter'); |
| |
| } |
| get gen() { return this.#gen; } |
| } |
| |
| const c = new C(); |
| |
| // Test the private fields do not appear as properties before set to value |
| assert.sameValue(Object.hasOwnProperty.call(C.prototype, "#gen"), false, 'Object.hasOwnProperty.call(C.prototype, "#gen")'); |
| assert.sameValue(Object.hasOwnProperty.call(C, "#gen"), false, 'Object.hasOwnProperty.call(C, "#gen")'); |
| assert.sameValue(Object.hasOwnProperty.call(c, "#gen"), false, 'Object.hasOwnProperty.call(c, "#gen")'); |
| |
| var iter = c.gen(); |
| |
| iter.next().then(() => { |
| throw new Test262Error('Promise incorrectly fulfilled.'); |
| }, v => { |
| assert.sameValue(v.constructor, TypeError, "TypeError"); |
| |
| iter.next().then(({ done, value }) => { |
| assert.sameValue(done, true, 'the iterator is completed'); |
| assert.sameValue(value, undefined, 'value is undefined'); |
| }).then($DONE, $DONE); |
| }).catch($DONE); |
| |
| assert.sameValue(callCount, 1); |
| |
| // Test the private fields do not appear as properties after set to value |
| assert.sameValue(Object.hasOwnProperty.call(C.prototype, "#gen"), false, 'Object.hasOwnProperty.call(C.prototype, "#gen")'); |
| assert.sameValue(Object.hasOwnProperty.call(C, "#gen"), false, 'Object.hasOwnProperty.call(C, "#gen")'); |
| assert.sameValue(Object.hasOwnProperty.call(c, "#gen"), false, 'Object.hasOwnProperty.call(c, "#gen")'); |