node/test/parallel/test-cluster-eaddrinuse.js
Rich Trott f7feab5b3b test: remove test-cluster-* var redeclarations
PR-URL: https://github.com/nodejs/node/pull/4980
Reviewed-By: Brian White <mscdex@mscdex.net>
Reviewed-By: James M Snell <jasnell@gmail.com>
2016-02-01 08:47:50 -08:00

43 lines
1.2 KiB
JavaScript

'use strict';
// Check that having a worker bind to a port that's already taken doesn't
// leave the master process in a confused state. Releasing the port and
// trying again should Just Work[TM].
var common = require('../common');
var assert = require('assert');
var fork = require('child_process').fork;
var net = require('net');
var id = '' + process.argv[2];
if (id === 'undefined') {
const server = net.createServer(common.fail);
server.listen(common.PORT, function() {
var worker = fork(__filename, ['worker']);
worker.on('message', function(msg) {
if (msg !== 'stop-listening') return;
server.close(function() {
worker.send('stopped-listening');
});
});
});
}
else if (id === 'worker') {
let server = net.createServer(common.fail);
server.listen(common.PORT, common.fail);
server.on('error', common.mustCall(function(e) {
assert(e.code, 'EADDRINUSE');
process.send('stop-listening');
process.once('message', function(msg) {
if (msg !== 'stopped-listening') return;
server = net.createServer(common.fail);
server.listen(common.PORT, common.mustCall(function() {
server.close();
}));
});
}));
}
else {
assert(0); // Bad argument.
}