with one click
nuxt-test-utils-skilld
// ALWAYS use when writing code importing "@nuxt/test-utils". Consult for debugging, best practices, or modifying @nuxt/test-utils, nuxt/test-utils, nuxt test-utils, nuxt test utils, test-utils, test utils.
// ALWAYS use when writing code importing "@nuxt/test-utils". Consult for debugging, best practices, or modifying @nuxt/test-utils, nuxt/test-utils, nuxt test-utils, nuxt test utils, test-utils, test utils.
| name | nuxt-test-utils-skilld |
| description | ALWAYS use when writing code importing "@nuxt/test-utils". Consult for debugging, best practices, or modifying @nuxt/test-utils, nuxt/test-utils, nuxt test-utils, nuxt test utils, test-utils, test utils. |
| metadata | {"version":"4.0.0","generated_by":"Claude Code ยท Haiku 4.5","generated_at":"2026-03-19T00:00:00.000Z"} |
@nuxt/test-utilsVersion: 4.0.0 Deps: @clack/prompts@1.0.0, @nuxt/devtools-kit@^2.7.0, @nuxt/kit@^3.21.0, c12@^3.3.3, consola@^3.4.2, defu@^6.1.4, destr@^2.0.5, estree-walker@^3.0.3, exsolve@^1.0.8, fake-indexeddb@^6.2.5, get-port-please@^3.2.0, h3@^1.15.5, h3-next@npm:h3@2.0.1-rc.11, local-pkg@^1.1.2, magic-string@^0.30.21, node-fetch-native@^1.6.7, node-mock-http@^1.0.4, nypm@^0.6.4, ofetch@^1.5.1, pathe@^2.0.3, perfect-debounce@^2.1.0, radix3@^1.1.2, scule@^1.3.0, std-env@^3.10.0, tinyexec@^1.0.2, ufo@^1.6.3, unplugin@^3.0.0, vitest-environment-nuxt@^1.0.1, vue@^3.5.27 Tags: alpha: 3.9.0-alpha.3, latest: 4.0.0
References: package.json โ exports, entry points โข README โ setup, basic usage โข Docs โ API reference, guides โข GitHub Issues โ bugs, workarounds, edge cases โข GitHub Discussions โ Q&A, patterns, recipes โข Releases โ changelog, breaking changes, new APIs
Use skilld search instead of grepping .skilld/ directories โ hybrid semantic + keyword search across all indexed docs, issues, and releases. If skilld is unavailable, use npx -y skilld search.
skilld search "query" -p @nuxt/test-utils
skilld search "issues:error handling" -p @nuxt/test-utils
skilld search "releases:deprecated" -p @nuxt/test-utils
Filters: docs:, issues:, releases: prefix narrows by source type.
This section documents version-specific API changes โ prioritize recent major/minor releases.
BREAKING: Composables at top-level of describe block โ v4 moved Nuxt initialization from setupFiles to beforeAll hook, causing useRouter(), useRoute(), useNuxtApp() and other composables to fail with [nuxt] instance unavailable when called outside of beforeAll/beforeEach/test block. Wrap at-describe-level usage in beforeAll() source
BREAKING: vi.mock stricter exports โ v4 (via vitest v4) throws error when accessing exports not returned by factory function, instead of silently returning undefined. Use importOriginal helper to preserve all exports source
BREAKING: vitest peer dependency โ v4 requires vitest ^4.0.2 (from ^3.2.0). Tightened dependency ranges for happy-dom >=20.0.11, jsdom >=27.4.0, @jest/globals >=30.0.0, @cucumber/cucumber >=11.0.0, @testing-library/vue ^8.0.1 source
NEW: mockNuxtImport original parameter โ v4.0 passes original implementation to factory function, enabling natural partial mocking: mockNuxtImport('useRoute', original => vi.fn(original)) source
NEW: registerEndpoint query parameter support โ v4.0 fixed long-standing issue where registerEndpoint did not work correctly with query parameters in URLs (#1560) source
NEW: registerEndpoint once option โ v3.21 added once option to registerEndpoint for single-use endpoint registration source
NEW: renderSuspended rerender behavior โ v3.21 added support for rerender behavior in renderSuspended helper (#1466) source
NEW: CSS modules in mount/render helpers โ v3.21 added support for CSS modules in mount and render helpers (#1464) source
NEW: cleanup scoped option โ v3.20 added scoped option to cleanup components for targeted cleanup (#1389) source
NEW: registerEndpoint with native fetch โ v3.20 enabled registerEndpoint to work with native fetch and $fetch.create (#1415, #1403) source
NEW: wrapper.vm automatic ref unwrapping โ v3.20 added automatic ref unwrapping for wrapper.vm property, simplifying access to unwrapped reactive values (#1405) source
NEW: mockNuxtImport mocked target arguments โ v3.21 added support for mocked target arguments in mockNuxtImport (#1492) source
NEW: Mocking before Nuxt startup โ v4.0 moved Nuxt initialization to beforeAll hook, allowing vi.mock and mockNuxtImport to take effect before Nuxt starts, fixing unreliable mocking of composables used in middleware and plugins (#1516, #750, #836, #1496) source
NEW: setupBun timeouts โ v4.0 added support for setup and teardown timeouts configuration in setupBun (#1578) source
Also changed: Route sync emulation skipped when NuxtPage exists (v3.22) ยท Initial route change can be skipped via option (v3.22) ยท h3 v2 support (v3.23) ยท mount + render helpers unified logic (v3.22) ยท App context passed across mount + render helpers (v3.21)
Move Nuxt composable calls to beforeAll or beforeEach hooks, not describe block scope โ Nuxt initialization moved to beforeAll in v4.0.0, causing describe-level composable calls to fail with "instance unavailable" error source
Use mockNuxtImport with the original implementation parameter for natural partial mocking โ v4.0.0 passes the original factory to enable spreading and modifying without infinite loops source
mockNuxtImport('useRoute', original =>
vi.fn(original)
)
Extract import.meta.server and import.meta.client to a helper module before mocking โ direct assignment to import.meta doesn't work; wrap in a re-export and mock that instead source
Use .env.test file for test-specific environment variables instead of config โ Vitest loads .env.test automatically for test runs while preserving actual app config source
Use vi.hoisted() for mock factories to optimize module graph โ avoids eager imports of large dependency trees that mockNuxtImport requires source
const mocks = vi.hoisted(() => ({
navigateTo: vi.fn(),
useRouter: vi.fn(),
}))
vi.mock('#app/composables/router', () => mocks)
Place server/API tests in the nuxt environment, not node โ server code needs Nuxt magic (auto-imports, composables); node environment is only for pure utilities source
Mock Pinia stores by wrapping the store import with createTestingPinia โ avoid Symbol conflicts when using @pinia/nuxt module by providing testing instance to store function source
Use scoped option in cleanup for isolated component state โ v3.20.0 added cleanup({ scoped: true }) to prevent test isolation issues with component instances source
Enable automatic ref unwrapping with wrapper.vm โ v3.20.0 unwraps refs automatically, eliminating .value calls for cleaner test assertions source
Use registerEndpoint in setup files for persistent mock routes โ v4.0.0 ensures endpoints persist across module resets and supports query parameters source
Related: unplugin-skilld
ALWAYS use when writing code importing "oxc-walker". Consult for debugging, best practices, or modifying oxc-walker, oxc walker.
Unified plugin system for build tools. ALWAYS use when writing code importing "unplugin". Consult for debugging, best practices, or modifying unplugin.