mirror of
https://github.com/nodejs/node.git
synced 2025-05-15 16:01:52 +00:00

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