node/test/parallel/test-domain-multi.js
cjihrig 7dd82dd1c3 test: add common.mustNotCall()
This commit adds a mustNotCall() helper for testing. This provides
an alternative to using common.fail() as a callback, or creating
a callback function for the sole purpose of calling common.fail().

PR-URL: https://github.com/nodejs/node/pull/11152
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com>
Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
Reviewed-By: Yuta Hiroto <hello@about-hiroppy.com>
2017-02-06 14:07:55 -05:00

55 lines
1.4 KiB
JavaScript

'use strict';
// Tests of multiple domains happening at once.
const common = require('../common');
const domain = require('domain');
const http = require('http');
const a = domain.create();
a.enter(); // this will be our "root" domain
a.on('error', common.mustNotCall());
const server = http.createServer((req, res) => {
// child domain of a.
const b = domain.create();
a.add(b);
// treat these EE objects as if they are a part of the b domain
// so, an 'error' event on them propagates to the domain, rather
// than being thrown.
b.add(req);
b.add(res);
b.on('error', common.mustCall((er) => {
if (res) {
res.writeHead(500);
res.end('An error occurred');
}
// res.writeHead(500), res.destroy, etc.
server.close();
}));
// XXX this bind should not be necessary.
// the write cb behavior in http/net should use an
// event so that it picks up the domain handling.
res.write('HELLO\n', b.bind(() => {
throw new Error('this kills domain B, not A');
}));
}).listen(0, () => {
const c = domain.create();
const req = http.get({ host: 'localhost', port: server.address().port });
// add the request to the C domain
c.add(req);
req.on('response', (res) => {
// add the response object to the C domain
c.add(res);
res.pipe(process.stdout);
});
c.on('error', common.mustCall((er) => { }));
});