Index: test/mjsunit/es6/debug-blockscopes.js |
diff --git a/test/mjsunit/es6/debug-blockscopes.js b/test/mjsunit/es6/debug-blockscopes.js |
deleted file mode 100644 |
index 47a5d6a0fea3b2614e8a4e4be8100ef6098407b0..0000000000000000000000000000000000000000 |
--- a/test/mjsunit/es6/debug-blockscopes.js |
+++ /dev/null |
@@ -1,491 +0,0 @@ |
-// Copyright 2011 the V8 project authors. All rights reserved. |
-// Redistribution and use in source and binary forms, with or without |
-// modification, are permitted provided that the following conditions are |
-// met: |
-// |
-// * Redistributions of source code must retain the above copyright |
-// notice, this list of conditions and the following disclaimer. |
-// * Redistributions in binary form must reproduce the above |
-// copyright notice, this list of conditions and the following |
-// disclaimer in the documentation and/or other materials provided |
-// with the distribution. |
-// * Neither the name of Google Inc. nor the names of its |
-// contributors may be used to endorse or promote products derived |
-// from this software without specific prior written permission. |
-// |
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
- |
-// Flags: --expose-debug-as debug --allow-natives-syntax --noanalyze-environment-liveness |
-// The functions used for testing backtraces. They are at the top to make the |
-// testing of source line/column easier. |
- |
-"use strict"; |
- |
-// Get the Debug object exposed from the debug context global object. |
-var Debug = debug.Debug; |
- |
-var test_name; |
-var listener_delegate; |
-var listener_called; |
-var exception; |
-var begin_test_count = 0; |
-var end_test_count = 0; |
-var break_count = 0; |
- |
- |
-// Debug event listener which delegates. |
-function listener(event, exec_state, event_data, data) { |
- try { |
- if (event == Debug.DebugEvent.Break) { |
- break_count++; |
- listener_called = true; |
- listener_delegate(exec_state); |
- } |
- } catch (e) { |
- print(e, e.stack); |
- exception = e; |
- } |
-} |
- |
-// Add the debug event listener. |
-Debug.setListener(listener); |
- |
- |
-// Initialize for a new test. |
-function BeginTest(name) { |
- test_name = name; |
- listener_delegate = null; |
- listener_called = false; |
- exception = null; |
- begin_test_count++; |
-} |
- |
- |
-// Check result of a test. |
-function EndTest() { |
- assertTrue(listener_called, "listerner not called for " + test_name); |
- assertNull(exception, test_name, exception); |
- end_test_count++; |
-} |
- |
-var global_object = this; |
- |
-// Check that the scope chain contains the expected types of scopes. |
-function CheckScopeChain(scopes, exec_state) { |
- assertEquals(scopes.length, exec_state.frame().scopeCount()); |
- for (var i = 0; i < scopes.length; i++) { |
- var scope = exec_state.frame().scope(i); |
- assertTrue(scope.isScope()); |
- assertEquals(scopes[i], scope.scopeType()); |
- |
- // Check the global object when hitting the global scope. |
- if (scopes[i] == debug.ScopeType.Global) { |
- // Objects don't have same class (one is "global", other is "Object", |
- // so just check the properties directly. |
- assertPropertiesEqual(global_object, scope.scopeObject().value()); |
- } |
- } |
-} |
- |
-// Check that the content of the scope is as expected. For functions just check |
-// that there is a function. |
-function CheckScopeContent(content, number, exec_state) { |
- var scope = exec_state.frame().scope(number); |
- var count = 0; |
- for (var p in content) { |
- var property_mirror = scope.scopeObject().property(p); |
- if (property_mirror.isUndefined()) { |
- print('property ' + p + ' not found in scope'); |
- } |
- assertFalse(property_mirror.isUndefined(), |
- 'property ' + p + ' not found in scope'); |
- if (typeof(content[p]) === 'function') { |
- assertTrue(property_mirror.value().isFunction()); |
- } else { |
- assertEquals(content[p], property_mirror.value().value(), |
- 'property ' + p + ' has unexpected value'); |
- } |
- count++; |
- } |
- |
- // 'arguments' and might be exposed in the local and closure scope. Just |
- // ignore this. |
- var scope_size = scope.scopeObject().properties().length; |
- if (!scope.scopeObject().property('arguments').isUndefined()) { |
- scope_size--; |
- } |
- // Temporary variables introduced by the parser have not been materialized. |
- assertTrue(scope.scopeObject().property('').isUndefined()); |
- |
- if (count != scope_size) { |
- print('Names found in scope:'); |
- var names = scope.scopeObject().propertyNames(); |
- for (var i = 0; i < names.length; i++) { |
- print(names[i]); |
- } |
- } |
- assertEquals(count, scope_size); |
-} |
- |
- |
-function assertEqualsUnlessOptimized(expected, value, f) { |
- try { |
- assertEquals(expected, value); |
- } catch (e) { |
- assertOptimized(f); |
- } |
-} |
- |
-// Simple empty block scope in local scope. |
-BeginTest("Local block 1"); |
- |
-function local_block_1() { |
- { |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({}, 0, exec_state); |
-}; |
-local_block_1(); |
-EndTest(); |
- |
- |
-// Simple empty block scope in local scope with a parameter. |
-BeginTest("Local 2"); |
- |
-function local_2(a) { |
- { |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({a:1}, 0, exec_state); |
-}; |
-local_2(1); |
-EndTest(); |
- |
- |
-// Local scope with a parameter and a local variable. |
-BeginTest("Local 3"); |
- |
-function local_3(a) { |
- let x = 3; |
- debugger; |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({a:1,x:3}, 0, exec_state); |
-}; |
-local_3(1); |
-EndTest(); |
- |
- |
-// Local scope with parameters and local variables. |
-BeginTest("Local 4"); |
- |
-function local_4(a, b) { |
- let x = 3; |
- let y = 4; |
- debugger; |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({a:1,b:2,x:3,y:4}, 0, exec_state); |
-}; |
-local_4(1, 2); |
-EndTest(); |
- |
- |
-// Single variable in a block scope. |
-BeginTest("Local 5"); |
- |
-function local_5(a) { |
- { |
- let x = 5; |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:5}, 0, exec_state); |
- CheckScopeContent({a:1}, 1, exec_state); |
-}; |
-local_5(1); |
-EndTest(); |
- |
- |
-// Two variables in a block scope. |
-BeginTest("Local 6"); |
- |
-function local_6(a) { |
- { |
- let x = 6; |
- let y = 7; |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:6,y:7}, 0, exec_state); |
- CheckScopeContent({a:1}, 1, exec_state); |
-}; |
-local_6(1); |
-EndTest(); |
- |
- |
-// Two variables in a block scope. |
-BeginTest("Local 7"); |
- |
-function local_7(a) { |
- { |
- { |
- let x = 8; |
- debugger; |
- } |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:8}, 0, exec_state); |
- CheckScopeContent({a:1}, 1, exec_state); |
-}; |
-local_7(1); |
-EndTest(); |
- |
- |
-// Simple closure formed by returning an inner function referering to an outer |
-// block local variable and an outer function's parameter. |
-BeginTest("Closure 1"); |
- |
-function closure_1(a) { |
- var x = 2; |
- let y = 3; |
- if (true) { |
- let z = 4; |
- function f() { |
- debugger; |
- return a + x + y + z; |
- }; |
- return f; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Local, |
- debug.ScopeType.Block, |
- debug.ScopeType.Closure, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({}, 0, exec_state); |
- CheckScopeContent({a:1,x:2,y:3}, 2, exec_state); |
-}; |
-closure_1(1)(); |
-EndTest(); |
- |
- |
-// Simple for-in loop over the keys of an object. |
-BeginTest("For loop 1"); |
- |
-function for_loop_1() { |
- for (let x in {y:undefined}) { |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:'y'}, 0, exec_state); |
- // The function scope contains a temporary iteration variable, but it is |
- // hidden to the debugger. |
-}; |
-for_loop_1(); |
-EndTest(); |
- |
- |
-// For-in loop over the keys of an object with a block scoped let variable |
-// shadowing the iteration variable. |
-BeginTest("For loop 2"); |
- |
-function for_loop_2() { |
- for (let x in {y:undefined}) { |
- let x = 3; |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:3}, 0, exec_state); |
- CheckScopeContent({x:'y'}, 1, exec_state); |
- // The function scope contains a temporary iteration variable, hidden to the |
- // debugger. |
-}; |
-for_loop_2(); |
-EndTest(); |
- |
- |
-// Simple for loop. |
-BeginTest("For loop 3"); |
- |
-function for_loop_3() { |
- for (let x = 3; x < 4; ++x) { |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:3}, 0, exec_state); |
- CheckScopeContent({}, 1, exec_state); |
-}; |
-for_loop_3(); |
-EndTest(); |
- |
- |
-// For loop with a block scoped let variable shadowing the iteration variable. |
-BeginTest("For loop 4"); |
- |
-function for_loop_4() { |
- for (let x = 3; x < 4; ++x) { |
- let x = 5; |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:5}, 0, exec_state); |
- CheckScopeContent({x:3}, 1, exec_state); |
- CheckScopeContent({}, 2, exec_state); |
-}; |
-for_loop_4(); |
-EndTest(); |
- |
- |
-// For loop with two variable declarations. |
-BeginTest("For loop 5"); |
- |
-function for_loop_5() { |
- for (let x = 3, y = 5; x < 4; ++x) { |
- debugger; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:3,y:5}, 0, exec_state); |
- CheckScopeContent({}, 1, exec_state); |
-}; |
-for_loop_5(); |
-EndTest(); |
- |
- |
-// Uninitialized variables |
-BeginTest("Uninitialized 1"); |
- |
-function uninitialized_1() { |
- { |
- debugger; |
- let x = 1; |
- } |
-} |
- |
-listener_delegate = function(exec_state) { |
- CheckScopeChain([debug.ScopeType.Block, |
- debug.ScopeType.Local, |
- debug.ScopeType.Script, |
- debug.ScopeType.Global], exec_state); |
- CheckScopeContent({x:undefined}, 0, exec_state); |
-}; |
-uninitialized_1(); |
-EndTest(); |
- |
- |
-// Block scopes shadowing |
-BeginTest("Block scopes shadowing 1"); |
-function shadowing_1() { |
- let i = 0; |
- { |
- let i = 5; |
- debugger; |
- } |
- assertEquals(0, i); |
-} |
- |
-listener_delegate = function (exec_state) { |
- assertEqualsUnlessOptimized(5, exec_state.frame(0).evaluate("i").value()); |
-} |
-shadowing_1(); |
-EndTest(); |
- |
- |
-// Block scopes shadowing |
-BeginTest("Block scopes shadowing 2"); |
-function shadowing_2() { |
- let i = 0; |
- { |
- let j = 5; |
- debugger; |
- } |
-} |
- |
-listener_delegate = function (exec_state) { |
- assertEqualsUnlessOptimized(0, exec_state.frame(0).evaluate("i").value()); |
- assertEqualsUnlessOptimized(5, exec_state.frame(0).evaluate("j").value()); |
-} |
-shadowing_2(); |
-EndTest(); |