| // Copyright 2017 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 side-effect-free evaluation'); |
| |
| contextGroup.addScript(` |
| function testFunction() |
| { |
| var o = 0; |
| function f() { return 1; } |
| function g() { o = 2; return o; } |
| debugger; |
| } |
| //# sourceURL=foo.js`); |
| |
| Protocol.Debugger.enable(); |
| |
| Protocol.Debugger.oncePaused().then(debuggerPaused); |
| |
| Protocol.Runtime.evaluate({ "expression": "setTimeout(testFunction, 0)" }); |
| |
| var topFrameId; |
| |
| function debuggerPaused(messageObject) |
| { |
| InspectorTest.log("Paused on 'debugger;'"); |
| |
| topFrameId = messageObject.params.callFrames[0].callFrameId; |
| Protocol.Debugger.evaluateOnCallFrame({ callFrameId: topFrameId, expression: "f()"}).then(evaluatedFirst); |
| } |
| |
| function evaluatedFirst(response) |
| { |
| InspectorTest.log("f() returns " + response.result.result.value); |
| Protocol.Debugger.evaluateOnCallFrame({ callFrameId: topFrameId, expression: "g()"}).then(evaluatedSecond); |
| } |
| |
| function evaluatedSecond(response) |
| { |
| InspectorTest.log("g() returns " + response.result.result.value); |
| Protocol.Debugger.evaluateOnCallFrame({ callFrameId: topFrameId, expression: "f()", throwOnSideEffect: true}).then(evaluatedThird); |
| } |
| |
| function evaluatedThird(response) |
| { |
| InspectorTest.log("f() returns " + response.result.result.value); |
| Protocol.Debugger.evaluateOnCallFrame({ callFrameId: topFrameId, expression: "g()", throwOnSideEffect: true}).then(evaluatedFourth); |
| InspectorTest.completeTest(); |
| } |
| |
| function evaluatedFourth(response) |
| { |
| InspectorTest.log("g() throws " + response.result.result.className); |
| InspectorTest.completeTest(); |
| } |