From 47003679436ea3681c08be354c66f8e184383c04 Mon Sep 17 00:00:00 2001 From: Vladimir Date: Wed, 5 Jun 2024 12:40:18 +0200 Subject: [PATCH] fix(browser): set server.open to false and move error handling after init (#5845) --- packages/browser/src/client/mocker.ts | 12 ++++++++---- packages/browser/src/client/tester.ts | 10 +++++----- packages/vitest/src/browser.ts | 2 +- packages/vitest/src/integrations/browser/server.ts | 3 ++- packages/vitest/src/node/config.ts | 8 +++++--- packages/vitest/src/node/plugins/index.ts | 5 +++-- 6 files changed, 24 insertions(+), 16 deletions(-) diff --git a/packages/browser/src/client/mocker.ts b/packages/browser/src/client/mocker.ts index 10780d3c733c..c76c5c218b18 100644 --- a/packages/browser/src/client/mocker.ts +++ b/packages/browser/src/client/mocker.ts @@ -5,14 +5,18 @@ import { getBrowserState } from './utils' const now = Date.now +interface SpyModule { + spyOn: typeof import('vitest').vi['spyOn'] +} + export class VitestBrowserClientMocker { private queue = new Set>() private mocks: Record = {} private factories: Record any> = {} - private spyModule!: typeof import('vitest') + private spyModule!: SpyModule - public setSpyModule(mod: typeof import('vitest')) { + public setSpyModule(mod: SpyModule) { this.spyModule = mod } @@ -187,7 +191,7 @@ export class VitestBrowserClientMocker { if (isFunction) { // mock and delegate calls to original prototype method, which should be also mocked already const original = this[key] - const mock = spyModule.vi.spyOn(this, key as string).mockImplementation(original) + const mock = spyModule.spyOn(this, key as string).mockImplementation(original) mock.mockRestore = () => { mock.mockReset() mock.mockImplementation(original) @@ -197,7 +201,7 @@ export class VitestBrowserClientMocker { } } } - const mock = spyModule.vi.spyOn(newContainer, property).mockImplementation(mockFunction) + const mock = spyModule.spyOn(newContainer, property).mockImplementation(mockFunction) mock.mockRestore = () => { mock.mockReset() mock.mockImplementation(mockFunction) diff --git a/packages/browser/src/client/tester.ts b/packages/browser/src/client/tester.ts index acee61f27341..2752a3ebf067 100644 --- a/packages/browser/src/client/tester.ts +++ b/packages/browser/src/client/tester.ts @@ -63,9 +63,6 @@ async function prepareTestEnvironment(files: string[]) { const rpc: any = await loadSafeRpc(client) - stopErrorHandler() - registerUnexpectedErrors(rpc) - const providedContext = await client.rpc.getProvidedContext() const state: WorkerGlobalState = { @@ -119,17 +116,20 @@ async function prepareTestEnvironment(files: string[]) { browserHashMap.set(filename, [true, version]) }) - const [runner, { startTests, setupCommonEnv, Vitest }] = await Promise.all([ + const [runner, { startTests, setupCommonEnv, Spy }] = await Promise.all([ initiateRunner(config), importId('vitest/browser') as Promise, ]) - mocker.setSpyModule(Vitest) + mocker.setSpyModule(Spy) onCancel.then((reason) => { runner.onCancel?.(reason) }) + stopErrorHandler() + registerUnexpectedErrors(rpc) + return { runner, config, diff --git a/packages/vitest/src/browser.ts b/packages/vitest/src/browser.ts index c167bc899854..5515f458c441 100644 --- a/packages/vitest/src/browser.ts +++ b/packages/vitest/src/browser.ts @@ -10,4 +10,4 @@ export { getCoverageProvider, startCoverageInsideWorker, } from './integrations/coverage' -export * as Vitest from './index' +export * as Spy from './integrations/spy' diff --git a/packages/vitest/src/integrations/browser/server.ts b/packages/vitest/src/integrations/browser/server.ts index ba9d3596ede4..bc93ce8433e1 100644 --- a/packages/vitest/src/integrations/browser/server.ts +++ b/packages/vitest/src/integrations/browser/server.ts @@ -35,7 +35,7 @@ export async function createBrowserServer(project: WorkspaceProject, configFile: enforce: 'post', name: 'vitest:browser:config', async config(config) { - const server = resolveApiServerConfig(config.test?.browser || {}) || { + const server = resolveApiServerConfig(config.test?.browser || {}, defaultBrowserPort) || { port: defaultBrowserPort, } @@ -45,6 +45,7 @@ export async function createBrowserServer(project: WorkspaceProject, configFile: config.server = { ...config.server, ...server, + open: false, } config.server.fs ??= {} config.server.fs.allow = config.server.fs.allow || [] diff --git a/packages/vitest/src/node/config.ts b/packages/vitest/src/node/config.ts index b5b0c419d227..90e49c7249fd 100644 --- a/packages/vitest/src/node/config.ts +++ b/packages/vitest/src/node/config.ts @@ -38,6 +38,7 @@ function parseInspector(inspect: string | undefined | boolean | number) { export function resolveApiServerConfig( options: Options, + defaultPort: number, ): ApiConfig | undefined { let api: ApiConfig | undefined @@ -407,7 +408,7 @@ export function resolveConfig( } // the server has been created, we don't need to override vite.server options - resolved.api = resolveApiServerConfig(options) + resolved.api = resolveApiServerConfig(options, defaultPort) if (options.related) resolved.related = toArray(options.related).map(file => resolve(resolved.root, file)) @@ -535,7 +536,8 @@ export function resolveConfig( resolved.browser.enabled ??= false resolved.browser.headless ??= isCI resolved.browser.isolate ??= true - resolved.browser.ui ??= !isCI + // disable in headless mode by default, and if CI is detected + resolved.browser.ui ??= resolved.browser.headless === false ? true : !isCI resolved.browser.viewport ??= {} as any resolved.browser.viewport.width ??= 414 @@ -544,7 +546,7 @@ export function resolveConfig( if (resolved.browser.enabled && stdProvider === 'stackblitz') resolved.browser.provider = 'preview' - resolved.browser.api = resolveApiServerConfig(resolved.browser) || { + resolved.browser.api = resolveApiServerConfig(resolved.browser, defaultBrowserPort) || { port: defaultBrowserPort, } diff --git a/packages/vitest/src/node/plugins/index.ts b/packages/vitest/src/node/plugins/index.ts index 01791ac4cab7..06eb1d2037da 100644 --- a/packages/vitest/src/node/plugins/index.ts +++ b/packages/vitest/src/node/plugins/index.ts @@ -6,6 +6,7 @@ import { deepMerge, notNullish, removeUndefinedValues, toArray } from '../../uti import { resolveApiServerConfig } from '../config' import { Vitest } from '../core' import { generateScopedClassName } from '../../integrations/css/css-modules' +import { defaultPort } from '../../constants' import { SsrReplacerPlugin } from './ssrReplacer' import { CSSEnablerPlugin } from './cssEnabler' import { CoverageTransform } from './coverageTransform' @@ -48,7 +49,7 @@ export async function VitestPlugin(options: UserConfig = {}, ctx = new Vitest('t removeUndefinedValues(viteConfig.test ?? {}), options, ) - testConfig.api = resolveApiServerConfig(testConfig) + testConfig.api = resolveApiServerConfig(testConfig, defaultPort) // store defines for globalThis to make them // reassignable when running in worker in src/runtime/setup.ts @@ -166,7 +167,7 @@ export async function VitestPlugin(options: UserConfig = {}, ctx = new Vitest('t viteConfigTest, options, ) - options.api = resolveApiServerConfig(options) + options.api = resolveApiServerConfig(options, defaultPort) // we replace every "import.meta.env" with "process.env" // to allow reassigning, so we need to put all envs on process.env