node/test/parallel/test-cluster-setup-master-multiple.js
Rich Trott 082cc8d6d8 test: remove unnecessary assignments
common.js needs to be loaded in all tests so that there is checking
for variable leaks and possibly other things. However, it does not
need to be assigned to a variable if nothing in common.js is referred
to elsewhere in the test.

PR-URL: https://github.com/nodejs/node/pull/4408
Reviewed-By: James M Snell <jasnell@gmail.com>
2015-12-26 18:00:02 -08:00

51 lines
1.3 KiB
JavaScript

'use strict';
require('../common');
var assert = require('assert');
var cluster = require('cluster');
assert(cluster.isMaster);
// The cluster.settings object is cloned even though the current implementation
// makes that unecessary. This is to make the test less fragile if the
// implementation ever changes such that cluster.settings is mutated instead of
// replaced.
function cheapClone(obj) {
return JSON.parse(JSON.stringify(obj));
}
var configs = [];
// Capture changes
cluster.on('setup', function() {
console.log('"setup" emitted', cluster.settings);
configs.push(cheapClone(cluster.settings));
});
var execs = [
'node-next',
'node-next-2',
'node-next-3',
];
process.on('exit', function assertTests() {
// Tests that "setup" is emitted for every call to setupMaster
assert.strictEqual(configs.length, execs.length);
assert.strictEqual(configs[0].exec, execs[0]);
assert.strictEqual(configs[1].exec, execs[1]);
assert.strictEqual(configs[2].exec, execs[2]);
});
// Make changes to cluster settings
execs.forEach(function(v, i) {
setTimeout(function() {
cluster.setupMaster({ exec: v });
}, i * 100);
});
// cluster emits 'setup' asynchronously, so we must stay alive long
// enough for that to happen
setTimeout(function() {
console.log('cluster setup complete');
}, (execs.length + 1) * 100);