mirror of https://github.com/lukechilds/node.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
257 lines
5.5 KiB
257 lines
5.5 KiB
10 years ago
|
'use strict';
|
||
10 years ago
|
|
||
9 years ago
|
// This test makes sure that when using --abort-on-uncaught-exception and
|
||
|
// when throwing an error from within a domain that has an error handler
|
||
|
// setup, the process _does not_ abort.
|
||
10 years ago
|
|
||
9 years ago
|
const common = require('../common');
|
||
|
const assert = require('assert');
|
||
|
const domain = require('domain');
|
||
|
const child_process = require('child_process');
|
||
10 years ago
|
|
||
8 years ago
|
let errorHandlerCalled = false;
|
||
10 years ago
|
|
||
9 years ago
|
const tests = [
|
||
|
function nextTick() {
|
||
|
const d = domain.create();
|
||
10 years ago
|
|
||
9 years ago
|
d.once('error', function(err) {
|
||
|
errorHandlerCalled = true;
|
||
10 years ago
|
});
|
||
|
|
||
9 years ago
|
d.run(function() {
|
||
|
process.nextTick(function() {
|
||
|
throw new Error('exceptional!');
|
||
|
});
|
||
|
});
|
||
|
},
|
||
10 years ago
|
|
||
9 years ago
|
function timer() {
|
||
|
const d = domain.create();
|
||
10 years ago
|
|
||
9 years ago
|
d.on('error', function(err) {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
10 years ago
|
|
||
9 years ago
|
d.run(function() {
|
||
|
setTimeout(function() {
|
||
10 years ago
|
throw new Error('exceptional!');
|
||
9 years ago
|
}, 33);
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function immediate() {
|
||
|
const d = domain.create();
|
||
|
|
||
|
d.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
setImmediate(function() {
|
||
|
throw new Error('boom!');
|
||
10 years ago
|
});
|
||
9 years ago
|
});
|
||
|
},
|
||
10 years ago
|
|
||
9 years ago
|
function timerPlusNextTick() {
|
||
|
const d = domain.create();
|
||
10 years ago
|
|
||
9 years ago
|
d.on('error', function(err) {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
setTimeout(function() {
|
||
|
process.nextTick(function() {
|
||
|
throw new Error('exceptional!');
|
||
|
});
|
||
|
}, 33);
|
||
|
});
|
||
|
},
|
||
10 years ago
|
|
||
9 years ago
|
function firstRun() {
|
||
|
const d = domain.create();
|
||
10 years ago
|
|
||
9 years ago
|
d.on('error', function(err) {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
throw new Error('exceptional!');
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function fsAsync() {
|
||
|
const d = domain.create();
|
||
|
|
||
|
d.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
8 years ago
|
const fs = require('fs');
|
||
9 years ago
|
fs.exists('/non/existing/file', function onExists(exists) {
|
||
|
throw new Error('boom!');
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function netServer() {
|
||
|
const net = require('net');
|
||
|
const d = domain.create();
|
||
|
|
||
|
d.on('error', function(err) {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
const server = net.createServer(function(conn) {
|
||
|
conn.pipe(conn);
|
||
|
});
|
||
9 years ago
|
server.listen(0, common.localhostIPv4, function() {
|
||
|
const conn = net.connect(this.address().port, common.localhostIPv4);
|
||
9 years ago
|
conn.once('data', function() {
|
||
|
throw new Error('ok');
|
||
|
});
|
||
|
conn.end('ok');
|
||
|
server.close();
|
||
10 years ago
|
});
|
||
9 years ago
|
});
|
||
|
},
|
||
|
|
||
|
function firstRunOnlyTopLevelErrorHandler() {
|
||
|
const d = domain.create();
|
||
|
const d2 = domain.create();
|
||
|
|
||
|
d.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
d2.run(function() {
|
||
|
throw new Error('boom!');
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function firstRunNestedWithErrorHandler() {
|
||
|
const d = domain.create();
|
||
|
const d2 = domain.create();
|
||
|
|
||
|
d2.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
d2.run(function() {
|
||
|
throw new Error('boom!');
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function timeoutNestedWithErrorHandler() {
|
||
|
const d = domain.create();
|
||
|
const d2 = domain.create();
|
||
|
|
||
|
d2.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
d2.run(function() {
|
||
|
setTimeout(function() {
|
||
|
console.log('foo');
|
||
|
throw new Error('boom!');
|
||
|
}, 33);
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function setImmediateNestedWithErrorHandler() {
|
||
|
const d = domain.create();
|
||
|
const d2 = domain.create();
|
||
|
|
||
|
d2.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
d2.run(function() {
|
||
|
setImmediate(function() {
|
||
|
throw new Error('boom!');
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function nextTickNestedWithErrorHandler() {
|
||
|
const d = domain.create();
|
||
|
const d2 = domain.create();
|
||
|
|
||
|
d2.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
d2.run(function() {
|
||
|
process.nextTick(function() {
|
||
|
throw new Error('boom!');
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
|
||
|
function fsAsyncNestedWithErrorHandler() {
|
||
|
const d = domain.create();
|
||
|
const d2 = domain.create();
|
||
|
|
||
|
d2.on('error', function errorHandler() {
|
||
|
errorHandlerCalled = true;
|
||
|
});
|
||
|
|
||
|
d.run(function() {
|
||
|
d2.run(function() {
|
||
8 years ago
|
const fs = require('fs');
|
||
9 years ago
|
fs.exists('/non/existing/file', function onExists(exists) {
|
||
|
throw new Error('boom!');
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
];
|
||
|
|
||
|
if (process.argv[2] === 'child') {
|
||
|
const testIndex = +process.argv[3];
|
||
|
|
||
|
tests[testIndex]();
|
||
|
|
||
|
process.on('exit', function onExit() {
|
||
8 years ago
|
assert.strictEqual(errorHandlerCalled, true);
|
||
9 years ago
|
});
|
||
|
} else {
|
||
|
|
||
|
tests.forEach(function(test, testIndex) {
|
||
8 years ago
|
let testCmd = '';
|
||
9 years ago
|
if (!common.isWindows) {
|
||
9 years ago
|
// Do not create core files, as it can take a lot of disk space on
|
||
|
// continuous testing and developers' machines
|
||
|
testCmd += 'ulimit -c 0 && ';
|
||
|
}
|
||
|
|
||
9 years ago
|
testCmd += process.argv[0];
|
||
9 years ago
|
testCmd += ' ' + '--abort-on-uncaught-exception';
|
||
|
testCmd += ' ' + process.argv[1];
|
||
|
testCmd += ' ' + 'child';
|
||
|
testCmd += ' ' + testIndex;
|
||
|
|
||
8 years ago
|
const child = child_process.exec(testCmd);
|
||
9 years ago
|
|
||
|
child.on('exit', function onExit(code, signal) {
|
||
8 years ago
|
assert.strictEqual(code, 0, 'Test at index ' + testIndex +
|
||
9 years ago
|
' should have exited with exit code 0 but instead exited with code ' +
|
||
|
code + ' and signal ' + signal);
|
||
10 years ago
|
});
|
||
|
});
|
||
|
}
|