Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@nuxt/test-utils

nuxt719.6kMIT3.15.4TypeScript support: included

Test utilities for Nuxt

readme

changelog

Changelog

All notable changes to this project will be documented in this file. See standard-version for commit guidelines.

v3.15.4

compare changes

🩹 Fixes

  • e2e: Use tinyexec to resolve nuxi binary (7df895e3)
  • e2e: Increase default windows setup timeout (6f38dd58)

✅ Tests

❤️ Contributors

v3.15.3

compare changes

🩹 Fixes

  • e2e: Use node:path to resolve dist directory (#1054)

❤️ Contributors

v3.15.2

compare changes

🩹 Fixes

  • module: Remove setInterval from the presets (#1035)

🏡 Chore

  • Add devtools-kit types + specify vite in jest fixture (c37781b5)
  • Double windows timeout (45e16131)

✅ Tests

  • Update windows timeout for e2e test (1acb335b)

❤️ Contributors

v3.15.1

compare changes

🩹 Fixes

❤️ Contributors

v3.15.0

compare changes

🚀 Enhancements

  • e2e: Expose NuxtPage playwright type (#1015)
  • playwright: Allow providing default test options (#1001)

🩹 Fixes

  • runtime-utils: Support defineModel in mountSuspended (#1011)
  • core: Bump teardown timeout for jest (3225562ea)
  • runtime-utils: Handle reserved props (#1025)
  • vitest-environment: Suppress suspense warning (#1026)
  • runtime-utils: Suppress errors setting unneeded properties (4e9f34b96)
  • e2e: Handle javaScriptEnabled: false (ca06f3375)
  • e2e: Use subpath import for distDir string (094acb299)
  • e2e: Remove dirname when calculating distDir (56122b745)
  • e2e: Use nuxtConfig.nitro.output.dir with build: false (#936)

🏡 Chore

  • Upgrade typescript separately (ee6f4c088)
  • Add knip and reduce peer dependencies (4e10bd266)
  • Revert node requirement (bb4345a84)
  • Use installed-check to keep engines.node in sync (ebcc5effa)

✅ Tests

🤖 CI

❤️ Contributors

v3.14.4

compare changes

🩹 Fixes

  • e2e: Set NODE_ENV when running built server (#969)
  • runtime-utils: Bind this in options api methods (#971)

❤️ Contributors

v3.14.3

compare changes

🩹 Fixes

  • vitest-environment: Respect custom url in setup (#957)
  • runtime-utils: Pass global directives to mountSuspended (#960)
  • runtime-utils: Pass global directives to renderSuspended (cf1b48ff)
  • runtime-utils: Support options api data, computed + methods (#963)

🏡 Chore

✅ Tests

  • Bump playwright setup time for windows (21ade1f2)

❤️ Contributors

v3.14.2

compare changes

🔥 Performance

  • e2e: Use tinyexec to run commands (#939)

🩹 Fixes

  • config: Exclude new nuxt import-conditions plugin (7cc8f653b)

📖 Documentation

🏡 Chore

  • vitest-environment-nuxt: Specify license is MIT (#919)
  • Release vitest-environment-nuxt (e30c044cf)
  • Update @nuxtjs/i18n separately (3d8955d36)
  • Set compatibilityDate in fixtures (7723f969c)
  • Update vitest type import (05e94fcc4)
  • Trim tag from tinyexec stdout (2b50cfee0)

❤️ Contributors

v3.14.1

compare changes

🩹 Fixes

  • e2e,config: Provide fallback compatibilityDate (8e01e3f7f)
  • module: Don't include type-check plugin in resolved vitest plugins (#911)

📖 Documentation

  • Provide intellisense hints for setup properties (#906)

🏡 Chore

❤️ Contributors

v3.14.0

compare changes

🚀 Enhancements

  • runtime-utils: Expose setup result from renderSuspended (#852)
  • e2e: Allow overwriting env variables in setup (#903)
  • e2e: Allow running e2e tests against existing server (#803)
  • e2e: Allow updating env in context before setup runs (#812)

🩹 Fixes

  • runtime-utils: Ts-ignore #build/ import until nuxt v3.12 release (66b23ae6)
  • runtime-utils: Allow setProps to replace an array (#877)

🏡 Chore

  • Ignore ts-ignores for now (ac2d9fbb)
  • Add @danielroe to code owners (76f65b3b)
  • Remove ts-ignore now that we're upgraded (16827f7f)

✅ Tests

  • Bump timeout in windows browser spec (73e2c716)

❤️ Contributors

v3.13.1

compare changes

🩹 Fixes

  • Revert execa to v8 for now (fef8b062)
  • config: Force buildId to test manually (25e081e4)
  • runtime-utils: Use appId fallback after tryUseNuxtApp (#849)

🏡 Chore

🤖 CI

  • Run test suite on windows (#851)

❤️ Contributors

v3.13.0

compare changes

🚀 Enhancements

  • e2e: Improve types for $fetch (b21d9a54)
  • deps: Upgrade execa to v9 (#843)

🔥 Performance

  • e2e: Don't iterate when cleaning up if nothing registered (#753)

🩹 Fixes

  • e2e: Improve types for fetch and mockLogger (eb40a6a6)
  • e2e: Force string response within startServer (1b182505)
  • e2e: Improve return types for mockLogger (21aa7a2f)
  • runtime: Improve types for renderSuspended and mountSuspended (1636cede)
  • e2e: Revert changes for $fetch inference to unbreak build (dd295d39)
  • vitest: Strongly type vitest environment options (37582c71)
  • module: Correctly filter vite plugins (021824d0)
  • runtime: Preserve setupState return (ab7fd457)
  • playwright: Bump dependency and remove polyfill (#819)
  • runtime: Use effectScope in renderSuspended (#820)
  • e2e: Type $fetch using globalThis instead (b1269edb)
  • Set buildId to nuxt-app for compatibility with nuxt v3.12+ (a00b2c1f)
  • runtime-utils: Use tryUseNuxtApp rather than buildId override (726e0a2d)

🏡 Chore

❤️ Contributors

v3.12.1

compare changes

🩹 Fixes

  • Publish playwright.d.ts (#797)

❤️ Contributors

v3.12.0

compare changes

🚀 Enhancements

  • e2e: Add 'route'/'hydration' options for page.goto() (#739)
  • e2e: Add playwright runner (#776)

🩹 Fixes

  • config: Remove nuxt's custom vite logger (eca52f5c)

🏡 Chore

  • Force correct typing for e2e subpath (9fd93a8c)
  • Don't run publish step separately (0078d0bc)

🤖 CI

❤️ Contributors

v3.11.0

compare changes

🚀 Enhancements

  • vitest-environment: Add support for in-source testing (#651)

🩹 Fixes

  • runtime: Reset modules after nuxt setup runs (#726)

✅ Tests

  • Add example of mocking vue-router (e293cea1)
  • Add example of mocking nuxt useRoute (fe465193)

❤️ Contributors

v3.10.0

compare changes

🚀 Enhancements

  • e2e: Add cucumber test runner (#711)
  • e2e: Support env option for startServer (#640)

🩹 Fixes

  • runtime-utils: Resolve to in RouterLink stub (#687)
  • Mark afterAll and setup hooks as async (#702)
  • module: Always append import when mocking (#701)

🏡 Chore

  • Add required dev deps to app-vitest example (#712)
  • Pin vue/nuxt versions (00674cd0)

✅ Tests

  • Update config key (25060645)
  • Add example test for nuxt-injected value (#663)
  • Update to actually use $t (#675)

🤖 CI

❤️ Contributors

v3.9.0

compare changes

🚀 Enhancements

  • Add nuxt-vitest re-exports (#230)
  • Add nuxt-vitest and vitest-environment-nuxt code and tests (f4ae58ac)
  • Use internal implementation of nuxt-vitest (#235)
  • e2e: Auto-detect jest runner (ae37b0ee)
  • ⚠️ Read .env.test + allow overriding with nuxt.dotenv (#655)

🩹 Fixes

  • Add @nuxt/test-utils-nightly to deps to inline (0caf44d0)
  • Use implied .d.mts types (d9694f21)
  • Add setupState type to mountSuspended return type (#400)
  • Add runtime fixture to workspace and address regressions (#240)
  • Opt-in to future vitest option (#247)
  • Use vite-ignore for playwright dynamic import (c1ac4a08)
  • Do not set process.browser globally (#250)
  • Support transpiling nuxt nightly releases (c63f69c8)
  • Rewrite mock plugin for compat with vite 5/rollup 4 (d0ba5af3)
  • Do not skip transforms on test files (3bbcc1ea)
  • Add @vitest/ui to peer deps (7f4f6053)
  • Use buildDir option (#596)
  • ⚠️ Load nuxt app within setupFiles (#260)
  • Teardown build directories after tests (#597)
  • Import useRouter explicitly in entry (129d8335)
  • Return absolute path for stub entry (180bb306)
  • Don't return absolute path in dev mode (f47dd9a3)
  • Clone overrides (df84d0c1)
  • Skip vite-plugin-vue-inspector:post plugin (8a6a0523)
  • Clean up wrappers when calling renderSuspended (5b189115)
  • Exclude vite-plugin-checker from runtime vitest config (053a5dff)
  • Resolve devtools url after vitest config is resolved (1206db79)
  • Remove module override of app.rootId (e662c1f0)
  • Remove rootId environment option (dead5e3d)
  • Add back rootId environment option" (827180ec)
  • runtime-utils: Don't stub helpers when shallow (#632)
  • Avoid enumerating keys on render context (43b2724b)
  • Support typescript entry file (c5806009)
  • vitest-environment: Normalise setupFiles before merge (#653)
  • module: Close nuxt before shutting down (17cf9435)
  • runtime: Do not assign readonly setup state (8d799275)
  • runtime: Implement setProps (522f8bf5)
  • vitest-environment: Handle different entry format (5c07bb48)
  • runtime: Import reactive and unref (d68cdae9)

💅 Refactors

  • Move to monorepo (#31)
  • Split core utils to core/ (f144cb40)
  • Clean up internal code imports (#245)
  • Use defu rather than mergeConfig from vite (#246)
  • Further split vitest from vite config (ef58e4cb)
  • Split out mock transform plugin w/ tests (a37fa408)
  • Remove rollup implementation of transform plugin (71345967)
  • module: Rename config key to testUtils (c2b09732)

📖 Documentation

  • playground: Demo usage of co-exists unit and nuxt testing (#6)
  • Add JSDoc comments (#205)
  • Add documentation for mountSuspended (#227)
  • Add basic README and missing LICENCE (51eb9de2)
  • Remove links to nuxt-vitest (254605df)
  • Update links to nuxt docs on testing (2e619a89)

📦 Build

  • Fix build issues and correct dependencies (3e2f8b29)
  • Move runtime-utils.mjs -> runtime-utils/index.mjs (#634)
  • ⚠️ Use /runtime subpath export (de9a2a81)
  • Prefer /e2e subpath export (88952fb0)

✅ Tests

  • Update playground to 0.4.5 devtools (7d4a6b28)
  • Add useHead to fixture (6d4bb420)
  • Add type tests (9de62b6e)
  • Await 2 ticks after navigation for route to update (cb6c1e3a)
  • Correct test assertion (c644bdb3)
  • Avoid depending on specific number of ticks (e98d71ea)
  • Update test to use server rather than live api (7df6be28)
  • Add a few more basic examples for e2e tests (490753c4)
  • Add jest example/test (#224)
  • Add type test (#241)
  • Make indexeddb plugin client-only (0477e414)
  • Add tests for events emitted from defineModel (#629)
  • Add failing test for exposed methods on components within suspense (a4ec3f83)
  • Remove workaround for route update (c9699ad1)
  • Add example of importing a dynamic route (fe420b9c)
  • Re-organise test suite (9c877821)
  • Add failing test for setProps (dc93e003)
  • Reenable expose test (204037e4)
  • Add example fixture with @nuxt/content (#631)
  • Add example fixture with @nuxtjs/i18n (#633)
  • Add generate assertion and enable browser (94513939)

🎨 Styles

🤖 CI

  • Add testing workflow (ce74b0b5)
  • Add lint workflow for pushes to main (f141b8d4)
  • Add workflow to test examples (0c3c318f)
  • Prepare environment before running module test (5be069dc)
  • 'nightly' releases on pushes to main (#210)
  • Fetch full history (d61614b1)
  • Install playwright manually (58906de3)
  • Remove extra branch from release workflow (e24d884f)
  • Prepare build environment (6d8e71ad)
  • Run unit tests in ci (cbd5616a)
  • Support automated release prs (#623)
  • Fetch all commits in creating changelog (6f22b096)
  • Disable changelog creation script for now (5ef70c35)
  • Reenable changelogensets (fb754d54)

⚠️ Breaking Changes

  • ⚠️ Read .env.test + allow overriding with nuxt.dotenv (#655)
  • ⚠️ Ignore query params when checking if an endpoint is mocked (c1f8890b)
  • ⚠️ Load nuxt app within setupFiles (#260)
  • ⚠️ Use /runtime subpath export (de9a2a81)
  • ⚠️ Drop support for vitest < 0.34 (#654)

❤️ Contributors