From 52412f6d5a54745ee37a4a67f038455c26ba5772 Mon Sep 17 00:00:00 2001 From: Alexey Lavinsky Date: Wed, 23 Sep 2020 18:39:15 +0300 Subject: [PATCH] feat: improve error message --- src/CssSyntaxError.js | 3 ++- test/__snapshots__/loader.test.js.snap | 4 ++-- test/helpers/getErrors.js | 4 ++-- test/helpers/normalizeErrors.js | 15 ++++++++++++++- test/loader.test.js | 4 ++-- 5 files changed, 22 insertions(+), 8 deletions(-) diff --git a/src/CssSyntaxError.js b/src/CssSyntaxError.js index 95f80f87..e39eb82d 100644 --- a/src/CssSyntaxError.js +++ b/src/CssSyntaxError.js @@ -2,7 +2,7 @@ export default class CssSyntaxError extends Error { constructor(error) { super(error); - const { reason, line, column } = error; + const { reason, line, column, file } = error; this.name = 'CssSyntaxError'; @@ -14,6 +14,7 @@ export default class CssSyntaxError extends Error { this.message += `(${line}:${column}) `; } + this.message += file ? `${file} ` : ' '; this.message += `${reason}`; const code = error.showSourceCode(); diff --git a/test/__snapshots__/loader.test.js.snap b/test/__snapshots__/loader.test.js.snap index 8b652215..9490502b 100644 --- a/test/__snapshots__/loader.test.js.snap +++ b/test/__snapshots__/loader.test.js.snap @@ -131,7 +131,7 @@ Array [ "ModuleBuildError: Module build failed (from \`replaced original path\`): CssSyntaxError -(1:8) Unknown word +(1:8) /test/fixtures/invisible-space.css Unknown word > 1 | a { 

 color: red; 

 } | ^ @@ -146,7 +146,7 @@ Array [ "ModuleBuildError: Module build failed (from \`replaced original path\`): CssSyntaxError -(2:3) Unknown word +(2:3) /test/fixtures/error.css Unknown word 1 | .some { > 2 | invalid css; diff --git a/test/helpers/getErrors.js b/test/helpers/getErrors.js index 03339e1e..55ae008b 100644 --- a/test/helpers/getErrors.js +++ b/test/helpers/getErrors.js @@ -1,5 +1,5 @@ import normalizeErrors from './normalizeErrors'; -export default (stats, shortError) => { - return normalizeErrors(stats.compilation.errors, shortError).sort(); +export default (stats, shortError, type) => { + return normalizeErrors(stats.compilation.errors, shortError, type).sort(); }; diff --git a/test/helpers/normalizeErrors.js b/test/helpers/normalizeErrors.js index 56fabce8..c844eb95 100644 --- a/test/helpers/normalizeErrors.js +++ b/test/helpers/normalizeErrors.js @@ -27,7 +27,7 @@ function removeCWD(str) { .replace(new RegExp(cwd, 'g'), ''); } -export default (errors, shortError) => { +export default (errors, shortError, type) => { return errors.map((error) => { let errorMessage = error.toString(); @@ -35,6 +35,19 @@ export default (errors, shortError) => { errorMessage = errorMessage.split('\n').slice(0, 2).join('\n'); } + if (type === 'postcss') { + errorMessage = errorMessage + .split('\n') + .map((str) => { + if (/^\(/i.test(str)) { + return removeCWD(str); + } + + return str; + }) + .join('\n'); + } + return removeCWD(errorMessage.split('\n').slice(0, 12).join('\n')); }); }; diff --git a/test/loader.test.js b/test/loader.test.js index d8c84f12..0195d0ce 100644 --- a/test/loader.test.js +++ b/test/loader.test.js @@ -132,7 +132,7 @@ describe('loader', () => { ) ).toBe(true); expect(getWarnings(stats)).toMatchSnapshot('warnings'); - expect(getErrors(stats)).toMatchSnapshot('errors'); + expect(getErrors(stats, false, 'postcss')).toMatchSnapshot('errors'); }); it('should reuse `ast` from "postcss-loader"', async () => { @@ -360,7 +360,7 @@ describe('loader', () => { const stats = await compile(compiler); expect(getWarnings(stats)).toMatchSnapshot('warnings'); - expect(getErrors(stats)).toMatchSnapshot('errors'); + expect(getErrors(stats, false, 'postcss')).toMatchSnapshot('errors'); }); it('should work with the "modules.auto" option and the "importLoaders" option', async () => {