From bf1015980eabcd9b9c7925c36bbb6bb1bc349fa6 Mon Sep 17 00:00:00 2001 From: Luis Felipe Zaguini Date: Wed, 22 Nov 2023 12:24:13 +0100 Subject: [PATCH] Display better warning messages --- .../src/utils/test/transform-styles.js | 63 +++++++++++++------ .../src/utils/transform-styles/index.js | 8 ++- 2 files changed, 52 insertions(+), 19 deletions(-) diff --git a/packages/block-editor/src/utils/test/transform-styles.js b/packages/block-editor/src/utils/test/transform-styles.js index b00720fd2142c..38eaa1947d2a8 100644 --- a/packages/block-editor/src/utils/test/transform-styles.js +++ b/packages/block-editor/src/utils/test/transform-styles.js @@ -4,26 +4,53 @@ import transformStyles from '../transform-styles'; describe( 'transformStyles', () => { - it( 'should not throw error in case of invalid css', () => { - const run = () => - transformStyles( - [ - { - css: 'h1 { color: red; }', // valid CSS - }, - { - css: 'h1 { color: red;', // invalid CSS - }, - ], - '.my-namespace' - ); - - expect( run ).not.toThrow(); + describe( 'error handling', () => { + beforeEach( () => { + // Intentionally suppress the expected console errors and warnings to reduce + // noise in the test output. + jest.spyOn( console, 'warn' ).mockImplementation( jest.fn() ); + } ); - const [ validCSS, invalidCSS ] = run(); + it( 'should not throw error in case of invalid css', () => { + const run = () => + transformStyles( + [ + { + css: 'h1 { color: red;', // invalid CSS + }, + ], + '.my-namespace' + ); + + expect( run ).not.toThrow(); + expect( console ).toHaveWarned(); + } ); - expect( validCSS ).toBe( '.my-namespace h1 { color: red; }' ); - expect( invalidCSS ).toBe( null ); + it( 'should warn invalid css in the console', () => { + const run = () => + transformStyles( + [ + { + css: 'h1 { color: red; }', // valid CSS + }, + { + css: 'h1 { color: red;', // invalid CSS + }, + ], + '.my-namespace' + ); + + const [ validCSS, invalidCSS ] = run(); + + expect( validCSS ).toBe( '.my-namespace h1 { color: red; }' ); + expect( invalidCSS ).toBe( null ); + + expect( console ).toHaveWarnedWith( + 'wp.blockEditor.transformStyles Failed to transform CSS.', + ':1:1: Unclosed block\n> 1 | h1 { color: red;\n | ^' + // ^^^^ In PostCSS, a tab is equal four spaces + ); + } ); } ); describe( 'selector wrap', () => { diff --git a/packages/block-editor/src/utils/transform-styles/index.js b/packages/block-editor/src/utils/transform-styles/index.js index 4c7300d331d02..4da6f6ce23795 100644 --- a/packages/block-editor/src/utils/transform-styles/index.js +++ b/packages/block-editor/src/utils/transform-styles/index.js @@ -33,7 +33,13 @@ const transformStyles = ( styles, wrapperSelector = '' ) => { ].filter( Boolean ) ).process( css, {} ).css; // use sync PostCSS API } catch ( error ) { - if ( ! ( error instanceof CssSyntaxError ) ) { + if ( error instanceof CssSyntaxError ) { + // eslint-disable-next-line no-console + console.warn( + 'wp.blockEditor.transformStyles Failed to transform CSS.', + error.message + '\n' + error.showSourceCode( false ) + ); + } else { // eslint-disable-next-line no-console console.warn( 'wp.blockEditor.transformStyles Failed to transform CSS.',