Skip to content

Commit

Permalink
test: improve process warning coverage
Browse files Browse the repository at this point in the history
PR-URL: #15212
Reviewed-By: Refael Ackermann <[email protected]>
Reviewed-By: Daniel Bevenius <[email protected]>
Reviewed-By: Colin Ihrig <[email protected]>
Reviewed-By: Benjamin Gruenbaum <[email protected]>
Reviewed-By: Luigi Pinca <[email protected]>
Reviewed-By: Tobias Nießen <[email protected]>
  • Loading branch information
jasnell committed Sep 20, 2017
1 parent ede09f2 commit 3ce501c
Showing 1 changed file with 59 additions and 0 deletions.
59 changes: 59 additions & 0 deletions test/parallel/test-process-warning.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
'use strict';

const common = require('../common');
const assert = require('assert');

function test1() {
// Output is skipped if the argument to the 'warning' event is
// not an Error object.
common.hijackStderr(common.mustNotCall('stderr.write must not be called'));
process.emit('warning', 'test');
setImmediate(test2);
}

function test2() {
// Output is skipped if it's a deprecation warning and
// process.noDeprecation = true
process.noDeprecation = true;
process.emitWarning('test', 'DeprecationWarning');
process.noDeprecation = false;
setImmediate(test3);
}

function test3() {
common.restoreStderr();
// Type defaults to warning when the second argument is an object
process.emitWarning('test', {});
process.once('warning', common.mustCall((warning) => {
assert.strictEqual(warning.name, 'Warning');
}));
setImmediate(test4);
}

function test4() {
// process.emitWarning will throw when process.throwDeprecation is true
// and type is `DeprecationWarning`.
process.throwDeprecation = true;
assert.throws(
() => process.emitWarning('test', 'DeprecationWarning'),
/^DeprecationWarning: test$/);
process.throwDeprecation = false;
setImmediate(test5);
}

function test5() {
// Setting toString to a non-function should not cause an error
const err = new Error('test');
err.toString = 1;
process.emitWarning(err);
setImmediate(test6);
}

function test6() {
process.emitWarning('test', { detail: 'foo' });
process.on('warning', (warning) => {
assert.strictEqual(warning.detail, 'foo');
});
}

test1();

0 comments on commit 3ce501c

Please sign in to comment.