mirror of
https://github.com/nodejs/node.git
synced 2025-05-07 15:35:41 +00:00

This refactors two tests to ignore line numbers in stack traces. That way changed line numbers do not have any impact on the test outcome anymore. PR-URL: https://github.com/nodejs/node/pull/28608 Fixes: https://github.com/nodejs/node/issues/28546 Reviewed-By: Jiawen Geng <technicalcute@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Lance Ball <lball@redhat.com> Reviewed-By: Anto Aravinth <anto.aravinth.cse@gmail.com>
75 lines
1.8 KiB
JavaScript
75 lines
1.8 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
const ArrayStream = require('../common/arraystream');
|
|
const fixtures = require('../common/fixtures');
|
|
const assert = require('assert');
|
|
const repl = require('repl');
|
|
|
|
const stackRegExp = /repl:[0-9]+:[0-9]+/g;
|
|
|
|
function run({ command, expected }) {
|
|
let accum = '';
|
|
|
|
const inputStream = new ArrayStream();
|
|
const outputStream = new ArrayStream();
|
|
|
|
outputStream.write = (data) => accum += data.replace('\r', '');
|
|
|
|
const r = repl.start({
|
|
prompt: '',
|
|
input: inputStream,
|
|
output: outputStream,
|
|
terminal: false,
|
|
useColors: false
|
|
});
|
|
|
|
r.write(`${command}\n`);
|
|
assert.strictEqual(
|
|
accum.replace(stackRegExp, 'repl:*:*'),
|
|
expected.replace(stackRegExp, 'repl:*:*')
|
|
);
|
|
r.close();
|
|
}
|
|
|
|
const origPrepareStackTrace = Error.prepareStackTrace;
|
|
Error.prepareStackTrace = (err, stack) => {
|
|
if (err instanceof SyntaxError)
|
|
return err.toString();
|
|
stack.push(err);
|
|
return stack.reverse().join('--->\n');
|
|
};
|
|
|
|
process.on('uncaughtException', (e) => {
|
|
Error.prepareStackTrace = origPrepareStackTrace;
|
|
throw e;
|
|
});
|
|
|
|
const tests = [
|
|
{
|
|
// test .load for a file that throws
|
|
command: `.load ${fixtures.path('repl-pretty-stack.js')}`,
|
|
expected: 'Thrown:\nError: Whoops!--->\nrepl:*:*--->\nd (repl:*:*)' +
|
|
'--->\nc (repl:*:*)--->\nb (repl:*:*)--->\na (repl:*:*)\n'
|
|
},
|
|
{
|
|
command: 'let x y;',
|
|
expected: 'Thrown:\n' +
|
|
'let x y;\n ^\n\nSyntaxError: Unexpected identifier\n'
|
|
},
|
|
{
|
|
command: 'throw new Error(\'Whoops!\')',
|
|
expected: 'Thrown:\nError: Whoops!\n'
|
|
},
|
|
{
|
|
command: 'foo = bar;',
|
|
expected: 'Thrown:\nReferenceError: bar is not defined\n'
|
|
},
|
|
// test anonymous IIFE
|
|
{
|
|
command: '(function() { throw new Error(\'Whoops!\'); })()',
|
|
expected: 'Thrown:\nError: Whoops!--->\nrepl:*:*\n'
|
|
}
|
|
];
|
|
|
|
tests.forEach(run);
|