From 5c308edc660c90ca78f5216e3d50ffd3f805dc94 Mon Sep 17 00:00:00 2001 From: Vladimir Date: Thu, 9 May 2024 17:33:30 +0200 Subject: [PATCH] feat: remove deprecated options (#5696) --- packages/ui/node/reporter.ts | 5 +---- packages/vitest/src/index.ts | 2 -- packages/vitest/src/node/cli/cac.ts | 7 ------- packages/vitest/src/node/config.ts | 5 ----- packages/vitest/src/node/index.ts | 10 +++++++++- packages/vitest/src/node/reporters/html.ts | 3 +++ packages/vitest/src/node/reporters/index.ts | 3 ++- packages/vitest/src/node/reporters/junit.ts | 6 ++---- packages/vitest/src/types/config.ts | 1 - test/config/test/failures.test.ts | 7 ------- 10 files changed, 17 insertions(+), 32 deletions(-) create mode 100644 packages/vitest/src/node/reporters/html.ts diff --git a/packages/ui/node/reporter.ts b/packages/ui/node/reporter.ts index a11b18b6a30e..e67f56e29a2b 100644 --- a/packages/ui/node/reporter.ts +++ b/packages/ui/node/reporter.ts @@ -7,12 +7,9 @@ import c from 'picocolors' import fg from 'fast-glob' import { stringify } from 'flatted' import type { File, ModuleGraphData, Reporter, ResolvedConfig, Vitest } from 'vitest' +import type { HTMLOptions } from 'vitest/node' import { getModuleGraph } from '../../vitest/src/utils/graph' -export interface HTMLOptions { - outputFile?: string -} - interface PotentialConfig { outputFile?: string | Partial> } diff --git a/packages/vitest/src/index.ts b/packages/vitest/src/index.ts index 4b298149dc56..8f898d539282 100644 --- a/packages/vitest/src/index.ts +++ b/packages/vitest/src/index.ts @@ -17,8 +17,6 @@ export * from './integrations/chai' export * from './integrations/vi' export * from './integrations/utils' export { inject } from './integrations/inject' -// TODO: remove in 2.0.0, import from vitest/snapshot directly -export type { SnapshotEnvironment } from '@vitest/snapshot/environment' export * from './types' export * from './api/types' diff --git a/packages/vitest/src/node/cli/cac.ts b/packages/vitest/src/node/cli/cac.ts index 2fd61e3517da..7eb22907c4bd 100644 --- a/packages/vitest/src/node/cli/cac.ts +++ b/packages/vitest/src/node/cli/cac.ts @@ -167,13 +167,6 @@ export function createCLI(options: CLIOptions = {}) { benchCliOptionsConfig, ) - // TODO: remove in Vitest 2.0 - cli - .command('typecheck [...filters]') - .action(() => { - throw new Error(`Running typecheck via "typecheck" command is removed. Please use "--typecheck" to run your regular tests alongside typechecking, or "--typecheck.only" to run only typecheck tests.`) - }) - cli .command('[...filters]', undefined, options) .action((filters, options) => start('test', filters, options)) diff --git a/packages/vitest/src/node/config.ts b/packages/vitest/src/node/config.ts index 44555faea5c9..6b438170d8cf 100644 --- a/packages/vitest/src/node/config.ts +++ b/packages/vitest/src/node/config.ts @@ -167,11 +167,6 @@ export function resolveConfig( } } - // TODO: V2.0.0 remove - // @ts-expect-error -- check for removed API option - if (resolved.coverage.provider === 'c8') - throw new Error('"coverage.provider: c8" is not supported anymore. Use "coverage.provider: v8" instead') - if (resolved.coverage.provider === 'v8' && resolved.coverage.enabled && isBrowserEnabled(resolved)) throw new Error('@vitest/coverage-v8 does not work with --browser. Use @vitest/coverage-istanbul instead') diff --git a/packages/vitest/src/node/index.ts b/packages/vitest/src/node/index.ts index 9178c52ae8c8..92bacfeaee5a 100644 --- a/packages/vitest/src/node/index.ts +++ b/packages/vitest/src/node/index.ts @@ -13,4 +13,12 @@ export { VitestPackageInstaller } from './packageInstaller' export type { TestSequencer, TestSequencerConstructor } from './sequencers/types' export { BaseSequencer } from './sequencers/BaseSequencer' -export type { BrowserProviderInitializationOptions, BrowserProvider, BrowserProviderOptions, BrowserScript } from '../types/browser' +export type { + BrowserProviderInitializationOptions, + BrowserProvider, + BrowserProviderOptions, + BrowserScript, +} from '../types/browser' +export type { JsonOptions } from './reporters/json' +export type { JUnitOptions } from './reporters/junit' +export type { HTMLOptions } from './reporters/html' diff --git a/packages/vitest/src/node/reporters/html.ts b/packages/vitest/src/node/reporters/html.ts new file mode 100644 index 000000000000..9f0f63403bfd --- /dev/null +++ b/packages/vitest/src/node/reporters/html.ts @@ -0,0 +1,3 @@ +export interface HTMLOptions { + outputFile?: string +} diff --git a/packages/vitest/src/node/reporters/index.ts b/packages/vitest/src/node/reporters/index.ts index ffd2dde0812f..06a62055dc27 100644 --- a/packages/vitest/src/node/reporters/index.ts +++ b/packages/vitest/src/node/reporters/index.ts @@ -10,6 +10,7 @@ import { TapFlatReporter } from './tap-flat' import { HangingProcessReporter } from './hanging-process' import { GithubActionsReporter } from './github-actions' import type { BaseReporter } from './base' +import type { HTMLOptions } from './html' export { DefaultReporter, @@ -52,7 +53,7 @@ export interface BuiltinReporterOptions { 'tap-flat': never 'junit': JUnitOptions 'hanging-process': never - 'html': { outputFile?: string } // TODO: Any better place for defining this UI package's reporter options? + 'html': HTMLOptions } export * from './benchmark' diff --git a/packages/vitest/src/node/reporters/junit.ts b/packages/vitest/src/node/reporters/junit.ts index ccbae37ddd99..2400672ad58f 100644 --- a/packages/vitest/src/node/reporters/junit.ts +++ b/packages/vitest/src/node/reporters/junit.ts @@ -169,8 +169,7 @@ export class JUnitReporter implements Reporter { async writeTasks(tasks: Task[], filename: string): Promise { for (const task of tasks) { await this.writeElement('testcase', { - // TODO: v2.0.0 Remove env variable in favor of custom reporter options, e.g. "reporters: [['json', { classname: 'something' }]]" - classname: this.options.classname ?? process.env.VITEST_JUNIT_CLASSNAME ?? filename, + classname: this.options.classname ?? filename, file: this.options.addFileAttribute ? filename : undefined, name: task.name, time: getDuration(task), @@ -264,8 +263,7 @@ export class JUnitReporter implements Reporter { stats.failures += file.stats.failures return stats }, { - // TODO: v2.0.0 Remove env variable in favor of custom reporter options, e.g. "reporters: [['json', { suiteName: 'something' }]]" - name: this.options.suiteName || process.env.VITEST_JUNIT_SUITE_NAME || 'vitest tests', + name: this.options.suiteName || 'vitest tests', tests: 0, failures: 0, errors: 0, // we cannot detect those diff --git a/packages/vitest/src/types/config.ts b/packages/vitest/src/types/config.ts index 400755654200..a45326944a1d 100644 --- a/packages/vitest/src/types/config.ts +++ b/packages/vitest/src/types/config.ts @@ -391,7 +391,6 @@ export interface InlineConfig { */ reporters?: Arrayable | ((ReporterName | InlineReporter) | [ReporterName] | ReporterWithOptions)[] - // TODO: v2.0.0 Remove in favor of custom reporter options, e.g. "reporters: [['json', { outputFile: 'some-dir/file.html' }]]" /** * Write test results to a file when the --reporter=json` or `--reporter=junit` option is also specified. * Also definable individually per reporter by using an object instead. diff --git a/test/config/test/failures.test.ts b/test/config/test/failures.test.ts index 4f3ca721d13e..79d8af2ca1fa 100644 --- a/test/config/test/failures.test.ts +++ b/test/config/test/failures.test.ts @@ -49,13 +49,6 @@ test('inspect-brk cannot be used with multi processing', async () => { expect(stderr).toMatch('Error: You cannot use --inspect without "--no-file-parallelism", "poolOptions.threads.singleThread" or "poolOptions.forks.singleFork"') }) -test('c8 coverage provider is not supported', async () => { - // @ts-expect-error -- check for removed API option - const { stderr } = await runVitest({ coverage: { enabled: true, provider: 'c8' } }) - - expect(stderr).toMatch('Error: "coverage.provider: c8" is not supported anymore. Use "coverage.provider: v8" instead') -}) - test('v8 coverage provider cannot be used with browser', async () => { const { stderr } = await runVitest({ coverage: { enabled: true }, browser: { enabled: true, name: 'chrome' } })