From b31405f6fdd77fa85ac4d9acf297fec67f159bbb Mon Sep 17 00:00:00 2001 From: Ricardo Gobbo de Souza Date: Mon, 5 Sep 2022 05:51:00 -0300 Subject: [PATCH] feat(test-utils): add `mockFn` and `mockLogger` utils (#6235) Co-authored-by: Pooya Parsa --- .../content/2.guide/6.going-further/7.testing.md | 5 +++++ packages/test-utils/build.config.ts | 3 +-- packages/test-utils/package.json | 1 + packages/test-utils/src/context.ts | 4 +++- packages/test-utils/src/index.ts | 1 + packages/test-utils/src/mock.ts | 16 ++++++++++++++++ packages/test-utils/src/setup/jest.ts | 7 ++++++- packages/test-utils/src/setup/vitest.ts | 3 +++ packages/test-utils/src/types.ts | 1 + yarn.lock | 1 + 10 files changed, 38 insertions(+), 4 deletions(-) create mode 100644 packages/test-utils/src/mock.ts diff --git a/docs/content/2.guide/6.going-further/7.testing.md b/docs/content/2.guide/6.going-further/7.testing.md index 0f4406a7b29..4fa4fb14cc0 100644 --- a/docs/content/2.guide/6.going-further/7.testing.md +++ b/docs/content/2.guide/6.going-further/7.testing.md @@ -184,6 +184,11 @@ describe('ssr', async () => { For more usage, please refer to our [tests for Nuxt 3 framework](https://github.com/nuxt/framework/blob/main/test/basic.test.ts). +## Mock utils + +- `mockFn()`: Returns a mocked function based on test runner. +- `mockLogger()`: Mocks logger using [`consola.mockTypes`](https://github.com/unjs/consola#mocktypes) and `mockFn()`. Returns an object of mocked logger types. + ## Testing in a Browser ::alert{icon=🚧} diff --git a/packages/test-utils/build.config.ts b/packages/test-utils/build.config.ts index 038925e9197..586a5fe31d7 100644 --- a/packages/test-utils/build.config.ts +++ b/packages/test-utils/build.config.ts @@ -5,10 +5,9 @@ export default defineBuildConfig({ entries: [ 'src/index' ], - dependencies: [ - ], externals: [ 'vitest', + 'jest', 'playwright', 'playwright-core', 'listhen' diff --git a/packages/test-utils/package.json b/packages/test-utils/package.json index 71e8b52211c..49e8f472688 100644 --- a/packages/test-utils/package.json +++ b/packages/test-utils/package.json @@ -15,6 +15,7 @@ "dependencies": { "@nuxt/kit": "3.0.0-rc.9", "@nuxt/schema": "3.0.0-rc.9", + "consola": "^2.15.3", "defu": "^6.1.0", "execa": "^6.1.0", "get-port-please": "^2.6.1", diff --git a/packages/test-utils/src/context.ts b/packages/test-utils/src/context.ts index 3a09ecab5f1..ad987d1ec97 100644 --- a/packages/test-utils/src/context.ts +++ b/packages/test-utils/src/context.ts @@ -22,7 +22,9 @@ export function createTestContext (options: Partial): TestContext { } }) - return setTestContext({ options: _options as TestOptions }) + return setTestContext({ + options: _options as TestOptions + }) } export function useTestContext (): TestContext { diff --git a/packages/test-utils/src/index.ts b/packages/test-utils/src/index.ts index 55d9ebae535..3238c8d5203 100644 --- a/packages/test-utils/src/index.ts +++ b/packages/test-utils/src/index.ts @@ -1,5 +1,6 @@ export * from './browser' export * from './context' +export * from './mock' export * from './nuxt' export * from './server' export * from './setup' diff --git a/packages/test-utils/src/mock.ts b/packages/test-utils/src/mock.ts new file mode 100644 index 00000000000..52843da05a8 --- /dev/null +++ b/packages/test-utils/src/mock.ts @@ -0,0 +1,16 @@ +import consola from 'consola' +import { useTestContext } from './context' + +export function mockFn () { + const ctx = useTestContext() + return ctx.mockFn +} + +export function mockLogger (): Record { + const mocks: any = {} + consola.mockTypes((type) => { + mocks[type] = mockFn() + return mocks[type] + }) + return mocks +} diff --git a/packages/test-utils/src/setup/jest.ts b/packages/test-utils/src/setup/jest.ts index 67bec30a58b..01a9f654386 100644 --- a/packages/test-utils/src/setup/jest.ts +++ b/packages/test-utils/src/setup/jest.ts @@ -1,6 +1,11 @@ import type { TestHooks } from '../types' -export default function setupJest (hooks: TestHooks) { +export default async function setupJest (hooks: TestHooks) { + // @ts-ignore + const jest = await import('jest') + + hooks.ctx.mockFn = jest.fn + // TODO: add globals existing check to provide better error message // @ts-expect-error jest types test('setup', hooks.setup, 120 * 1000) diff --git a/packages/test-utils/src/setup/vitest.ts b/packages/test-utils/src/setup/vitest.ts index 60a3b340ffb..5fa16f6d9ed 100644 --- a/packages/test-utils/src/setup/vitest.ts +++ b/packages/test-utils/src/setup/vitest.ts @@ -2,6 +2,9 @@ import type { TestHooks } from '../types' export default async function setupVitest (hooks: TestHooks) { const vitest = await import('vitest') + + hooks.ctx.mockFn = vitest.vi.fn + vitest.beforeAll(hooks.setup, 120 * 1000) vitest.beforeEach(hooks.beforeEach) vitest.afterEach(hooks.afterEach) diff --git a/packages/test-utils/src/types.ts b/packages/test-utils/src/types.ts index 8e41fa4a9f2..ab8612ff216 100644 --- a/packages/test-utils/src/types.ts +++ b/packages/test-utils/src/types.ts @@ -31,6 +31,7 @@ export interface TestContext { browser?: Browser url?: string serverProcess?: ExecaChildProcess + mockFn?: Function } export interface TestHooks { diff --git a/yarn.lock b/yarn.lock index f23a6f76582..720234deb97 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1743,6 +1743,7 @@ __metadata: dependencies: "@nuxt/kit": 3.0.0-rc.9 "@nuxt/schema": 3.0.0-rc.9 + consola: ^2.15.3 defu: ^6.1.0 execa: ^6.1.0 get-port-please: ^2.6.1