mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-26 09:13:54 +01:00 
			
		
		
		
	Add tests that assert the management of the running execution context's LexicalEnvironment and VariableEnvironment components, as created by the following abstract operations: - NewDeclarativeEnvironment - NewObjectEnvironment - NewFunctionEnvironment Many tests require the use of non-strict direct eval, meaning they may not be run in strict mode. This does not effect coverage because the semantics in these cases are not observable from strict mode code. Some situations require the creation of a binding, but this binding has no relevance to the test itself. In these cases, use names consisting solely of the underscore character (`_`). Avoid the use of Block statements wherever possible, as these trigger the creation of additional environments which may interfere with the behavior under test.
		
			
				
	
	
		
			33 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Copyright (C) 2016 the V8 project authors. All rights reserved.
 | |
| // This code is governed by the BSD license found in the LICENSE file.
 | |
| /*---
 | |
| esid: sec-switch-statement-runtime-semantics-evaluation
 | |
| description: Retainment of existing variable environment (`case` clause)
 | |
| info: |
 | |
|     1. Let exprRef be the result of evaluating Expression.
 | |
|     2. Let switchValue be ? GetValue(exprRef).
 | |
|     3. Let oldEnv be the running execution context's LexicalEnvironment.
 | |
|     4. Let blockEnv be NewDeclarativeEnvironment(oldEnv).
 | |
|     5. Perform BlockDeclarationInstantiation(CaseBlock, blockEnv).
 | |
|     6. Set the running execution context's LexicalEnvironment to blockEnv.
 | |
|     7. Let R be the result of performing CaseBlockEvaluation of CaseBlock with
 | |
|       argument switchValue.
 | |
|     [...]
 | |
| flags: [noStrict]
 | |
| ---*/
 | |
| 
 | |
| var probeExpr, probeSelector, probeStmt;
 | |
| var probeBefore = function() { return x; };
 | |
| 
 | |
| switch (eval('var x = 1;'), probeExpr = function() { return x; }, null) {
 | |
|   case eval('var x = 2;'), probeSelector = function() { return x; }, null:
 | |
|     probeStmt = function() { return x; };
 | |
|     var x = 3;
 | |
| }
 | |
| 
 | |
| assert.sameValue(probeBefore(), 3, 'reference preceeding statement');
 | |
| assert.sameValue(probeExpr(), 3, 'reference from first Expression');
 | |
| assert.sameValue(probeSelector(), 3, 'reference from "selector" Expression');
 | |
| assert.sameValue(probeStmt(), 3, 'reference from Statement position');
 | |
| assert.sameValue(x, 3, 'reference following statement');
 |