mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-25 17:53:53 +02:00 
			
		
		
		
	Early errors may result from parsing the source text of a test file, but they may also result from parsing some other source text as referenced through the ES2015 module syntax. The latter form of early error is not necessarily detectable by ECMAScript parsers, however. Because of this, the label "early" is not sufficiently precise for all Test262 consumers to correctly interpret all tests. Update the "phase" name of "early" to "parse" for all those negative tests that describe errors resulting from parsing of the file's source text directly. A forthcoming commit will update the remaining tests to use a "phase" name that is more specific to module resolution.
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // This file was procedurally generated from the following sources:
 | |
| // - src/dstr-binding/ary-ptrn-rest-init-obj.case
 | |
| // - src/dstr-binding/default/cls-expr-async-gen-meth-dflt.template
 | |
| /*---
 | |
| description: Reset element (nested object pattern) does not support initializer (class expression async generator method (default parameter))
 | |
| esid: sec-class-definitions-runtime-semantics-evaluation
 | |
| features: [async-iteration]
 | |
| flags: [generated, async]
 | |
| negative:
 | |
|   phase: parse
 | |
|   type: SyntaxError
 | |
| info: |
 | |
|     ClassExpression : class BindingIdentifieropt ClassTail
 | |
| 
 | |
|     1. If BindingIdentifieropt is not present, let className be undefined.
 | |
|     2. Else, let className be StringValue of BindingIdentifier.
 | |
|     3. Let value be the result of ClassDefinitionEvaluation of ClassTail
 | |
|        with argument className.
 | |
|     [...]
 | |
| 
 | |
|     14.5.14 Runtime Semantics: ClassDefinitionEvaluation
 | |
| 
 | |
|     21. For each ClassElement m in order from methods
 | |
|         a. If IsStatic of m is false, then
 | |
|            i. Let status be the result of performing
 | |
|               PropertyDefinitionEvaluation for m with arguments proto and
 | |
|               false.
 | |
|         [...]
 | |
| 
 | |
|     Runtime Semantics: PropertyDefinitionEvaluation
 | |
| 
 | |
|     AsyncGeneratorMethod :
 | |
|         async [no LineTerminator here] * PropertyName ( UniqueFormalParameters )
 | |
|             { AsyncGeneratorBody }
 | |
| 
 | |
|     1. Let propKey be the result of evaluating PropertyName.
 | |
|     2. ReturnIfAbrupt(propKey).
 | |
|     3. If the function code for this AsyncGeneratorMethod is strict mode code, let strict be true.
 | |
|        Otherwise let strict be false.
 | |
|     4. Let scope be the running execution context's LexicalEnvironment.
 | |
|     5. Let closure be ! AsyncGeneratorFunctionCreate(Method, UniqueFormalParameters,
 | |
|        AsyncGeneratorBody, scope, strict).
 | |
|     [...]
 | |
| 
 | |
| 
 | |
|     13.3.3 Destructuring Binding Patterns
 | |
|     ArrayBindingPattern[Yield] :
 | |
|         [ Elisionopt BindingRestElement[?Yield]opt ]
 | |
|         [ BindingElementList[?Yield] ]
 | |
|         [ BindingElementList[?Yield] , Elisionopt BindingRestElement[?Yield]opt ]
 | |
| ---*/
 | |
| throw "Test262: This statement should not be evaluated.";
 | |
| 
 | |
| 
 | |
| var callCount = 0;
 | |
| var C = class {
 | |
|   async *method([...{ x } = []] = []) {
 | |
|     
 | |
|     callCount = callCount + 1;
 | |
|   }
 | |
| };
 | |
| 
 | |
| new C().method().next().then(() => {
 | |
|     assert.sameValue(callCount, 1, 'invoked exactly once');    
 | |
| }).then($DONE, $DONE);
 |