diff --git a/packages/playwright/src/reporters/base.ts b/packages/playwright/src/reporters/base.ts index f418baeea43d6..e4575a86273ff 100644 --- a/packages/playwright/src/reporters/base.ts +++ b/packages/playwright/src/reporters/base.ts @@ -414,7 +414,7 @@ function relativeTestPath(config: FullConfig, test: TestCase): string { export function stepSuffix(step: TestStep | undefined) { const stepTitles = step ? step.titlePath() : []; - return stepTitles.map(t => ' › ' + t).join(''); + return stepTitles.map(t => t.split('\n')[0]).map(t => ' › ' + t).join(''); } export function formatTestTitle(config: FullConfig, test: TestCase, step?: TestStep, omitLocation: boolean = false): string { diff --git a/tests/playwright-test/reporter-line.spec.ts b/tests/playwright-test/reporter-line.spec.ts index 5e591b191d477..14959877b5813 100644 --- a/tests/playwright-test/reporter-line.spec.ts +++ b/tests/playwright-test/reporter-line.spec.ts @@ -109,6 +109,28 @@ for (const useIntermediateMergeReport of [false, true] as const) { ].join('\n')); }); + test('should trim multiline step titles to first line', { + annotation: { type: 'issue', description: 'https://github.com/microsoft/playwright/issues/31266' } + }, async ({ runInlineTest }) => { + const result = await runInlineTest({ + 'a.test.ts': ` + import { test, expect } from '@playwright/test'; + test('passes', async ({}) => { + await test.step(\`outer + 1.0\`, async () => { + await test.step(\`inner + 1.1\`, async () => { + expect(1).toBe(1); + }); + }); + }); + `, + }, { reporter: 'line' }); + const text = result.output; + expect(text).toContain('[1/1] a.test.ts:6:26 › passes › outer › inner'); + expect(result.exitCode).toBe(0); + }); + test('should render failed test steps', async ({ runInlineTest }) => { const result = await runInlineTest({ 'a.test.ts': `