From 866860e6a687c0f9f24cc8b736d5ce7334ec2d41 Mon Sep 17 00:00:00 2001 From: Philipp Spiess Date: Tue, 23 Jul 2024 14:40:11 +0200 Subject: [PATCH] Print eventual lightning CSS parsing errors when the CSS matcher fail (#14034) --- jest/customMatchers.js | 73 ++++++++++++++++++++++++------------------ 1 file changed, 41 insertions(+), 32 deletions(-) diff --git a/jest/customMatchers.js b/jest/customMatchers.js index 9b1c6b6d060c..c41696ce8526 100644 --- a/jest/customMatchers.js +++ b/jest/customMatchers.js @@ -23,39 +23,42 @@ function formatPrettier(input) { function format(input) { try { - return lightningcss - .transform({ - filename: 'input.css', - code: Buffer.from(input), - minify: false, - targets: { chrome: 106 << 16 }, - drafts: { - nesting: true, - customMedia: true, - }, - }) - .code.toString('utf8') + return [ + lightningcss + .transform({ + filename: 'input.css', + code: Buffer.from(input), + minify: false, + targets: { chrome: 106 << 16 }, + drafts: { + nesting: true, + customMedia: true, + }, + }) + .code.toString('utf8'), + null, + ] } catch (err) { + let lines = err.source.split('\n') + let e = new Error( + [ + 'Error formatting using Lightning CSS:', + '', + ...[ + '```css', + ...lines.slice(Math.max(err.loc.line - 3, 0), err.loc.line), + ' '.repeat(err.loc.column - 1) + '^-- ' + err.toString(), + ...lines.slice(err.loc.line, err.loc.line + 2), + '```', + ], + ].join('\n') + ) try { // Lightning CSS is pretty strict, so it will fail for `@media screen(md) {}` for example, // in that case we can fallback to prettier since it doesn't really care. However if an // actual syntax error is made, then we still want to show the proper error. - return formatPrettier(input.replace(/\n/g, '')) + return [formatPrettier(input.replace(/\n/g, '')), e] } catch { - let lines = err.source.split('\n') - let e = new Error( - [ - 'Error formatting using Lightning CSS:', - '', - ...[ - '```css', - ...lines.slice(Math.max(err.loc.line - 3, 0), err.loc.line), - ' '.repeat(err.loc.column - 1) + '^-- ' + err.toString(), - ...lines.slice(err.loc.line, err.loc.line + 2), - '```', - ], - ].join('\n') - ) if (Error.captureStackTrace) { Error.captureStackTrace(e, toMatchFormattedCss) } @@ -71,8 +74,8 @@ function toMatchFormattedCss(received = '', argument = '') { promise: this.promise, } - let formattedReceived = format(received) - let formattedArgument = format(argument) + let [formattedReceived, formattingReceivedError] = format(received) + let [formattedArgument, formattingArgumentError] = format(argument) let pass = formattedReceived === formattedArgument @@ -99,7 +102,9 @@ function toMatchFormattedCss(received = '', argument = '') { (diffString && diffString.includes('- Expect') ? `Difference:\n\n${diffString}` : `Expected: ${this.utils.printExpected(expected)}\n` + - `Received: ${this.utils.printReceived(actual)}`) + `Received: ${this.utils.printReceived(actual)}`) + + (formattingReceivedError ? '\n\n' + formattingReceivedError : '') + + (formattingArgumentError ? '\n\n' + formattingArgumentError : '') ) } @@ -118,7 +123,9 @@ expect.extend({ promise: this.promise, } - let pass = format(received).includes(format(argument)) + let [formattedReceived, formattedReceivedError] = format(received) + let [formattedArgument, formattedArgumentError] = format(argument) + let pass = formattedReceived.includes(formattedArgument) let message = pass ? () => { @@ -143,7 +150,9 @@ expect.extend({ (diffString && diffString.includes('- Expect') ? `Difference:\n\n${diffString}` : `Expected: ${this.utils.printExpected(expected)}\n` + - `Received: ${this.utils.printReceived(actual)}`) + `Received: ${this.utils.printReceived(actual)}`) + + (formattedReceivedError ? '\n\n' + formattedReceivedError : '') + + (formattedArgumentError ? '\n\n' + formattedArgumentError : '') ) }