2016-01-20 11:38:35 -08:00
|
|
|
'use strict';
|
|
|
|
|
2017-10-06 09:47:22 -07:00
|
|
|
require('../common');
|
|
|
|
const fixtures = require('../common/fixtures');
|
2016-01-20 11:38:35 -08:00
|
|
|
const assert = require('assert');
|
|
|
|
const execFile = require('child_process').execFile;
|
2017-10-06 09:47:22 -07:00
|
|
|
const warnmod = require.resolve(fixtures.path('warnings.js'));
|
2016-01-20 11:38:35 -08:00
|
|
|
const node = process.execPath;
|
|
|
|
|
|
|
|
const normal = [warnmod];
|
|
|
|
const noWarn = ['--no-warnings', warnmod];
|
|
|
|
const traceWarn = ['--trace-warnings', warnmod];
|
|
|
|
|
2017-06-18 16:22:32 +03:00
|
|
|
const warningMessage = /^\(.+\)\sWarning: a bad practice warning/;
|
|
|
|
|
2016-01-20 11:38:35 -08:00
|
|
|
execFile(node, normal, function(er, stdout, stderr) {
|
|
|
|
// Show Process Warnings
|
2017-01-08 15:36:25 +00:00
|
|
|
assert.strictEqual(er, null);
|
|
|
|
assert.strictEqual(stdout, '');
|
2021-08-29 10:14:22 +02:00
|
|
|
assert.match(stderr, warningMessage);
|
2016-01-20 11:38:35 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
execFile(node, noWarn, function(er, stdout, stderr) {
|
|
|
|
// Hide Process Warnings
|
2017-01-08 15:36:25 +00:00
|
|
|
assert.strictEqual(er, null);
|
|
|
|
assert.strictEqual(stdout, '');
|
2021-08-29 10:14:22 +02:00
|
|
|
assert.doesNotMatch(stderr, warningMessage);
|
2016-01-20 11:38:35 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
execFile(node, traceWarn, function(er, stdout, stderr) {
|
|
|
|
// Show Warning Trace
|
2017-01-08 15:36:25 +00:00
|
|
|
assert.strictEqual(er, null);
|
|
|
|
assert.strictEqual(stdout, '');
|
2021-08-29 10:14:22 +02:00
|
|
|
assert.match(stderr, warningMessage);
|
|
|
|
assert.match(stderr, /at Object\.<anonymous>\s\(.+warnings\.js:3:9\)/);
|
2016-01-20 11:38:35 -08:00
|
|
|
});
|