From f8be4a52c09794ac12eeeade0b33757d42f37a19 Mon Sep 17 00:00:00 2001 From: Timmy Willison Date: Thu, 14 Mar 2024 09:05:57 -0400 Subject: [PATCH] Tests: add actual and expected messages to test reporter Close gh-5444 --- test/runner/reporter.js | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/test/runner/reporter.js b/test/runner/reporter.js index bb5e7601b..74417f2fb 100644 --- a/test/runner/reporter.js +++ b/test/runner/reporter.js @@ -10,28 +10,28 @@ export function reportTest( test, reportId, { browser, headless } ) { return; } - let message = `Test ${ test.status } on ${ chalk.yellow( + let message = `${ chalk.bold( `${ test.suiteName }: ${ test.name }` ) }`; + message += `\nTest ${ test.status } on ${ chalk.yellow( getBrowserString( browser, headless ) ) } (${ chalk.bold( reportId ) }).`; - message += `\n${ chalk.bold( `${ test.suiteName }: ${ test.name }` ) }`; - // Prefer failed assertions over error messages - if ( test.assertions.filter( ( a ) => !!a && !a.passed ).length ) { - test.assertions.forEach( ( assertion, i ) => { - if ( !assertion.passed ) { - message += `\n${ i + 1 }. ${ chalk.red( assertion.message ) }`; - message += `\n${ chalk.gray( assertion.stack ) }`; - } - } ); - } else if ( test.errors.length ) { + // test.assertions only contains passed assertions; + // test.errors contains all failed asssertions + if ( test.errors.length ) { for ( const error of test.errors ) { - message += `\n${ chalk.red( error.message ) }`; + message += "\n"; + message += `\n${ error.message }`; message += `\n${ chalk.gray( error.stack ) }`; + if ( error.expected && error.actual ) { + message += `\nexpected: ${ JSON.stringify( error.expected ) }`; + message += `\nactual: ${ chalk.red( JSON.stringify( error.actual ) ) }`; + } } } console.log( "\n\n" + message ); + // Only return failed messages if ( test.status === "failed" ) { return message; } -- 2.39.5