53 lines
1.5 KiB
JavaScript
53 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);
|
||
|
});
|
||
|
}
|
||
|
}
|