'use strict'; // Testing mutual send of handles: from master to worker, and from worker to // master. const common = require('../common'); const assert = require('assert'); const cluster = require('cluster'); const net = require('net'); if (cluster.isMaster) { const worker = cluster.fork(); worker.on('exit', function(code, signal) { assert.strictEqual(code, 0, 'Worker exited with an error code'); assert(!signal, 'Worker exited by a signal'); server.close(); }); const server = net.createServer(function(socket) { worker.send('handle', socket); }); server.listen(common.PORT, function() { worker.send('listen'); }); } else { process.on('message', function(msg, handle) { if (msg === 'listen') { const client1 = net.connect({ host: 'localhost', port: common.PORT }); const client2 = net.connect({ host: 'localhost', port: common.PORT }); let waiting = 2; client1.on('close', onclose); client2.on('close', onclose); function onclose() { if (--waiting === 0) cluster.worker.disconnect(); } setTimeout(function() { client1.end(); client2.end(); }, 50); } else { process.send('reply', handle); } }); }