Skip to content

Commit

Permalink
tests: add tests in case of warnings from loader
Browse files Browse the repository at this point in the history
  • Loading branch information
snitin315 committed Aug 18, 2020
1 parent 8611c6a commit 4e1b4c9
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 1 deletion.
2 changes: 1 addition & 1 deletion packages/webpack-cli/lib/utils/Compiler.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ class Compiler {
logger.error(err.stack || err);
process.exit(1); // eslint-disable-line
}
if (!outputOptions.watch && stats.hasErrors()) {
if (!outputOptions.watch && (stats.hasErrors() || stats.hasWarnings())) {
process.exitCode = 1;
}
if (outputOptions.json) {
Expand Down
12 changes: 12 additions & 0 deletions test/loader/warning-test/loader-warning.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
'use strict';

const { run } = require('../../utils/test-utils');

describe('loader warning test', () => {
it(`should not ignore loader's warning and exit with a non zero exit code`, () => {
const { stdout, exitCode } = run(__dirname, [], false);

expect(stdout).toContain('This is a warning');
expect(exitCode).not.toEqual(0);
});
});
5 changes: 5 additions & 0 deletions test/loader/warning-test/my-loader.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module.exports = function loader(source) {
const { emitWarning } = this;
emitWarning('This is a warning');
return source;
};
1 change: 1 addition & 0 deletions test/loader/warning-test/src/main.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
console.log('loader warning test');
30 changes: 30 additions & 0 deletions test/loader/warning-test/webpack.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
const path = require('path');

module.exports = {
mode: 'development',

entry: {
bundle: './src/main.js',
},

output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js',
},

module: {
rules: [
{
test: /.(js|jsx)?$/,
loader: 'my-loader',
include: [path.resolve(__dirname, 'src')],
exclude: [/node_modules/],
},
],
},
resolveLoader: {
alias: {
'my-loader': require.resolve('./my-loader'),
},
},
};

0 comments on commit 4e1b4c9

Please sign in to comment.