| // Copyright 2016 the V8 project authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| let {session, contextGroup, Protocol} = InspectorTest.start('Tests updating call frame scopes'); |
| |
| contextGroup.addScript( |
| `function TestFunction() |
| { |
| var a = 2; |
| debugger; |
| debugger; |
| }`); |
| |
| var newVariableValue = 55; |
| |
| Protocol.Debugger.enable(); |
| |
| Protocol.Debugger.oncePaused().then(handleDebuggerPaused); |
| |
| Protocol.Runtime.evaluate({ "expression": "setTimeout(TestFunction, 0)" }); |
| |
| function handleDebuggerPaused(messageObject) |
| { |
| InspectorTest.log("Paused on 'debugger;'"); |
| |
| var topFrame = messageObject.params.callFrames[0]; |
| var topFrameId = topFrame.callFrameId; |
| Protocol.Debugger.evaluateOnCallFrame({ "callFrameId": topFrameId, "expression": "a = " + newVariableValue }).then(callbackChangeValue); |
| } |
| |
| function callbackChangeValue(response) |
| { |
| InspectorTest.log("Variable value changed"); |
| Protocol.Debugger.oncePaused().then(callbackGetBacktrace); |
| Protocol.Debugger.resume(); |
| } |
| |
| function callbackGetBacktrace(response) |
| { |
| InspectorTest.log("Stacktrace re-read again"); |
| var localScope = response.params.callFrames[0].scopeChain[0]; |
| Protocol.Runtime.getProperties({ "objectId": localScope.object.objectId }).then(callbackGetProperties); |
| } |
| |
| function callbackGetProperties(response) |
| { |
| InspectorTest.log("Scope variables downloaded anew"); |
| var varNamedA; |
| var propertyList = response.result.result; |
| for (var i = 0; i < propertyList.length; i++) { |
| if (propertyList[i].name === "a") { |
| varNamedA = propertyList[i]; |
| break; |
| } |
| } |
| if (varNamedA) { |
| var actualValue = varNamedA.value.value; |
| InspectorTest.log("New variable is " + actualValue + ", expected is " + newVariableValue + ", old was: 2"); |
| InspectorTest.log(actualValue === newVariableValue ? "SUCCESS" : "FAIL"); |
| } else { |
| InspectorTest.log("Failed to find variable in scope"); |
| } |
| InspectorTest.completeTest(); |
| } |