node/test/parallel/test-child-process-stdout-f...

46 lines
1.1 KiB
JavaScript

var common = require('../common');
var assert = require('assert');
var path = require('path');
// if child process output to console and exit
if (process.argv[2] === 'child') {
console.log('hello');
for (var i = 0; i < 200; i++) {
console.log('filler');
}
console.log('goodbye');
process.exit(0);
} else {
// parent process
var spawn = require('child_process').spawn;
// spawn self as child
var child = spawn(process.argv[0], [process.argv[1], 'child']);
var gotHello = false;
var gotBye = false;
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) {
if (data.slice(0, 6) == 'hello\n') {
gotHello = true;
} else if (data.slice(data.length - 8) == 'goodbye\n') {
gotBye = true;
} else {
gotBye = false;
}
});
child.on('close', function (data) {
assert(gotHello);
assert(gotBye);
});
}