mirror of
https://github.com/nodejs/node.git
synced 2025-05-17 22:02:33 +00:00

Squashed from: - deps: Add node-inspect 1.10.1 This adds a reimplementation of the old CLI debugger (`node debug`) against the new debugger protocol (`node --inspect`). This is necessary because the old protocol won't be supported in future versions of V8. - deps: Update node-inspect to 1.10.2 Starting with 1.10.2 the test suite should pass consistently on windows. - deps: Update to node-inspect 1.10.4 PR-URL: https://github.com/nodejs/node/pull/10187 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: James M Snell <jasnell@gmail.com>
64 lines
1.8 KiB
JavaScript
64 lines
1.8 KiB
JavaScript
'use strict';
|
|
const Path = require('path');
|
|
|
|
const { test } = require('tap');
|
|
|
|
const startCLI = require('./start-cli');
|
|
|
|
test('break on (uncaught) exceptions', (t) => {
|
|
const script = Path.join('examples', 'exceptions.js');
|
|
const cli = startCLI([script]);
|
|
|
|
function onFatal(error) {
|
|
cli.quit();
|
|
throw error;
|
|
}
|
|
|
|
return cli.waitFor(/break/)
|
|
.then(() => cli.waitForPrompt())
|
|
.then(() => {
|
|
t.match(cli.output, `break in ${script}:1`);
|
|
})
|
|
// making sure it will die by default:
|
|
.then(() => cli.command('c'))
|
|
.then(() => cli.waitFor(/disconnect/))
|
|
|
|
// Next run: With `breakOnException` it pauses in both places
|
|
.then(() => cli.stepCommand('r'))
|
|
.then(() => {
|
|
t.match(cli.output, `break in ${script}:1`);
|
|
})
|
|
.then(() => cli.command('breakOnException'))
|
|
.then(() => cli.stepCommand('c'))
|
|
.then(() => {
|
|
t.match(cli.output, `exception in ${script}:4`);
|
|
})
|
|
.then(() => cli.stepCommand('c'))
|
|
.then(() => {
|
|
t.match(cli.output, `exception in ${script}:10`);
|
|
})
|
|
|
|
// Next run: With `breakOnUncaught` it only pauses on the 2nd exception
|
|
.then(() => cli.command('breakOnUncaught'))
|
|
.then(() => cli.stepCommand('r')) // also, the setting survives the restart
|
|
.then(() => {
|
|
t.match(cli.output, `break in ${script}:1`);
|
|
})
|
|
.then(() => cli.stepCommand('c'))
|
|
.then(() => {
|
|
t.match(cli.output, `exception in ${script}:10`);
|
|
})
|
|
|
|
// Next run: Back to the initial state! It should die again.
|
|
.then(() => cli.command('breakOnNone'))
|
|
.then(() => cli.stepCommand('r'))
|
|
.then(() => {
|
|
t.match(cli.output, `break in ${script}:1`);
|
|
})
|
|
.then(() => cli.command('c'))
|
|
.then(() => cli.waitFor(/disconnect/))
|
|
|
|
.then(() => cli.quit())
|
|
.then(null, onFatal);
|
|
});
|