mirror of https://github.com/nodejs/node.git
37 lines
1.1 KiB
JavaScript
37 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
require('../common');
|
|
const fixtures = require('../common/fixtures');
|
|
const assert = require('assert');
|
|
const execFile = require('child_process').execFile;
|
|
const warnmod = require.resolve(fixtures.path('warnings.js'));
|
|
const node = process.execPath;
|
|
|
|
const normal = [warnmod];
|
|
const noWarn = ['--no-warnings', warnmod];
|
|
const traceWarn = ['--trace-warnings', warnmod];
|
|
|
|
const warningMessage = /^\(.+\)\sWarning: a bad practice warning/;
|
|
|
|
execFile(node, normal, function(er, stdout, stderr) {
|
|
// Show Process Warnings
|
|
assert.strictEqual(er, null);
|
|
assert.strictEqual(stdout, '');
|
|
assert.match(stderr, warningMessage);
|
|
});
|
|
|
|
execFile(node, noWarn, function(er, stdout, stderr) {
|
|
// Hide Process Warnings
|
|
assert.strictEqual(er, null);
|
|
assert.strictEqual(stdout, '');
|
|
assert.doesNotMatch(stderr, warningMessage);
|
|
});
|
|
|
|
execFile(node, traceWarn, function(er, stdout, stderr) {
|
|
// Show Warning Trace
|
|
assert.strictEqual(er, null);
|
|
assert.strictEqual(stdout, '');
|
|
assert.match(stderr, warningMessage);
|
|
assert.match(stderr, /at Object\.<anonymous>\s\(.+warnings\.js:3:9\)/);
|
|
});
|