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.
		
			
				
	
	
		
			67 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // This file was procedurally generated from the following sources:
 | |
| // - src/dstr-binding/ary-ptrn-rest-not-final-ary.case
 | |
| // - src/dstr-binding/default/gen-meth.template
 | |
| /*---
 | |
| description: Rest element (array binding pattern) may not be followed by any element (generator method)
 | |
| esid: sec-generator-function-definitions-runtime-semantics-propertydefinitionevaluation
 | |
| es6id: 14.4.13
 | |
| features: [generators, destructuring-binding]
 | |
| flags: [generated]
 | |
| negative:
 | |
|   phase: parse
 | |
|   type: SyntaxError
 | |
| info: |
 | |
|     GeneratorMethod :
 | |
|         * PropertyName ( StrictFormalParameters ) { GeneratorBody }
 | |
| 
 | |
|     1. Let propKey be the result of evaluating PropertyName.
 | |
|     2. ReturnIfAbrupt(propKey).
 | |
|     3. If the function code for this GeneratorMethod 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 GeneratorFunctionCreate(Method,
 | |
|        StrictFormalParameters, GeneratorBody, scope, strict).
 | |
|     [...]
 | |
| 
 | |
|     9.2.1 [[Call]] ( thisArgument, argumentsList)
 | |
| 
 | |
|     [...]
 | |
|     7. Let result be OrdinaryCallEvaluateBody(F, argumentsList).
 | |
|     [...]
 | |
| 
 | |
|     9.2.1.3 OrdinaryCallEvaluateBody ( F, argumentsList )
 | |
| 
 | |
|     1. Let status be FunctionDeclarationInstantiation(F, argumentsList).
 | |
|     [...]
 | |
| 
 | |
|     9.2.12 FunctionDeclarationInstantiation(func, argumentsList)
 | |
| 
 | |
|     [...]
 | |
|     23. Let iteratorRecord be Record {[[iterator]]:
 | |
|         CreateListIterator(argumentsList), [[done]]: false}.
 | |
|     24. If hasDuplicates is true, then
 | |
|         [...]
 | |
|     25. Else,
 | |
|         b. Let formalStatus be IteratorBindingInitialization for formals with
 | |
|            iteratorRecord and env as arguments.
 | |
|     [...]
 | |
| 
 | |
|     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 obj = {
 | |
|   *method([...[x], y]) {
 | |
|     
 | |
|     callCount = callCount + 1;
 | |
|   }
 | |
| };
 | |
| 
 | |
| obj.method([1, 2, 3]).next();
 | |
| assert.sameValue(callCount, 1, 'generator method invoked exactly once');
 |