diff --git a/packages/vitest/src/config.ts b/packages/vitest/src/config.ts index e08dcab0fa058..b3e71144ff7a2 100644 --- a/packages/vitest/src/config.ts +++ b/packages/vitest/src/config.ts @@ -30,6 +30,8 @@ export function defineProject(config: T): T { return config } -export function defineWorkspace(config: T): T { +type Workspace = (string | (UserProjectConfigExport & { extends?: string })) + +export function defineWorkspace(config: Workspace[]): Workspace[] { return config } diff --git a/test/config/package.json b/test/config/package.json index 3318db3a62466..598c81fc3ec07 100644 --- a/test/config/package.json +++ b/test/config/package.json @@ -3,7 +3,7 @@ "type": "module", "private": true, "scripts": { - "test": "vitest run --typecheck" + "test": "vitest run --typecheck.enabled" }, "devDependencies": { "vite": "latest", diff --git a/test/config/test/config-types.test-d.ts b/test/config/test/config-types.test-d.ts index ce7dbc8288d83..16f3da044bf59 100644 --- a/test/config/test/config-types.test-d.ts +++ b/test/config/test/config-types.test-d.ts @@ -1,5 +1,5 @@ -import { describe, expectTypeOf, test } from 'vitest' -import { type UserWorkspaceConfig, defineConfig, defineProject, defineWorkspace, mergeConfig } from 'vitest/config' +import { assertType, describe, expectTypeOf, test } from 'vitest' +import { defineConfig, defineProject, defineWorkspace, mergeConfig } from 'vitest/config' const expectMainTestConfig = expectTypeOf(defineConfig).parameter(0).resolves.toHaveProperty('test').exclude() const expectProjectTestConfig = expectTypeOf(defineProject).parameter(0).resolves.toHaveProperty('test').exclude() @@ -26,9 +26,76 @@ describe('merge config helper', () => { }) }) -describe('workspace config', () => { - test('correctly defines return type', () => { - expectTypeOf(defineWorkspace([{ test: { name: 'test' } }])).items.toMatchTypeOf() - expectTypeOf(defineWorkspace(['packages/*'])).items.toBeString() +describe('define workspace helper', () => { + type DefineWorkspaceParameter = Parameters[0] + + test('allows string', () => { + assertType(['./path/to/workspace']) + }) + + test('allows config object', () => { + assertType([{ + test: { + name: 'Workspace Project #1', + include: ['string'], + + // @ts-expect-error -- Not allowed here + coverage: {}, + }, + }]) + }) + + test('allows mixing strings and config objects', () => { + defineWorkspace([ + './path/to/project', + { + test: { + name: 'Workspace Project #1', + include: ['string'], + + // @ts-expect-error -- Not allowed here + coverage: {}, + }, + }, + './path/to/another/project', + { + extends: 'workspace custom field', + test: { + name: 'Workspace Project #2', + include: ['string'], + + // @ts-expect-error -- Not allowed here + coverage: {}, + }, + }, + ]) + }) + + test('return type matches parameters', () => { + expectTypeOf(defineWorkspace).returns.toMatchTypeOf() + + expectTypeOf(defineWorkspace([ + './path/to/project', + { + test: { + name: 'Workspace Project #1', + include: ['string'], + + // @ts-expect-error -- Not allowed here + coverage: {}, + }, + }, + './path/to/another/project', + { + extends: 'workspace custom field', + test: { + name: 'Workspace Project #2', + include: ['string'], + + // @ts-expect-error -- Not allowed here + coverage: {}, + }, + }, + ])).items.toMatchTypeOf() }) })