|
|
|
'use strict';
|
|
|
|
const common = require('../common');
|
|
|
|
const assert = require('assert');
|
|
|
|
|
|
|
|
// if child process output to console and exit
|
|
|
|
if (process.argv[2] === 'child') {
|
|
|
|
console.log('hello');
|
|
|
|
for (let i = 0; i < 200; i++) {
|
|
|
|
console.log('filler');
|
|
|
|
}
|
|
|
|
console.log('goodbye');
|
|
|
|
process.exit(0);
|
|
|
|
} else {
|
|
|
|
// parent process
|
|
|
|
const spawn = require('child_process').spawn;
|
|
|
|
|
|
|
|
// spawn self as child
|
|
|
|
const child = spawn(process.argv[0], [process.argv[1], 'child']);
|
|
|
|
|
|
|
|
let stdout = '';
|
|
|
|
|
|
|
|
child.stderr.setEncoding('utf8');
|
|
|
|
child.stderr.on('data', function(data) {
|
|
|
|
console.log('parent stderr: ' + data);
|
|
|
|
assert.ok(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
// check if we receive both 'hello' at start and 'goodbye' at end
|
|
|
|
child.stdout.setEncoding('utf8');
|
|
|
|
child.stdout.on('data', function(data) {
|
|
|
|
stdout += data;
|
|
|
|
});
|
|
|
|
|
|
|
|
child.on('close', common.mustCall(function() {
|
|
|
|
assert.strictEqual(stdout.slice(0, 6), 'hello\n');
|
|
|
|
assert.strictEqual(stdout.slice(stdout.length - 8), 'goodbye\n');
|
|
|
|
}));
|
|
|
|
}
|