node/test/parallel/test-domain-top-level-error-handler-throw.js
Rich Trott f593f9e9ef test: adjust comments for upcoming lint rule
Enforce `//` for multiline comments. Some tests mixed and matched, and
at least one did so in a (to me) surprising way.

PR-URL: https://github.com/nodejs/node/pull/35485
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2020-10-07 04:36:02 -07:00

51 lines
1.5 KiB
JavaScript

'use strict';
// The goal of this test is to make sure that when a top-level error
// handler throws an error following the handling of a previous error,
// the process reports the error message from the error thrown in the
// top-level error handler, not the one from the previous error.
require('../common');
const domainErrHandlerExMessage = 'exception from domain error handler';
const internalExMessage = 'You should NOT see me';
if (process.argv[2] === 'child') {
const domain = require('domain');
const d = domain.create();
d.on('error', function() {
throw new Error(domainErrHandlerExMessage);
});
d.run(function doStuff() {
process.nextTick(function() {
throw new Error(internalExMessage);
});
});
} else {
const fork = require('child_process').fork;
const assert = require('assert');
const child = fork(process.argv[1], ['child'], { silent: true });
let stderrOutput = '';
if (child) {
child.stderr.on('data', function onStderrData(data) {
stderrOutput += data.toString();
});
child.on('close', function onChildClosed() {
assert(stderrOutput.includes(domainErrHandlerExMessage));
assert.strictEqual(stderrOutput.includes(internalExMessage), false);
});
child.on('exit', function onChildExited(exitCode, signal) {
const expectedExitCode = 7;
const expectedSignal = null;
assert.strictEqual(exitCode, expectedExitCode);
assert.strictEqual(signal, expectedSignal);
});
}
}