mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
6a7d3ca515
Highlights: * The `node-inspect` test suite passes against latest master. * Removes use of deprecated `repl.rli`. Compare: https://github.com/nodejs/node-inspect/compare/v1.11.5...v1.11.6 PR-URL: https://github.com/nodejs/node/pull/28039 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com> Reviewed-By: Yongsheng Zhang <zyszys98@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
69 lines
2.1 KiB
JavaScript
69 lines
2.1 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.waitForInitialBreak()
|
|
.then(() => cli.waitForPrompt())
|
|
.then(() => {
|
|
t.match(cli.breakInfo, { filename: script, line: 1 });
|
|
})
|
|
// making sure it will die by default:
|
|
.then(() => cli.command('c'))
|
|
// TODO: Remove FATAL ERROR once node doesn't show a FATAL ERROR anymore
|
|
.then(() => cli.waitFor(/disconnect|FATAL ERROR/))
|
|
|
|
// Next run: With `breakOnException` it pauses in both places
|
|
.then(() => cli.stepCommand('r'))
|
|
.then(() => cli.waitForInitialBreak())
|
|
.then(() => {
|
|
t.match(cli.breakInfo, { filename: script, line: 1 });
|
|
})
|
|
.then(() => cli.command('breakOnException'))
|
|
.then(() => cli.stepCommand('c'))
|
|
.then(() => {
|
|
t.match(cli.output, `exception in ${script}:3`);
|
|
})
|
|
.then(() => cli.stepCommand('c'))
|
|
.then(() => {
|
|
t.match(cli.output, `exception in ${script}:9`);
|
|
})
|
|
|
|
// 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(() => cli.waitForInitialBreak())
|
|
.then(() => {
|
|
t.match(cli.breakInfo, { filename: script, line: 1 });
|
|
})
|
|
.then(() => cli.stepCommand('c'))
|
|
.then(() => {
|
|
t.match(cli.output, `exception in ${script}:9`);
|
|
})
|
|
|
|
// Next run: Back to the initial state! It should die again.
|
|
.then(() => cli.command('breakOnNone'))
|
|
.then(() => cli.stepCommand('r'))
|
|
.then(() => cli.waitForInitialBreak())
|
|
.then(() => {
|
|
t.match(cli.breakInfo, { filename: script, line: 1 });
|
|
})
|
|
.then(() => cli.command('c'))
|
|
// TODO: Remove FATAL ERROR once node doesn't show a FATAL ERROR anymore
|
|
.then(() => cli.waitFor(/disconnect|FATAL ERROR/))
|
|
|
|
.then(() => cli.quit())
|
|
.then(null, onFatal);
|
|
});
|