node/deps/v8/test/inspector/debugger/set-script-source-top-frame-with-additional-activations.js
Michaël Zasso 6bd756d7c6
deps: update V8 to 10.7.193.13
PR-URL: https://github.com/nodejs/node/pull/44741
Fixes: https://github.com/nodejs/node/issues/44650
Fixes: https://github.com/nodejs/node/issues/37472
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Jiawen Geng <technicalcute@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2022-10-11 07:24:33 +02:00

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();
})();