mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-25 17:53:53 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			112 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // This file was procedurally generated from the following sources:
 | |
| // - src/async-generators/yield-star-getiter-async-get-abrupt.case
 | |
| // - src/async-generators/default/async-class-decl-private-method.template
 | |
| /*---
 | |
| description: Abrupt completion while getting [Symbol.asyncIterator] (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).
 | |
|     ...
 | |
| 
 | |
|     GetMethod ( V, P )
 | |
| 
 | |
|     ...
 | |
|     2. Let func be ? GetV(V, P).
 | |
|     ...
 | |
| 
 | |
| ---*/
 | |
| var reason = {};
 | |
| var obj = {
 | |
|   get [Symbol.iterator]() {
 | |
|     throw new Test262Error('it should not get Symbol.iterator');
 | |
|   },
 | |
|   get [Symbol.asyncIterator]() {
 | |
|     throw reason;
 | |
|   }
 | |
| };
 | |
| 
 | |
| 
 | |
| 
 | |
| 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(
 | |
|   !Object.prototype.hasOwnProperty.call(C.prototype, "#gen"),
 | |
|   "#gen does not appear as an own property on C prototype"
 | |
| );
 | |
| assert(
 | |
|   !Object.prototype.hasOwnProperty.call(C, "#gen"),
 | |
|   "#gen does not appear as an own property on C constructor"
 | |
| );
 | |
| assert(
 | |
|   !Object.prototype.hasOwnProperty.call(c, "#gen"),
 | |
|   "#gen does not appear as an own property on C instance"
 | |
| );
 | |
| 
 | |
| var iter = c.gen();
 | |
| 
 | |
| iter.next().then(() => {
 | |
|   throw new Test262Error('Promise incorrectly fulfilled.');
 | |
| }, v => {
 | |
|   assert.sameValue(v, reason, "reject reason");
 | |
| 
 | |
|   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(
 | |
|   !Object.prototype.hasOwnProperty.call(C.prototype, "#gen"),
 | |
|   "#gen does not appear as an own property on C prototype"
 | |
| );
 | |
| assert(
 | |
|   !Object.prototype.hasOwnProperty.call(C, "#gen"),
 | |
|   "#gen does not appear as an own property on C constructor"
 | |
| );
 | |
| assert(
 | |
|   !Object.prototype.hasOwnProperty.call(c, "#gen"),
 | |
|   "#gen does not appear as an own property on C instance"
 | |
| );
 |