summaryrefslogtreecommitdiff
path: root/test/parallel/test-cluster-setup-master-multiple.js
blob: c8fefddc39a23ed178ca4722ba24524b3418f148 (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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
'use strict';
require('../common');
const assert = require('assert');
const cluster = require('cluster');

assert(cluster.isMaster);

// The cluster.settings object is cloned even though the current implementation
// makes that unnecessary. 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));
}

const configs = [];

// Capture changes
cluster.on('setup', function() {
  console.log('"setup" emitted', cluster.settings);
  configs.push(cheapClone(cluster.settings));
});

const 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);