mirror of https://github.com/nodejs/node.git
test: add `Debugger.setInstrumentationBreakpoint` known issue
PR-URL: https://github.com/nodejs/node/pull/31137 Refs: https://github.com/nodejs/node/issues/31138 Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>pull/52966/head
parent
91d30f35c4
commit
291c1211f2
|
@ -603,7 +603,8 @@ function printSkipMessage(msg) {
|
|||
|
||||
function skip(msg) {
|
||||
printSkipMessage(msg);
|
||||
process.exit(0);
|
||||
// In known_issues test, skipping should produce a non-zero exit code.
|
||||
process.exit(require.main?.filename.startsWith(path.resolve(__dirname, '../known_issues/')) ? 1 : 0);
|
||||
}
|
||||
|
||||
// Returns true if the exit code "exitCode" and/or signal name "signal"
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
console.log('dep loaded');
|
|
@ -0,0 +1 @@
|
|||
require('./dep');
|
|
@ -0,0 +1,54 @@
|
|||
// This test validates inspector's Debugger.setInstrumentationBreakpoint method.
|
||||
// Refs: https://github.com/nodejs/node/issues/31138
|
||||
|
||||
'use strict';
|
||||
const common = require('../common');
|
||||
|
||||
common.skipIfInspectorDisabled();
|
||||
|
||||
const assert = require('assert');
|
||||
const { resolve: UrlResolve } = require('url');
|
||||
const fixtures = require('../common/fixtures');
|
||||
const { NodeInstance } = require('../common/inspector-helper.js');
|
||||
|
||||
async function testBreakpointBeforeScriptExecution(session) {
|
||||
console.log('[test]',
|
||||
'Verifying debugger stops on start of each script ' +
|
||||
'(Debugger.setInstrumentationBreakpoint with beforeScriptExecution)');
|
||||
const commands = [
|
||||
{ 'method': 'Runtime.enable' },
|
||||
{ 'method': 'Debugger.enable' },
|
||||
{ 'method': 'Debugger.setInstrumentationBreakpoint',
|
||||
'params': { 'instrumentation': 'beforeScriptExecution' } },
|
||||
{ 'method': 'Runtime.runIfWaitingForDebugger' },
|
||||
];
|
||||
|
||||
await session.send(commands);
|
||||
|
||||
// Break on start
|
||||
await session.waitForBreakOnLine(
|
||||
0, UrlResolve(session.scriptURL().toString(), 'main.js'));
|
||||
await session.send([{ 'method': 'Debugger.resume' }]);
|
||||
|
||||
// Script loaded
|
||||
await session.waitForBreakOnLine(
|
||||
0, UrlResolve(session.scriptURL().toString(), 'main.js'));
|
||||
await session.send([{ 'method': 'Debugger.resume' }]);
|
||||
|
||||
// Script loaded
|
||||
await session.waitForBreakOnLine(
|
||||
0, UrlResolve(session.scriptURL().toString(), 'dep.js'));
|
||||
await session.send([{ 'method': 'Debugger.resume' }]);
|
||||
}
|
||||
|
||||
async function runTest() {
|
||||
const main = fixtures.path('inspector-instrumentation-breakpoint', 'main.js');
|
||||
const child = new NodeInstance(['--inspect-brk=0'], '', main);
|
||||
|
||||
const session = await child.connectInspectorSession();
|
||||
await testBreakpointBeforeScriptExecution(session);
|
||||
await session.runToCompletion();
|
||||
assert.strictEqual((await child.expectShutdown()).exitCode, 0);
|
||||
}
|
||||
|
||||
runTest();
|
Loading…
Reference in New Issue