Skip to content

Commit

Permalink
test: cover cluster error during dgram socket bind
Browse files Browse the repository at this point in the history
When a non-exclusive dgram socket is bound from a cluster
worker, a handle is requested from the cluster module. This
commit adds coverage for the case where an error occurs while
retrieving the handle.

PR-URL: #11295
Reviewed-By: James M Snell <jasnell@gmail.com>
  • Loading branch information
cjihrig authored and italoacasas committed Feb 14, 2017
1 parent 2952512 commit 68eb974
Showing 1 changed file with 29 additions and 0 deletions.
29 changes: 29 additions & 0 deletions test/parallel/test-dgram-cluster-bind-error.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
'use strict';
const common = require('../common');
const assert = require('assert');
const cluster = require('cluster');
const dgram = require('dgram');
const { UV_UNKNOWN } = process.binding('uv');

if (cluster.isMaster) {
cluster.fork();
} else {
// When the socket attempts to bind, it requests a handle from the cluster.
// Force the cluster to send back an error code.
cluster._getServer = function(self, options, callback) {
callback(UV_UNKNOWN);
};

const socket = dgram.createSocket('udp4');

socket.on('error', common.mustCall((err) => {
assert(/^Error: bind UNKNOWN 0.0.0.0$/.test(err.toString()));
process.nextTick(common.mustCall(() => {
assert.strictEqual(socket._bindState, 0); // BIND_STATE_UNBOUND
socket.close();
cluster.worker.disconnect();
}));
}));

socket.bind(common.mustNotCall('Socket should not bind.'));
}

0 comments on commit 68eb974

Please sign in to comment.