'use strict'; const common = require('../common'); const http = require('http'); const cluster = require('cluster'); const assert = require('assert'); cluster.schedulingPolicy = cluster.SCHED_NONE; const server = http.createServer(); if (cluster.isMaster) { let worker; server.listen(0, common.mustCall((error) => { assert.ifError(error); assert(worker); worker.send({ port: server.address().port }); })); worker = cluster.fork(); worker.on('exit', common.mustCall(() => { server.close(); })); } else { process.on('message', common.mustCall((msg) => { assert(msg.port); server.listen(msg.port); server.on('error', common.mustCall((e) => { cluster.worker.disconnect(); })); })); }