0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test/parallel/test-process-raw-debug.js
Rich Trott 082cc8d6d8 test: remove unnecessary assignments
common.js needs to be loaded in all tests so that there is checking
for variable leaks and possibly other things. However, it does not
need to be assigned to a variable if nothing in common.js is referred
to elsewhere in the test.

PR-URL: https://github.com/nodejs/node/pull/4408
Reviewed-By: James M Snell <jasnell@gmail.com>
2015-12-26 18:00:02 -08:00

52 lines
1.0 KiB
JavaScript

'use strict';
require('../common');
var assert = require('assert');
var os = require('os');
switch (process.argv[2]) {
case 'child':
return child();
case undefined:
return parent();
default:
throw new Error('wtf? ' + process.argv[2]);
}
function parent() {
var spawn = require('child_process').spawn;
var child = spawn(process.execPath, [__filename, 'child']);
var output = '';
child.stderr.on('data', function(c) {
output += c;
});
child.stderr.setEncoding('utf8');
child.stderr.on('end', function() {
assert.equal(output, 'I can still debug!' + os.EOL);
console.log('ok - got expected message');
});
child.on('exit', function(c) {
assert(!c);
console.log('ok - child exited nicely');
});
}
function child() {
// even when all hope is lost...
process.nextTick = function() {
throw new Error('No ticking!');
};
var stderr = process.stderr;
stderr.write = function() {
throw new Error('No writing to stderr!');
};
process._rawDebug('I can still %s!', 'debug');
}