From 17de89d8dbd15f0a92695c536177fdbfeefe4aa4 Mon Sep 17 00:00:00 2001 From: Vladimir Sheremet Date: Tue, 15 Oct 2024 12:08:31 +0200 Subject: [PATCH] fix: clarify slowTestThreshold, print slow tests in non-TTY mode --- docs/advanced/reporters.md | 4 ++ docs/config/index.md | 2 +- packages/vitest/src/node/cli/cli-config.ts | 2 +- packages/vitest/src/node/reporters/base.ts | 46 +++++++++++++------ .../src/node/reporters/reported-tasks.ts | 9 +++- 5 files changed, 46 insertions(+), 17 deletions(-) diff --git a/docs/advanced/reporters.md b/docs/advanced/reporters.md index 84d31ca13eef9..faa34090ba68c 100644 --- a/docs/advanced/reporters.md +++ b/docs/advanced/reporters.md @@ -196,6 +196,10 @@ export interface TestResultSkipped { } export interface TestDiagnostic { + /** + * If the duration of the test is above `slowTestThreshold`. + */ + slow: boolean /** * The amount of memory used by the test in bytes. * This value is only available if the test was executed with `logHeapUsage` flag. diff --git a/docs/config/index.md b/docs/config/index.md index f52e246a5f0c7..f9321433d458f 100644 --- a/docs/config/index.md +++ b/docs/config/index.md @@ -2174,7 +2174,7 @@ Path to custom tsconfig, relative to the project root. - **Default**: `300` - **CLI**: `--slow-test-threshold=`, `--slowTestThreshold=` -The number of milliseconds after which a test is considered slow and reported as such in the results. +The number of milliseconds after which a test or suite is considered slow and reported as such in the results. ### chaiConfig {#chaiconfig} diff --git a/packages/vitest/src/node/cli/cli-config.ts b/packages/vitest/src/node/cli/cli-config.ts index 05b83a555a179..841d49b190006 100644 --- a/packages/vitest/src/node/cli/cli-config.ts +++ b/packages/vitest/src/node/cli/cli-config.ts @@ -656,7 +656,7 @@ export const cliOptionsConfig: VitestCLIOptions = { }, slowTestThreshold: { description: - 'Threshold in milliseconds for a test to be considered slow (default: `300`)', + 'Threshold in milliseconds for a test or suite to be considered slow (default: `300`)', argument: '', }, teardownTimeout: { diff --git a/packages/vitest/src/node/reporters/base.ts b/packages/vitest/src/node/reporters/base.ts index b4c60674ac8ee..c17b9aace952c 100644 --- a/packages/vitest/src/node/reporters/base.ts +++ b/packages/vitest/src/node/reporters/base.ts @@ -17,7 +17,7 @@ import { toArray, } from '../../utils' import type { Vitest } from '../core' -import { F_POINTER, F_RIGHT } from '../../utils/figures' +import { F_CHECK, F_POINTER, F_RIGHT } from '../../utils/figures' import type { Reporter } from '../types/reporter' import type { ErrorWithDiff, UserConsoleLog } from '../../types/general' import { @@ -140,13 +140,7 @@ export abstract class BaseReporter implements Reporter { state += ` ${c.dim('|')} ${c.yellow(`${skipped.length} skipped`)}` } let suffix = c.dim(' (') + state + c.dim(')') - if (task.result.duration) { - const color - = task.result.duration > this.ctx.config.slowTestThreshold - ? c.yellow - : c.gray - suffix += color(` ${Math.round(task.result.duration)}${c.dim('ms')}`) - } + suffix += this.getDurationPrefix(task) if (this.ctx.config.logHeapUsage && task.result.heap != null) { suffix += c.magenta( ` ${Math.floor(task.result.heap / 1024 / 1024)} MB heap used`, @@ -163,13 +157,37 @@ export abstract class BaseReporter implements Reporter { title += `${task.name} ${suffix}` logger.log(title) - // print short errors, full errors will be at the end in summary - for (const test of failed) { - logger.log(c.red(` ${taskFail} ${getTestName(test, c.dim(' > '))}`)) - test.result?.errors?.forEach((e) => { - logger.log(c.red(` ${F_RIGHT} ${(e as any)?.message}`)) - }) + for (const test of tests) { + const duration = test.result?.duration || 0 + if (test.result?.state === 'fail') { + logger.log(c.red(` ${taskFail} ${getTestName(test, c.dim(' > '))}`)) + const suffix = this.getDurationPrefix(test) + + test.result?.errors?.forEach((e) => { + // print short errors, full errors will be at the end in summary + logger.log(c.red(` ${F_RIGHT} ${(e as any)?.message}${suffix}`)) + }) + } + // also print slow tests + else if (duration > this.ctx.config.slowTestThreshold) { + logger.log( + ` ${c.yellow(c.dim(F_CHECK))} ${getTestName(test, c.dim(' > '))}${c.yellow( + ` ${Math.round(duration)}${c.dim('ms')}`, + )}`, + ) + } + } + } + + private getDurationPrefix(task: Task) { + if (!task.result?.duration) { + return '' } + const color + = task.result.duration > this.ctx.config.slowTestThreshold + ? c.yellow + : c.gray + return color(` ${Math.round(task.result.duration)}${c.dim('ms')}`) } onWatcherStart( diff --git a/packages/vitest/src/node/reporters/reported-tasks.ts b/packages/vitest/src/node/reporters/reported-tasks.ts index 6914e2cf61658..aa0964bf6c32c 100644 --- a/packages/vitest/src/node/reporters/reported-tasks.ts +++ b/packages/vitest/src/node/reporters/reported-tasks.ts @@ -155,9 +155,12 @@ export class TestCase extends ReportedTaskImplementation { if (!result || result.state === 'run' || !result.startTime) { return undefined } + const duration = result.duration || 0 + const slow = duration > this.project.globalConfig.slowTestThreshold return { + slow, heap: result.heap, - duration: result.duration!, + duration, startTime: result.startTime, retryCount: result.retryCount ?? 0, repeatCount: result.repeatCount ?? 0, @@ -441,6 +444,10 @@ export interface TestResultSkipped { } export interface TestDiagnostic { + /** + * If the duration of the test is above `slowTestThreshold`. + */ + slow: boolean /** * The amount of memory used by the test in bytes. * This value is only available if the test was executed with `logHeapUsage` flag.