node/test/parallel/test-cluster-eaddrinuse.js

43 lines
1.2 KiB
JavaScript

// 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 cluster = require('cluster');
var fork = require('child_process').fork;
var net = require('net');
var id = '' + process.argv[2];
if (id === 'undefined') {
var server = net.createServer(assert.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') {
var server = net.createServer(assert.fail);
server.listen(common.PORT, assert.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(assert.fail);
server.listen(common.PORT, common.mustCall(function() {
server.close();
}));
});
}));
}
else {
assert(0); // Bad argument.
}