|  | // 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; } | 
|  | f,g; | 
|  | 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(); | 
|  | } |