summaryrefslogtreecommitdiff
path: root/test/parallel/test-cluster-shared-handle-bind-error.js
blob: f327de994a1fc60391f9480590b473582c4ddb20 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
var common = require('../common');
var assert = require('assert');
var cluster = require('cluster');
var net = require('net');

if (cluster.isMaster) {
  // Master opens and binds the socket and shares it with the worker.
  cluster.schedulingPolicy = cluster.SCHED_NONE;
  // Hog the TCP port so that when the worker tries to bind, it'll fail.
  net.createServer(assert.fail).listen(common.PORT, function() {
    var server = this;
    var worker = cluster.fork();
    worker.on('exit', common.mustCall(function(exitCode) {
      assert.equal(exitCode, 0);
      server.close();
    }));
  });
}
else {
  var s = net.createServer(assert.fail);
  s.listen(common.PORT, assert.fail.bind(null, 'listen should have failed'));
  s.on('error', common.mustCall(function(err) {
    assert.equal(err.code, 'EADDRINUSE');
    process.disconnect();
  }));
}