52 lines
1.8 KiB
JavaScript
52 lines
1.8 KiB
JavaScript
|
// Copyright 2022 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.
|
||
|
|
||
|
const {session, contextGroup, Protocol} = InspectorTest.start(
|
||
|
'Checks that setScriptSource fails when editing the top-most stack frame, but that function also has an activation further down the stack');
|
||
|
|
||
|
const script = `
|
||
|
function callsTestExpression(a, b) {
|
||
|
return testExpression(a, b);
|
||
|
}
|
||
|
|
||
|
function testExpression(a, b) {
|
||
|
debugger;
|
||
|
if (!a && !b) {
|
||
|
return callsTestExpression(5, 3);
|
||
|
}
|
||
|
return a + b;
|
||
|
}`;
|
||
|
const replacementScript = script.replace('a + b', 'a * b');
|
||
|
|
||
|
contextGroup.addScript(script);
|
||
|
|
||
|
session.setupScriptMap();
|
||
|
|
||
|
(async () => {
|
||
|
Protocol.Debugger.enable();
|
||
|
const { params: { scriptId } } = await Protocol.Debugger.onceScriptParsed();
|
||
|
|
||
|
const evaluatePromise = Protocol.Runtime.evaluate({ expression: 'callsTestExpression()' });
|
||
|
let { params: { callFrames: pausedCallFrames } } = await Protocol.Debugger.oncePaused();
|
||
|
InspectorTest.log('First pause at (before live edit):');
|
||
|
await session.logSourceLocation(pausedCallFrames[0].location);
|
||
|
|
||
|
Protocol.Debugger.resume();
|
||
|
({ params: { callFrames: pausedCallFrames } } = await Protocol.Debugger.oncePaused());
|
||
|
InspectorTest.log('Second pause at (before live edit):');
|
||
|
await session.logSourceLocation(pausedCallFrames[0].location);
|
||
|
|
||
|
const response = await Protocol.Debugger.setScriptSource({ scriptId, scriptSource: replacementScript, allowTopFrameEditing: true })
|
||
|
InspectorTest.log('Debugger.setScriptSource result:');
|
||
|
InspectorTest.logMessage(response.result);
|
||
|
|
||
|
Protocol.Debugger.resume();
|
||
|
|
||
|
const { result: { result } } = await evaluatePromise;
|
||
|
InspectorTest.log('Evaluation result:');
|
||
|
InspectorTest.logMessage(result);
|
||
|
|
||
|
InspectorTest.completeTest();
|
||
|
})();
|