[{"data":1,"prerenderedAt":7817},["ShallowReactive",2],{"$fGCo9l1hMtNdUiA6QzdUX5X3kLqaWcC5t2kdz4LrvCvc":3,"versions":2020,"-docs-4-x-getting-started-testing":2024,"-docs-4-x-getting-started-testing-surround":7812},[4,1120,1931],{"title":5,"titleTemplate":6,"icon":7,"path":8,"stem":9,"children":10,"page":108},"Docs",null,"i-lucide-book-marked","/docs/3.x","docs/3.x",[11,109,246,426,907,999,1036,1078],{"title":12,"titleTemplate":13,"icon":14,"path":15,"stem":16,"children":17,"page":108},"Get Started","%s · Get Started with Nuxt","i-lucide-rocket","/docs/3.x/getting-started","docs/3.x/1.getting-started",[18,23,28,33,38,43,48,53,58,63,68,73,78,83,88,93,98,103],{"title":19,"path":20,"stem":21,"titleTemplate":6,"icon":22},"Introduction","/docs/3.x/getting-started/introduction","docs/3.x/1.getting-started/01.introduction","i-lucide-info",{"title":24,"path":25,"stem":26,"titleTemplate":6,"icon":27},"Installation","/docs/3.x/getting-started/installation","docs/3.x/1.getting-started/02.installation","i-lucide-play",{"title":29,"path":30,"stem":31,"titleTemplate":6,"icon":32},"Configuration","/docs/3.x/getting-started/configuration","docs/3.x/1.getting-started/03.configuration","i-lucide-cog",{"title":34,"path":35,"stem":36,"titleTemplate":6,"icon":37},"Views","/docs/3.x/getting-started/views","docs/3.x/1.getting-started/04.views","i-lucide-panels-top-left",{"title":39,"path":40,"stem":41,"titleTemplate":6,"icon":42},"Assets","/docs/3.x/getting-started/assets","docs/3.x/1.getting-started/05.assets","i-lucide-image",{"title":44,"path":45,"stem":46,"titleTemplate":6,"icon":47},"Styling","/docs/3.x/getting-started/styling","docs/3.x/1.getting-started/06.styling","i-lucide-palette",{"title":49,"path":50,"stem":51,"titleTemplate":6,"icon":52},"Routing","/docs/3.x/getting-started/routing","docs/3.x/1.getting-started/07.routing","i-lucide-milestone",{"title":54,"path":55,"stem":56,"titleTemplate":6,"icon":57},"SEO and Meta","/docs/3.x/getting-started/seo-meta","docs/3.x/1.getting-started/08.seo-meta","i-lucide-file-search",{"title":59,"path":60,"stem":61,"titleTemplate":6,"icon":62},"Transitions","/docs/3.x/getting-started/transitions","docs/3.x/1.getting-started/09.transitions","i-lucide-toggle-right",{"title":64,"path":65,"stem":66,"titleTemplate":6,"icon":67},"Data Fetching","/docs/3.x/getting-started/data-fetching","docs/3.x/1.getting-started/10.data-fetching","i-lucide-cable",{"title":69,"path":70,"stem":71,"titleTemplate":6,"icon":72},"State Management","/docs/3.x/getting-started/state-management","docs/3.x/1.getting-started/11.state-management","i-lucide-database",{"title":74,"path":75,"stem":76,"titleTemplate":6,"icon":77},"Error Handling","/docs/3.x/getting-started/error-handling","docs/3.x/1.getting-started/12.error-handling","i-lucide-bug-off",{"title":79,"path":80,"stem":81,"titleTemplate":6,"icon":82},"Server","/docs/3.x/getting-started/server","docs/3.x/1.getting-started/13.server","i-lucide-pc-case",{"title":84,"path":85,"stem":86,"titleTemplate":6,"icon":87},"Layers","/docs/3.x/getting-started/layers","docs/3.x/1.getting-started/14.layers","i-lucide-layers",{"title":89,"path":90,"stem":91,"titleTemplate":6,"icon":92},"Prerendering","/docs/3.x/getting-started/prerendering","docs/3.x/1.getting-started/15.prerendering","i-lucide-file-code-2",{"title":94,"path":95,"stem":96,"titleTemplate":6,"icon":97},"Deployment","/docs/3.x/getting-started/deployment","docs/3.x/1.getting-started/16.deployment","i-lucide-cloud",{"title":99,"path":100,"stem":101,"titleTemplate":6,"icon":102},"Testing","/docs/3.x/getting-started/testing","docs/3.x/1.getting-started/17.testing","i-lucide-circle-check",{"title":104,"path":105,"stem":106,"titleTemplate":6,"icon":107},"Upgrade Guide","/docs/3.x/getting-started/upgrade","docs/3.x/1.getting-started/18.upgrade","i-lucide-circle-arrow-up",false,{"title":110,"titleTemplate":111,"icon":112,"path":113,"stem":114,"children":115,"page":108},"Directory Structure","%s · Nuxt Directory Structure","i-vscode-icons-default-folder","/docs/3.x/directory-structure","docs/3.x/2.directory-structure",[116,121,126,131,136,141,146,151,156,161,165,170,174,179,184,189,194,199,204,209,214,218,223,228,232,236,241],{"title":117,"path":118,"stem":119,"titleTemplate":6,"icon":120},".nuxt","/docs/3.x/directory-structure/nuxt","docs/3.x/2.directory-structure/0.nuxt","i-vscode-icons-folder-type-temp",{"title":122,"path":123,"stem":124,"titleTemplate":6,"icon":125},".output","/docs/3.x/directory-structure/output","docs/3.x/2.directory-structure/0.output","i-vscode-icons-folder-type-package",{"title":127,"path":128,"stem":129,"titleTemplate":6,"icon":130},"assets","/docs/3.x/directory-structure/assets","docs/3.x/2.directory-structure/1.assets","i-vscode-icons-folder-type-asset",{"title":132,"path":133,"stem":134,"titleTemplate":6,"icon":135},"components","/docs/3.x/directory-structure/components","docs/3.x/2.directory-structure/1.components","i-vscode-icons-folder-type-component",{"title":137,"path":138,"stem":139,"titleTemplate":6,"icon":140},"composables","/docs/3.x/directory-structure/composables","docs/3.x/2.directory-structure/1.composables","i-vscode-icons-folder-type-src",{"title":142,"path":143,"stem":144,"titleTemplate":6,"icon":145},"content","/docs/3.x/directory-structure/content","docs/3.x/2.directory-structure/1.content","i-vscode-icons-folder-type-log",{"title":147,"path":148,"stem":149,"titleTemplate":6,"icon":150},"layers","/docs/3.x/directory-structure/layers","docs/3.x/2.directory-structure/1.layers","i-vscode-icons-folder-type-nuxt",{"title":152,"path":153,"stem":154,"titleTemplate":6,"icon":155},"layouts","/docs/3.x/directory-structure/layouts","docs/3.x/2.directory-structure/1.layouts","i-vscode-icons-folder-type-view",{"title":157,"path":158,"stem":159,"titleTemplate":6,"icon":160},"middleware","/docs/3.x/directory-structure/middleware","docs/3.x/2.directory-structure/1.middleware","i-vscode-icons-folder-type-middleware",{"title":162,"path":163,"stem":164,"titleTemplate":6,"icon":150},"modules","/docs/3.x/directory-structure/modules","docs/3.x/2.directory-structure/1.modules",{"title":166,"path":167,"stem":168,"titleTemplate":6,"icon":169},"node_modules","/docs/3.x/directory-structure/node_modules","docs/3.x/2.directory-structure/1.node_modules","i-vscode-icons-folder-type-node",{"title":171,"path":172,"stem":173,"titleTemplate":6,"icon":155},"pages","/docs/3.x/directory-structure/pages","docs/3.x/2.directory-structure/1.pages",{"title":175,"path":176,"stem":177,"titleTemplate":6,"icon":178},"plugins","/docs/3.x/directory-structure/plugins","docs/3.x/2.directory-structure/1.plugins","i-vscode-icons-folder-type-plugin",{"title":180,"path":181,"stem":182,"titleTemplate":6,"icon":183},"public","/docs/3.x/directory-structure/public","docs/3.x/2.directory-structure/1.public","i-vscode-icons-folder-type-public",{"title":185,"path":186,"stem":187,"titleTemplate":6,"icon":188},"server","/docs/3.x/directory-structure/server","docs/3.x/2.directory-structure/1.server","i-vscode-icons-folder-type-server",{"title":190,"path":191,"stem":192,"titleTemplate":6,"icon":193},"shared","/docs/3.x/directory-structure/shared","docs/3.x/2.directory-structure/1.shared","i-vscode-icons-folder-type-shared",{"title":195,"path":196,"stem":197,"titleTemplate":6,"icon":198},"utils","/docs/3.x/directory-structure/utils","docs/3.x/2.directory-structure/1.utils","i-vscode-icons-folder-type-tools",{"title":200,"path":201,"stem":202,"titleTemplate":6,"icon":203},".env","/docs/3.x/directory-structure/env","docs/3.x/2.directory-structure/2.env","i-vscode-icons-file-type-dotenv",{"title":205,"path":206,"stem":207,"titleTemplate":6,"icon":208},".gitignore","/docs/3.x/directory-structure/gitignore","docs/3.x/2.directory-structure/2.gitignore","i-vscode-icons-file-type-git",{"title":210,"path":211,"stem":212,"titleTemplate":6,"icon":213},".nuxtignore","/docs/3.x/directory-structure/nuxtignore","docs/3.x/2.directory-structure/2.nuxtignore","i-vscode-icons-file-type-nuxt",{"title":215,"path":216,"stem":217,"titleTemplate":6,"icon":213},".nuxtrc","/docs/3.x/directory-structure/nuxtrc","docs/3.x/2.directory-structure/2.nuxtrc",{"title":219,"path":220,"stem":221,"titleTemplate":6,"icon":222},"app.vue","/docs/3.x/directory-structure/app","docs/3.x/2.directory-structure/3.app","i-vscode-icons-file-type-vue",{"title":224,"path":225,"stem":226,"titleTemplate":6,"icon":227},"app.config.ts","/docs/3.x/directory-structure/app-config","docs/3.x/2.directory-structure/3.app-config","i-vscode-icons-file-type-light-config",{"title":229,"path":230,"stem":231,"titleTemplate":6,"icon":222},"error.vue","/docs/3.x/directory-structure/error","docs/3.x/2.directory-structure/3.error",{"title":233,"path":234,"stem":235,"titleTemplate":6,"icon":213},"nuxt.config.ts","/docs/3.x/directory-structure/nuxt-config","docs/3.x/2.directory-structure/3.nuxt-config",{"title":237,"path":238,"stem":239,"titleTemplate":6,"icon":240},"package.json","/docs/3.x/directory-structure/package","docs/3.x/2.directory-structure/3.package","i-vscode-icons-file-type-npm",{"title":242,"path":243,"stem":244,"titleTemplate":6,"icon":245},"tsconfig.json","/docs/3.x/directory-structure/tsconfig","docs/3.x/2.directory-structure/3.tsconfig","i-vscode-icons-file-type-tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":249,"stem":250,"children":251,"page":108},"Guide","i-lucide-book-open","/docs/3.x/guide","docs/3.x/3.guide",[252,287,306,321,356,379],{"title":253,"titleTemplate":254,"icon":255,"path":256,"stem":257,"children":258,"page":108},"Key Concepts","%s · Nuxt Concepts","i-lucide-medal","/docs/3.x/guide/concepts","docs/3.x/3.guide/1.concepts",[259,263,267,271,275,279,283],{"title":260,"path":261,"stem":262,"titleTemplate":6},"Rendering Modes","/docs/3.x/guide/concepts/rendering","docs/3.x/3.guide/1.concepts/1.rendering",{"title":264,"path":265,"stem":266,"titleTemplate":6},"Nuxt Lifecycle","/docs/3.x/guide/concepts/nuxt-lifecycle","docs/3.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":269,"stem":270,"titleTemplate":6},"Auto-imports","/docs/3.x/guide/concepts/auto-imports","docs/3.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":273,"stem":274,"titleTemplate":6},"Server Engine","/docs/3.x/guide/concepts/server-engine","docs/3.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":277,"stem":278,"titleTemplate":6},"Modules","/docs/3.x/guide/concepts/modules","docs/3.x/3.guide/1.concepts/5.modules",{"title":280,"path":281,"stem":282,"titleTemplate":6},"TypeScript","/docs/3.x/guide/concepts/typescript","docs/3.x/3.guide/1.concepts/8.typescript",{"title":284,"path":285,"stem":286,"titleTemplate":6},"Code Style","/docs/3.x/guide/concepts/code-style","docs/3.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":291,"stem":292,"children":293,"page":108},"Best Practices","%s · Best Practices","i-lucide-square-check","/docs/3.x/guide/best-practices","docs/3.x/3.guide/2.best-practices",[294,298,302],{"title":295,"path":296,"stem":297,"titleTemplate":6},"Nuxt and hydration","/docs/3.x/guide/best-practices/hydration","docs/3.x/3.guide/2.best-practices/hydration",{"title":299,"path":300,"stem":301,"titleTemplate":6},"Nuxt Performance","/docs/3.x/guide/best-practices/performance","docs/3.x/3.guide/2.best-practices/performance",{"title":303,"path":304,"stem":305,"titleTemplate":6},"Nuxt Plugins","/docs/3.x/guide/best-practices/plugins","docs/3.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":310,"stem":311,"children":312,"page":108},"Working with AI","Working with AI: %s","i-lucide-bot","/docs/3.x/guide/ai","docs/3.x/3.guide/3.ai",[313,317],{"title":314,"path":315,"stem":316,"titleTemplate":6},"MCP Server","/docs/3.x/guide/ai/mcp","docs/3.x/3.guide/3.ai/1.mcp",{"title":318,"path":319,"stem":320,"titleTemplate":6},"LLMs.txt","/docs/3.x/guide/ai/llms-txt","docs/3.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":325,"stem":326,"children":327,"page":108},"Module Author Guide","%s · Nuxt Modules Author Guide","i-lucide-box","/docs/3.x/guide/modules","docs/3.x/3.guide/4.modules",[328,332,336,340,344,348,352],{"title":329,"path":330,"stem":331,"titleTemplate":6},"Create Your First Module","/docs/3.x/guide/modules/getting-started","docs/3.x/3.guide/4.modules/1.getting-started",{"title":333,"path":334,"stem":335,"titleTemplate":6},"Understand Module Structure","/docs/3.x/guide/modules/module-anatomy","docs/3.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":338,"stem":339,"titleTemplate":6},"Add Plugins, Components & More","/docs/3.x/guide/modules/recipes-basics","docs/3.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":342,"stem":343,"titleTemplate":6},"Use Hooks & Extend Types","/docs/3.x/guide/modules/recipes-advanced","docs/3.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":346,"stem":347,"titleTemplate":6},"Test Your Module","/docs/3.x/guide/modules/testing","docs/3.x/3.guide/4.modules/5.testing",{"title":349,"path":350,"stem":351,"titleTemplate":6},"Follow Best Practices","/docs/3.x/guide/modules/best-practices","docs/3.x/3.guide/4.modules/6.best-practices",{"title":353,"path":354,"stem":355,"titleTemplate":6},"Publish & Share Your Module","/docs/3.x/guide/modules/ecosystem","docs/3.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":360,"stem":361,"children":362,"page":108},"Recipes","%s · Recipes","i-lucide-cooking-pot","/docs/3.x/guide/recipes","docs/3.x/3.guide/5.recipes",[363,367,371,375],{"title":364,"path":365,"stem":366,"titleTemplate":6},"Custom Routing","/docs/3.x/guide/recipes/custom-routing","docs/3.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":369,"stem":370,"titleTemplate":6},"Vite Plugins","/docs/3.x/guide/recipes/vite-plugin","docs/3.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":373,"stem":374,"titleTemplate":6},"Custom useFetch","/docs/3.x/guide/recipes/custom-usefetch","docs/3.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":377,"stem":378,"titleTemplate":6},"Sessions and Authentication","/docs/3.x/guide/recipes/sessions-and-authentication","docs/3.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":383,"stem":384,"children":385,"page":108},"Going Further","%s · Nuxt Advanced","i-lucide-star","/docs/3.x/guide/going-further","docs/3.x/3.guide/6.going-further",[386,390,394,398,402,406,410,414,418,422],{"title":387,"path":388,"stem":389,"titleTemplate":6},"Custom Events","/docs/3.x/guide/going-further/events","docs/3.x/3.guide/6.going-further/1.events",{"title":391,"path":392,"stem":393,"titleTemplate":6},"Experimental Features","/docs/3.x/guide/going-further/experimental-features","docs/3.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":396,"stem":397,"titleTemplate":6},"Features","/docs/3.x/guide/going-further/features","docs/3.x/3.guide/6.going-further/1.features",{"title":399,"path":400,"stem":401,"titleTemplate":6},"Runtime Config","/docs/3.x/guide/going-further/runtime-config","docs/3.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":404,"stem":405,"titleTemplate":6},"Nightly Release Channel","/docs/3.x/guide/going-further/nightly-release-channel","docs/3.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":408,"stem":409,"titleTemplate":6},"Lifecycle Hooks","/docs/3.x/guide/going-further/hooks","docs/3.x/3.guide/6.going-further/2.hooks",{"title":411,"path":412,"stem":413,"titleTemplate":6},"Nuxt Kit","/docs/3.x/guide/going-further/kit","docs/3.x/3.guide/6.going-further/4.kit",{"title":415,"path":416,"stem":417,"titleTemplate":6},"NuxtApp","/docs/3.x/guide/going-further/nuxt-app","docs/3.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":420,"stem":421,"titleTemplate":6},"Authoring Nuxt Layers","/docs/3.x/guide/going-further/layers","docs/3.x/3.guide/6.going-further/7.layers",{"title":423,"path":424,"stem":425,"titleTemplate":6},"Debugging","/docs/3.x/guide/going-further/debugging","docs/3.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":430,"stem":431,"children":432,"page":108},"API","%s · Nuxt API","i-lucide-code-xml","/docs/3.x/api","docs/3.x/4.api",[433,499,622,745,816,889,902],{"title":434,"titleTemplate":435,"icon":324,"path":436,"stem":437,"children":438,"page":108},"Components","%s · Nuxt Components","/docs/3.x/api/components","docs/3.x/4.api/1.components",[439,443,447,451,455,459,463,467,471,475,479,483,487,491,495],{"title":440,"path":441,"stem":442,"titleTemplate":6},"\u003CClientOnly>","/docs/3.x/api/components/client-only","docs/3.x/4.api/1.components/1.client-only",{"title":444,"path":445,"stem":446,"titleTemplate":6},"\u003CDevOnly>","/docs/3.x/api/components/dev-only","docs/3.x/4.api/1.components/1.dev-only",{"title":448,"path":449,"stem":450,"titleTemplate":6},"\u003CNuxtClientFallback>","/docs/3.x/api/components/nuxt-client-fallback","docs/3.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":453,"stem":454,"titleTemplate":6},"\u003CNuxtPicture>","/docs/3.x/api/components/nuxt-picture","docs/3.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":457,"stem":458,"titleTemplate":6},"\u003CTeleport>","/docs/3.x/api/components/teleports","docs/3.x/4.api/1.components/11.teleports",{"title":460,"path":461,"stem":462,"titleTemplate":6},"\u003CNuxtRouteAnnouncer>","/docs/3.x/api/components/nuxt-route-announcer","docs/3.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":465,"stem":466,"titleTemplate":6},"\u003CNuxtTime>","/docs/3.x/api/components/nuxt-time","docs/3.x/4.api/1.components/13.nuxt-time",{"title":468,"path":469,"stem":470,"titleTemplate":6},"\u003CNuxtPage>","/docs/3.x/api/components/nuxt-page","docs/3.x/4.api/1.components/2.nuxt-page",{"title":472,"path":473,"stem":474,"titleTemplate":6},"\u003CNuxtLayout>","/docs/3.x/api/components/nuxt-layout","docs/3.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":477,"stem":478,"titleTemplate":6},"\u003CNuxtLink>","/docs/3.x/api/components/nuxt-link","docs/3.x/4.api/1.components/4.nuxt-link",{"title":480,"path":481,"stem":482,"titleTemplate":6},"\u003CNuxtLoadingIndicator>","/docs/3.x/api/components/nuxt-loading-indicator","docs/3.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":485,"stem":486,"titleTemplate":6},"\u003CNuxtErrorBoundary>","/docs/3.x/api/components/nuxt-error-boundary","docs/3.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":489,"stem":490,"titleTemplate":6},"\u003CNuxtWelcome>","/docs/3.x/api/components/nuxt-welcome","docs/3.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":493,"stem":494,"titleTemplate":6},"\u003CNuxtIsland>","/docs/3.x/api/components/nuxt-island","docs/3.x/4.api/1.components/8.nuxt-island",{"title":496,"path":497,"stem":498,"titleTemplate":6},"\u003CNuxtImg>","/docs/3.x/api/components/nuxt-img","docs/3.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":503,"stem":504,"children":505,"page":108},"Composables","%s · Nuxt Composables","i-lucide-arrow-left-right","/docs/3.x/api/composables","docs/3.x/4.api/2.composables",[506,510,514,518,522,526,530,534,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618],{"title":507,"path":508,"stem":509,"titleTemplate":6},"onPrehydrate","/docs/3.x/api/composables/on-prehydrate","docs/3.x/4.api/2.composables/on-prehydrate",{"title":511,"path":512,"stem":513,"titleTemplate":6},"useAppConfig","/docs/3.x/api/composables/use-app-config","docs/3.x/4.api/2.composables/use-app-config",{"title":515,"path":516,"stem":517,"titleTemplate":6},"useAsyncData","/docs/3.x/api/composables/use-async-data","docs/3.x/4.api/2.composables/use-async-data",{"title":519,"path":520,"stem":521,"titleTemplate":6},"useCookie","/docs/3.x/api/composables/use-cookie","docs/3.x/4.api/2.composables/use-cookie",{"title":523,"path":524,"stem":525,"titleTemplate":6},"useError","/docs/3.x/api/composables/use-error","docs/3.x/4.api/2.composables/use-error",{"title":527,"path":528,"stem":529,"titleTemplate":6},"useFetch","/docs/3.x/api/composables/use-fetch","docs/3.x/4.api/2.composables/use-fetch",{"title":531,"path":532,"stem":533,"titleTemplate":6},"useHead","/docs/3.x/api/composables/use-head","docs/3.x/4.api/2.composables/use-head",{"title":535,"path":536,"stem":537,"titleTemplate":6},"useHeadSafe","/docs/3.x/api/composables/use-head-safe","docs/3.x/4.api/2.composables/use-head-safe",{"title":539,"path":540,"stem":541,"titleTemplate":6},"useHydration","/docs/3.x/api/composables/use-hydration","docs/3.x/4.api/2.composables/use-hydration",{"title":543,"path":544,"stem":545,"titleTemplate":6},"useLazyAsyncData","/docs/3.x/api/composables/use-lazy-async-data","docs/3.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":548,"stem":549,"titleTemplate":6},"useLazyFetch","/docs/3.x/api/composables/use-lazy-fetch","docs/3.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":552,"stem":553,"titleTemplate":6},"useLoadingIndicator","/docs/3.x/api/composables/use-loading-indicator","docs/3.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":556,"stem":557,"titleTemplate":6},"useNuxtApp","/docs/3.x/api/composables/use-nuxt-app","docs/3.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":560,"stem":561,"titleTemplate":6},"useNuxtData","/docs/3.x/api/composables/use-nuxt-data","docs/3.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":564,"stem":565,"titleTemplate":6},"usePreviewMode","/docs/3.x/api/composables/use-preview-mode","docs/3.x/4.api/2.composables/use-preview-mode",{"title":567,"path":568,"stem":569,"titleTemplate":6},"useRequestEvent","/docs/3.x/api/composables/use-request-event","docs/3.x/4.api/2.composables/use-request-event",{"title":571,"path":572,"stem":573,"titleTemplate":6},"useRequestFetch","/docs/3.x/api/composables/use-request-fetch","docs/3.x/4.api/2.composables/use-request-fetch",{"title":575,"path":576,"stem":577,"titleTemplate":6},"useRequestHeader","/docs/3.x/api/composables/use-request-header","docs/3.x/4.api/2.composables/use-request-header",{"title":579,"path":580,"stem":581,"titleTemplate":6},"useRequestHeaders","/docs/3.x/api/composables/use-request-headers","docs/3.x/4.api/2.composables/use-request-headers",{"title":583,"path":584,"stem":585,"titleTemplate":6},"useRequestURL","/docs/3.x/api/composables/use-request-url","docs/3.x/4.api/2.composables/use-request-url",{"title":587,"path":588,"stem":589,"titleTemplate":6},"useResponseHeader","/docs/3.x/api/composables/use-response-header","docs/3.x/4.api/2.composables/use-response-header",{"title":591,"path":592,"stem":593,"titleTemplate":6},"useRoute","/docs/3.x/api/composables/use-route","docs/3.x/4.api/2.composables/use-route",{"title":595,"path":596,"stem":597,"titleTemplate":6},"useRouteAnnouncer","/docs/3.x/api/composables/use-route-announcer","docs/3.x/4.api/2.composables/use-route-announcer",{"title":599,"path":600,"stem":601,"titleTemplate":6},"useRouter","/docs/3.x/api/composables/use-router","docs/3.x/4.api/2.composables/use-router",{"title":603,"path":604,"stem":605,"titleTemplate":6},"useRuntimeConfig","/docs/3.x/api/composables/use-runtime-config","docs/3.x/4.api/2.composables/use-runtime-config",{"title":607,"path":608,"stem":609,"titleTemplate":6},"useRuntimeHook","/docs/3.x/api/composables/use-runtime-hook","docs/3.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":612,"stem":613,"titleTemplate":6},"useSeoMeta","/docs/3.x/api/composables/use-seo-meta","docs/3.x/4.api/2.composables/use-seo-meta",{"title":615,"path":616,"stem":617,"titleTemplate":6},"useServerSeoMeta","/docs/3.x/api/composables/use-server-seo-meta","docs/3.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":620,"stem":621,"titleTemplate":6},"useState","/docs/3.x/api/composables/use-state","docs/3.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":626,"stem":627,"children":628,"page":108},"Utils","%s · Nuxt Utils","i-lucide-square-function","/docs/3.x/api/utils","docs/3.x/4.api/3.utils",[629,633,637,641,645,649,653,657,661,665,669,673,677,681,685,689,693,697,701,705,709,713,717,721,725,729,733,737,741],{"title":630,"path":631,"stem":632,"titleTemplate":6},"$fetch","/docs/3.x/api/utils/dollarfetch","docs/3.x/4.api/3.utils/$fetch",{"title":634,"path":635,"stem":636,"titleTemplate":6},"abortNavigation","/docs/3.x/api/utils/abort-navigation","docs/3.x/4.api/3.utils/abort-navigation",{"title":638,"path":639,"stem":640,"titleTemplate":6},"addRouteMiddleware","/docs/3.x/api/utils/add-route-middleware","docs/3.x/4.api/3.utils/add-route-middleware",{"title":642,"path":643,"stem":644,"titleTemplate":6},"callOnce","/docs/3.x/api/utils/call-once","docs/3.x/4.api/3.utils/call-once",{"title":646,"path":647,"stem":648,"titleTemplate":6},"clearError","/docs/3.x/api/utils/clear-error","docs/3.x/4.api/3.utils/clear-error",{"title":650,"path":651,"stem":652,"titleTemplate":6},"clearNuxtData","/docs/3.x/api/utils/clear-nuxt-data","docs/3.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":655,"stem":656,"titleTemplate":6},"clearNuxtState","/docs/3.x/api/utils/clear-nuxt-state","docs/3.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":659,"stem":660,"titleTemplate":6},"createError","/docs/3.x/api/utils/create-error","docs/3.x/4.api/3.utils/create-error",{"title":662,"path":663,"stem":664,"titleTemplate":6},"defineLazyHydrationComponent","/docs/3.x/api/utils/define-lazy-hydration-component","docs/3.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":667,"stem":668,"titleTemplate":6},"defineNuxtComponent","/docs/3.x/api/utils/define-nuxt-component","docs/3.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":671,"stem":672,"titleTemplate":6},"defineNuxtPlugin","/docs/3.x/api/utils/define-nuxt-plugin","docs/3.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":675,"stem":676,"titleTemplate":6},"defineNuxtRouteMiddleware","/docs/3.x/api/utils/define-nuxt-route-middleware","docs/3.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":679,"stem":680,"titleTemplate":6},"definePageMeta","/docs/3.x/api/utils/define-page-meta","docs/3.x/4.api/3.utils/define-page-meta",{"title":682,"path":683,"stem":684,"titleTemplate":6},"defineRouteRules","/docs/3.x/api/utils/define-route-rules","docs/3.x/4.api/3.utils/define-route-rules",{"title":686,"path":687,"stem":688,"titleTemplate":6},"navigateTo","/docs/3.x/api/utils/navigate-to","docs/3.x/4.api/3.utils/navigate-to",{"title":690,"path":691,"stem":692,"titleTemplate":6},"onBeforeRouteLeave","/docs/3.x/api/utils/on-before-route-leave","docs/3.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":695,"stem":696,"titleTemplate":6},"onBeforeRouteUpdate","/docs/3.x/api/utils/on-before-route-update","docs/3.x/4.api/3.utils/on-before-route-update",{"title":698,"path":699,"stem":700,"titleTemplate":6},"onNuxtReady","/docs/3.x/api/utils/on-nuxt-ready","docs/3.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":703,"stem":704,"titleTemplate":6},"prefetchComponents","/docs/3.x/api/utils/prefetch-components","docs/3.x/4.api/3.utils/prefetch-components",{"title":706,"path":707,"stem":708,"titleTemplate":6},"preloadComponents","/docs/3.x/api/utils/preload-components","docs/3.x/4.api/3.utils/preload-components",{"title":710,"path":711,"stem":712,"titleTemplate":6},"preloadRouteComponents","/docs/3.x/api/utils/preload-route-components","docs/3.x/4.api/3.utils/preload-route-components",{"title":714,"path":715,"stem":716,"titleTemplate":6},"prerenderRoutes","/docs/3.x/api/utils/prerender-routes","docs/3.x/4.api/3.utils/prerender-routes",{"title":718,"path":719,"stem":720,"titleTemplate":6},"refreshCookie","/docs/3.x/api/utils/refresh-cookie","docs/3.x/4.api/3.utils/refresh-cookie",{"title":722,"path":723,"stem":724,"titleTemplate":6},"refreshNuxtData","/docs/3.x/api/utils/refresh-nuxt-data","docs/3.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":727,"stem":728,"titleTemplate":6},"reloadNuxtApp","/docs/3.x/api/utils/reload-nuxt-app","docs/3.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":731,"stem":732,"titleTemplate":6},"setPageLayout","/docs/3.x/api/utils/set-page-layout","docs/3.x/4.api/3.utils/set-page-layout",{"title":734,"path":735,"stem":736,"titleTemplate":6},"setResponseStatus","/docs/3.x/api/utils/set-response-status","docs/3.x/4.api/3.utils/set-response-status",{"title":738,"path":739,"stem":740,"titleTemplate":6},"showError","/docs/3.x/api/utils/show-error","docs/3.x/4.api/3.utils/show-error",{"title":742,"path":743,"stem":744,"titleTemplate":6},"updateAppConfig","/docs/3.x/api/utils/update-app-config","docs/3.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":749,"stem":750,"children":751,"page":108},"Commands","%s · Nuxt Commands","i-lucide-square-terminal","/docs/3.x/api/commands","docs/3.x/4.api/4.commands",[752,756,760,764,768,772,776,780,784,788,792,796,800,804,808,812],{"title":753,"path":754,"stem":755,"titleTemplate":6},"nuxt add","/docs/3.x/api/commands/add","docs/3.x/4.api/4.commands/add",{"title":757,"path":758,"stem":759,"titleTemplate":6},"nuxt analyze","/docs/3.x/api/commands/analyze","docs/3.x/4.api/4.commands/analyze",{"title":761,"path":762,"stem":763,"titleTemplate":6},"nuxt build","/docs/3.x/api/commands/build","docs/3.x/4.api/4.commands/build",{"title":765,"path":766,"stem":767,"titleTemplate":6},"nuxt build-module","/docs/3.x/api/commands/build-module","docs/3.x/4.api/4.commands/build-module",{"title":769,"path":770,"stem":771,"titleTemplate":6},"nuxt cleanup","/docs/3.x/api/commands/cleanup","docs/3.x/4.api/4.commands/cleanup",{"title":773,"path":774,"stem":775,"titleTemplate":6},"nuxt dev","/docs/3.x/api/commands/dev","docs/3.x/4.api/4.commands/dev",{"title":777,"path":778,"stem":779,"titleTemplate":6},"nuxt devtools","/docs/3.x/api/commands/devtools","docs/3.x/4.api/4.commands/devtools",{"title":781,"path":782,"stem":783,"titleTemplate":6},"nuxt generate","/docs/3.x/api/commands/generate","docs/3.x/4.api/4.commands/generate",{"title":785,"path":786,"stem":787,"titleTemplate":6},"nuxt info","/docs/3.x/api/commands/info","docs/3.x/4.api/4.commands/info",{"title":789,"path":790,"stem":791,"titleTemplate":6},"create nuxt","/docs/3.x/api/commands/init","docs/3.x/4.api/4.commands/init",{"title":793,"path":794,"stem":795,"titleTemplate":6},"nuxt module","/docs/3.x/api/commands/module","docs/3.x/4.api/4.commands/module",{"title":797,"path":798,"stem":799,"titleTemplate":6},"nuxt prepare","/docs/3.x/api/commands/prepare","docs/3.x/4.api/4.commands/prepare",{"title":801,"path":802,"stem":803,"titleTemplate":6},"nuxt preview","/docs/3.x/api/commands/preview","docs/3.x/4.api/4.commands/preview",{"title":805,"path":806,"stem":807,"titleTemplate":6},"nuxt test","/docs/3.x/api/commands/test","docs/3.x/4.api/4.commands/test",{"title":809,"path":810,"stem":811,"titleTemplate":6},"nuxt typecheck","/docs/3.x/api/commands/typecheck","docs/3.x/4.api/4.commands/typecheck",{"title":813,"path":814,"stem":815,"titleTemplate":6},"nuxt upgrade","/docs/3.x/api/commands/upgrade","docs/3.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":819,"stem":820,"children":821,"page":108},"%s · Nuxt Kit","i-lucide-package","/docs/3.x/api/kit","docs/3.x/4.api/5.kit",[822,825,828,832,836,840,844,848,852,855,859,863,866,869,873,877,881,885],{"title":276,"path":823,"stem":824,"titleTemplate":6},"/docs/3.x/api/kit/modules","docs/3.x/4.api/5.kit/1.modules",{"title":399,"path":826,"stem":827,"titleTemplate":6},"/docs/3.x/api/kit/runtime-config","docs/3.x/4.api/5.kit/10.runtime-config",{"title":829,"path":830,"stem":831,"titleTemplate":6},"Templates","/docs/3.x/api/kit/templates","docs/3.x/4.api/5.kit/10.templates",{"title":833,"path":834,"stem":835,"titleTemplate":6},"Nitro","/docs/3.x/api/kit/nitro","docs/3.x/4.api/5.kit/11.nitro",{"title":837,"path":838,"stem":839,"titleTemplate":6},"Resolving","/docs/3.x/api/kit/resolving","docs/3.x/4.api/5.kit/12.resolving",{"title":841,"path":842,"stem":843,"titleTemplate":6},"Logging","/docs/3.x/api/kit/logging","docs/3.x/4.api/5.kit/13.logging",{"title":845,"path":846,"stem":847,"titleTemplate":6},"Builder","/docs/3.x/api/kit/builder","docs/3.x/4.api/5.kit/14.builder",{"title":849,"path":850,"stem":851,"titleTemplate":6},"Examples","/docs/3.x/api/kit/examples","docs/3.x/4.api/5.kit/15.examples",{"title":84,"path":853,"stem":854,"titleTemplate":6},"/docs/3.x/api/kit/layers","docs/3.x/4.api/5.kit/16.layers",{"title":856,"path":857,"stem":858,"titleTemplate":6},"Programmatic Usage","/docs/3.x/api/kit/programmatic","docs/3.x/4.api/5.kit/2.programmatic",{"title":860,"path":861,"stem":862,"titleTemplate":6},"Compatibility","/docs/3.x/api/kit/compatibility","docs/3.x/4.api/5.kit/3.compatibility",{"title":268,"path":864,"stem":865,"titleTemplate":6},"/docs/3.x/api/kit/autoimports","docs/3.x/4.api/5.kit/4.autoimports",{"title":434,"path":867,"stem":868,"titleTemplate":6},"/docs/3.x/api/kit/components","docs/3.x/4.api/5.kit/5.components",{"title":870,"path":871,"stem":872,"titleTemplate":6},"Context","/docs/3.x/api/kit/context","docs/3.x/4.api/5.kit/6.context",{"title":874,"path":875,"stem":876,"titleTemplate":6},"Pages","/docs/3.x/api/kit/pages","docs/3.x/4.api/5.kit/7.pages",{"title":878,"path":879,"stem":880,"titleTemplate":6},"Layout","/docs/3.x/api/kit/layout","docs/3.x/4.api/5.kit/8.layout",{"title":882,"path":883,"stem":884,"titleTemplate":6},"Head","/docs/3.x/api/kit/head","docs/3.x/4.api/5.kit/9.head",{"title":886,"path":887,"stem":888,"titleTemplate":6},"Plugins","/docs/3.x/api/kit/plugins","docs/3.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":892,"stem":893,"children":894,"page":108},"Advanced","i-lucide-brain","/docs/3.x/api/advanced","docs/3.x/4.api/6.advanced",[895,898],{"title":407,"path":896,"stem":897,"titleTemplate":6},"/docs/3.x/api/advanced/hooks","docs/3.x/4.api/6.advanced/1.hooks",{"title":899,"path":900,"stem":901,"titleTemplate":6},"Import meta","/docs/3.x/api/advanced/import-meta","docs/3.x/4.api/6.advanced/2.import-meta",{"title":903,"path":904,"stem":905,"titleTemplate":906,"icon":32},"Nuxt Configuration","/docs/3.x/api/nuxt-config","docs/3.x/4.api/6.nuxt-config","%s",{"title":849,"titleTemplate":908,"icon":909,"path":910,"stem":911,"children":912,"page":108},"%s · Nuxt Examples","i-lucide-app-window-mac","/docs/3.x/examples","docs/3.x/4.examples",[913,917,939,954,990],{"title":914,"path":915,"stem":916,"titleTemplate":6},"Hello World","/docs/3.x/examples/hello-world","docs/3.x/4.examples/0.hello-world",{"title":395,"path":918,"stem":919,"children":920,"page":108},"/docs/3.x/examples/features","docs/3.x/4.examples/1.features",[921,925,928,931,935],{"title":922,"path":923,"stem":924,"titleTemplate":6},"Auto Imports","/docs/3.x/examples/features/auto-imports","docs/3.x/4.examples/1.features/1.auto-imports",{"title":64,"path":926,"stem":927,"titleTemplate":6},"/docs/3.x/examples/features/data-fetching","docs/3.x/4.examples/1.features/2.data-fetching",{"title":69,"path":929,"stem":930,"titleTemplate":6},"/docs/3.x/examples/features/state-management","docs/3.x/4.examples/1.features/3.state-management",{"title":932,"path":933,"stem":934,"titleTemplate":6},"Meta Tags","/docs/3.x/examples/features/meta-tags","docs/3.x/4.examples/1.features/4.meta-tags",{"title":936,"path":937,"stem":938,"titleTemplate":6},"Layouts","/docs/3.x/examples/features/layouts","docs/3.x/4.examples/1.features/5.layouts",{"title":49,"path":940,"stem":941,"children":942,"page":108},"/docs/3.x/examples/routing","docs/3.x/4.examples/2.routing",[943,947,950],{"title":944,"path":945,"stem":946,"titleTemplate":6},"Middleware","/docs/3.x/examples/routing/middleware","docs/3.x/4.examples/2.routing/middleware",{"title":874,"path":948,"stem":949,"titleTemplate":6},"/docs/3.x/examples/routing/pages","docs/3.x/4.examples/2.routing/pages",{"title":951,"path":952,"stem":953,"titleTemplate":6},"Universal Router","/docs/3.x/examples/routing/universal-router","docs/3.x/4.examples/2.routing/universal-router",{"title":890,"path":955,"stem":956,"children":957,"page":108},"/docs/3.x/examples/advanced","docs/3.x/4.examples/4.advanced",[958,961,964,968,972,976,980,983,986],{"title":84,"path":959,"stem":960,"titleTemplate":6},"/docs/3.x/examples/advanced/config-extends","docs/3.x/4.examples/4.advanced/config-extends",{"title":74,"path":962,"stem":963,"titleTemplate":6},"/docs/3.x/examples/advanced/error-handling","docs/3.x/4.examples/4.advanced/error-handling",{"title":965,"path":966,"stem":967,"titleTemplate":6},"JSX / TSX","/docs/3.x/examples/advanced/jsx","docs/3.x/4.examples/4.advanced/jsx",{"title":969,"path":970,"stem":971,"titleTemplate":6},"Locale","/docs/3.x/examples/advanced/locale","docs/3.x/4.examples/4.advanced/locale",{"title":973,"path":974,"stem":975,"titleTemplate":6},"Module Extend Pages","/docs/3.x/examples/advanced/module-extend-pages","docs/3.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":978,"stem":979,"titleTemplate":6},"Teleport","/docs/3.x/examples/advanced/teleport","docs/3.x/4.examples/4.advanced/teleport",{"title":99,"path":981,"stem":982,"titleTemplate":6},"/docs/3.x/examples/advanced/testing","docs/3.x/4.examples/4.advanced/testing",{"title":519,"path":984,"stem":985,"titleTemplate":6},"/docs/3.x/examples/advanced/use-cookie","docs/3.x/4.examples/4.advanced/use-cookie",{"title":987,"path":988,"stem":989,"titleTemplate":6},"Use Custom Fetch Composable","/docs/3.x/examples/advanced/use-custom-fetch-composable","docs/3.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":992,"stem":993,"children":994,"page":108},"Experimental","/docs/3.x/examples/experimental","docs/3.x/4.examples/7.experimental",[995],{"title":996,"path":997,"stem":998,"titleTemplate":6},"WASM","/docs/3.x/examples/experimental/wasm","docs/3.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1003,"stem":1004,"children":1005,"page":108},"Community","%s · Nuxt Community","i-lucide-messages-square","/docs/3.x/community","docs/3.x/5.community",[1006,1011,1016,1021,1026,1031],{"title":1007,"path":1008,"stem":1009,"titleTemplate":6,"icon":1010},"Getting Help","/docs/3.x/community/getting-help","docs/3.x/5.community/2.getting-help","i-lucide-life-buoy",{"title":1012,"path":1013,"stem":1014,"titleTemplate":6,"icon":1015},"Reporting Bugs","/docs/3.x/community/reporting-bugs","docs/3.x/5.community/3.reporting-bugs","i-lucide-bug",{"title":1017,"path":1018,"stem":1019,"titleTemplate":6,"icon":1020},"Contribution","/docs/3.x/community/contribution","docs/3.x/5.community/4.contribution","i-lucide-git-pull-request",{"title":1022,"path":1023,"stem":1024,"titleTemplate":6,"icon":1025},"Framework","/docs/3.x/community/framework-contribution","docs/3.x/5.community/5.framework-contribution","i-lucide-github",{"title":1027,"path":1028,"stem":1029,"titleTemplate":6,"icon":1030},"Roadmap","/docs/3.x/community/roadmap","docs/3.x/5.community/6.roadmap","i-lucide-map",{"title":1032,"path":1033,"stem":1034,"titleTemplate":6,"icon":1035},"Releases","/docs/3.x/community/changelog","docs/3.x/5.community/7.changelog","i-lucide-bell-dot",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1040,"stem":1041,"children":1042,"page":108},"Migrate to Nuxt Bridge","Migrate to Nuxt Bridge: %s","i-lucide-ship","/docs/3.x/bridge","docs/3.x/6.bridge",[1043,1047,1050,1053,1057,1061,1065,1068,1071,1074],{"title":1044,"path":1045,"stem":1046,"titleTemplate":6},"Overview","/docs/3.x/bridge/overview","docs/3.x/6.bridge/1.overview",{"title":29,"path":1048,"stem":1049,"titleTemplate":6},"/docs/3.x/bridge/configuration","docs/3.x/6.bridge/10.configuration",{"title":280,"path":1051,"stem":1052,"titleTemplate":6},"/docs/3.x/bridge/typescript","docs/3.x/6.bridge/2.typescript",{"title":1054,"path":1055,"stem":1056,"titleTemplate":6},"Legacy Composition API","/docs/3.x/bridge/bridge-composition-api","docs/3.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1059,"stem":1060,"titleTemplate":6},"Plugins and Middleware","/docs/3.x/bridge/plugins-and-middleware","docs/3.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1063,"stem":1064,"titleTemplate":6},"New Composition API","/docs/3.x/bridge/nuxt3-compatible-api","docs/3.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1066,"stem":1067,"titleTemplate":6},"/docs/3.x/bridge/meta","docs/3.x/6.bridge/6.meta",{"title":399,"path":1069,"stem":1070,"titleTemplate":6},"/docs/3.x/bridge/runtime-config","docs/3.x/6.bridge/7.runtime-config",{"title":833,"path":1072,"stem":1073,"titleTemplate":6},"/docs/3.x/bridge/nitro","docs/3.x/6.bridge/8.nitro",{"title":1075,"path":1076,"stem":1077,"titleTemplate":6},"Vite","/docs/3.x/bridge/vite","docs/3.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1081,"stem":1082,"children":1083,"page":108},"Migrate to Nuxt 3","Migrate to Nuxt 3: %s","/docs/3.x/migration","docs/3.x/7.migration",[1084,1087,1091,1094,1097,1100,1103,1106,1109,1113,1117],{"title":1044,"path":1085,"stem":1086,"titleTemplate":6},"/docs/3.x/migration/overview","docs/3.x/7.migration/1.overview",{"title":1088,"path":1089,"stem":1090,"titleTemplate":6},"Build Tooling","/docs/3.x/migration/bundling","docs/3.x/7.migration/10.bundling",{"title":79,"path":1092,"stem":1093,"titleTemplate":6},"/docs/3.x/migration/server","docs/3.x/7.migration/11.server",{"title":29,"path":1095,"stem":1096,"titleTemplate":6},"/docs/3.x/migration/configuration","docs/3.x/7.migration/2.configuration",{"title":276,"path":1098,"stem":1099,"titleTemplate":6},"/docs/3.x/migration/module-authors","docs/3.x/7.migration/20.module-authors",{"title":922,"path":1101,"stem":1102,"titleTemplate":6},"/docs/3.x/migration/auto-imports","docs/3.x/7.migration/3.auto-imports",{"title":932,"path":1104,"stem":1105,"titleTemplate":6},"/docs/3.x/migration/meta","docs/3.x/7.migration/4.meta",{"title":1058,"path":1107,"stem":1108,"titleTemplate":6},"/docs/3.x/migration/plugins-and-middleware","docs/3.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1111,"stem":1112,"titleTemplate":6},"Pages and Layouts","/docs/3.x/migration/pages-and-layouts","docs/3.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1115,"stem":1116,"titleTemplate":6},"Component Options","/docs/3.x/migration/component-options","docs/3.x/7.migration/7.component-options",{"title":399,"path":1118,"stem":1119,"titleTemplate":6},"/docs/3.x/migration/runtime-config","docs/3.x/7.migration/8.runtime-config",{"title":5,"titleTemplate":6,"icon":7,"path":1121,"stem":1122,"children":1123,"page":108},"/docs/4.x","docs/4.x",[1124,1182,1276,1403,1761,1838,1860,1894],{"title":12,"titleTemplate":13,"icon":14,"path":1125,"stem":1126,"children":1127,"page":108},"/docs/4.x/getting-started","docs/4.x/1.getting-started",[1128,1131,1134,1137,1140,1143,1146,1149,1152,1155,1158,1161,1164,1167,1170,1173,1176,1179],{"title":19,"path":1129,"stem":1130,"titleTemplate":6,"icon":22},"/docs/4.x/getting-started/introduction","docs/4.x/1.getting-started/01.introduction",{"title":24,"path":1132,"stem":1133,"titleTemplate":6,"icon":27},"/docs/4.x/getting-started/installation","docs/4.x/1.getting-started/02.installation",{"title":29,"path":1135,"stem":1136,"titleTemplate":6,"icon":32},"/docs/4.x/getting-started/configuration","docs/4.x/1.getting-started/03.configuration",{"title":34,"path":1138,"stem":1139,"titleTemplate":6,"icon":37},"/docs/4.x/getting-started/views","docs/4.x/1.getting-started/04.views",{"title":39,"path":1141,"stem":1142,"titleTemplate":6,"icon":42},"/docs/4.x/getting-started/assets","docs/4.x/1.getting-started/05.assets",{"title":44,"path":1144,"stem":1145,"titleTemplate":6,"icon":47},"/docs/4.x/getting-started/styling","docs/4.x/1.getting-started/06.styling",{"title":49,"path":1147,"stem":1148,"titleTemplate":6,"icon":52},"/docs/4.x/getting-started/routing","docs/4.x/1.getting-started/07.routing",{"title":54,"path":1150,"stem":1151,"titleTemplate":6,"icon":57},"/docs/4.x/getting-started/seo-meta","docs/4.x/1.getting-started/08.seo-meta",{"title":59,"path":1153,"stem":1154,"titleTemplate":6,"icon":62},"/docs/4.x/getting-started/transitions","docs/4.x/1.getting-started/09.transitions",{"title":64,"path":1156,"stem":1157,"titleTemplate":6,"icon":67},"/docs/4.x/getting-started/data-fetching","docs/4.x/1.getting-started/10.data-fetching",{"title":69,"path":1159,"stem":1160,"titleTemplate":6,"icon":72},"/docs/4.x/getting-started/state-management","docs/4.x/1.getting-started/11.state-management",{"title":74,"path":1162,"stem":1163,"titleTemplate":6,"icon":77},"/docs/4.x/getting-started/error-handling","docs/4.x/1.getting-started/12.error-handling",{"title":79,"path":1165,"stem":1166,"titleTemplate":6,"icon":82},"/docs/4.x/getting-started/server","docs/4.x/1.getting-started/13.server",{"title":84,"path":1168,"stem":1169,"titleTemplate":6,"icon":87},"/docs/4.x/getting-started/layers","docs/4.x/1.getting-started/14.layers",{"title":89,"path":1171,"stem":1172,"titleTemplate":6,"icon":92},"/docs/4.x/getting-started/prerendering","docs/4.x/1.getting-started/15.prerendering",{"title":94,"path":1174,"stem":1175,"titleTemplate":6,"icon":97},"/docs/4.x/getting-started/deployment","docs/4.x/1.getting-started/16.deployment",{"title":99,"path":1177,"stem":1178,"titleTemplate":6,"icon":102},"/docs/4.x/getting-started/testing","docs/4.x/1.getting-started/17.testing",{"title":104,"path":1180,"stem":1181,"titleTemplate":6,"icon":107},"/docs/4.x/getting-started/upgrade","docs/4.x/1.getting-started/18.upgrade",{"title":110,"titleTemplate":111,"icon":112,"path":1183,"stem":1184,"children":1185,"page":108},"/docs/4.x/directory-structure","docs/4.x/2.directory-structure",[1186,1189,1192,1234,1237,1240,1243,1246,1249,1252,1255,1258,1261,1264,1267,1270,1273],{"title":117,"path":1187,"stem":1188,"titleTemplate":6,"icon":120},"/docs/4.x/directory-structure/nuxt","docs/4.x/2.directory-structure/0.nuxt",{"title":122,"path":1190,"stem":1191,"titleTemplate":6,"icon":125},"/docs/4.x/directory-structure/output","docs/4.x/2.directory-structure/0.output",{"title":1193,"titleTemplate":111,"head":1194,"defaultOpen":1196,"icon":1197,"path":1198,"stem":1199,"children":1200,"page":108},"app",{"title":1195},"app/",true,"i-vscode-icons-folder-type-app","/docs/4.x/directory-structure/app","docs/4.x/2.directory-structure/1.app",[1201,1204,1207,1210,1213,1216,1219,1222,1225,1228,1231],{"title":127,"path":1202,"stem":1203,"titleTemplate":6,"icon":130},"/docs/4.x/directory-structure/app/assets","docs/4.x/2.directory-structure/1.app/1.assets",{"title":132,"path":1205,"stem":1206,"titleTemplate":6,"icon":135},"/docs/4.x/directory-structure/app/components","docs/4.x/2.directory-structure/1.app/1.components",{"title":137,"path":1208,"stem":1209,"titleTemplate":6,"icon":140},"/docs/4.x/directory-structure/app/composables","docs/4.x/2.directory-structure/1.app/1.composables",{"title":152,"path":1211,"stem":1212,"titleTemplate":6,"icon":155},"/docs/4.x/directory-structure/app/layouts","docs/4.x/2.directory-structure/1.app/1.layouts",{"title":157,"path":1214,"stem":1215,"titleTemplate":6,"icon":160},"/docs/4.x/directory-structure/app/middleware","docs/4.x/2.directory-structure/1.app/1.middleware",{"title":171,"path":1217,"stem":1218,"titleTemplate":6,"icon":155},"/docs/4.x/directory-structure/app/pages","docs/4.x/2.directory-structure/1.app/1.pages",{"title":175,"path":1220,"stem":1221,"titleTemplate":6,"icon":178},"/docs/4.x/directory-structure/app/plugins","docs/4.x/2.directory-structure/1.app/1.plugins",{"title":195,"path":1223,"stem":1224,"titleTemplate":6,"icon":198},"/docs/4.x/directory-structure/app/utils","docs/4.x/2.directory-structure/1.app/1.utils",{"title":219,"path":1226,"stem":1227,"titleTemplate":6,"icon":222},"/docs/4.x/directory-structure/app/app","docs/4.x/2.directory-structure/1.app/3.app",{"title":224,"path":1229,"stem":1230,"titleTemplate":6,"icon":227},"/docs/4.x/directory-structure/app/app-config","docs/4.x/2.directory-structure/1.app/3.app-config",{"title":229,"path":1232,"stem":1233,"titleTemplate":6,"icon":222},"/docs/4.x/directory-structure/app/error","docs/4.x/2.directory-structure/1.app/3.error",{"title":142,"path":1235,"stem":1236,"titleTemplate":6,"icon":145},"/docs/4.x/directory-structure/content","docs/4.x/2.directory-structure/1.content",{"title":147,"path":1238,"stem":1239,"titleTemplate":6,"icon":150},"/docs/4.x/directory-structure/layers","docs/4.x/2.directory-structure/1.layers",{"title":162,"path":1241,"stem":1242,"titleTemplate":6,"icon":150},"/docs/4.x/directory-structure/modules","docs/4.x/2.directory-structure/1.modules",{"title":166,"path":1244,"stem":1245,"titleTemplate":6,"icon":169},"/docs/4.x/directory-structure/node_modules","docs/4.x/2.directory-structure/1.node_modules",{"title":180,"path":1247,"stem":1248,"titleTemplate":6,"icon":183},"/docs/4.x/directory-structure/public","docs/4.x/2.directory-structure/1.public",{"title":185,"path":1250,"stem":1251,"titleTemplate":6,"icon":188},"/docs/4.x/directory-structure/server","docs/4.x/2.directory-structure/1.server",{"title":190,"path":1253,"stem":1254,"titleTemplate":6,"icon":193},"/docs/4.x/directory-structure/shared","docs/4.x/2.directory-structure/1.shared",{"title":200,"path":1256,"stem":1257,"titleTemplate":6,"icon":203},"/docs/4.x/directory-structure/env","docs/4.x/2.directory-structure/2.env",{"title":205,"path":1259,"stem":1260,"titleTemplate":6,"icon":208},"/docs/4.x/directory-structure/gitignore","docs/4.x/2.directory-structure/2.gitignore",{"title":210,"path":1262,"stem":1263,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxtignore","docs/4.x/2.directory-structure/2.nuxtignore",{"title":215,"path":1265,"stem":1266,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxtrc","docs/4.x/2.directory-structure/2.nuxtrc",{"title":233,"path":1268,"stem":1269,"titleTemplate":6,"icon":213},"/docs/4.x/directory-structure/nuxt-config","docs/4.x/2.directory-structure/3.nuxt-config",{"title":237,"path":1271,"stem":1272,"titleTemplate":6,"icon":240},"/docs/4.x/directory-structure/package","docs/4.x/2.directory-structure/3.package",{"title":242,"path":1274,"stem":1275,"titleTemplate":6,"icon":245},"/docs/4.x/directory-structure/tsconfig","docs/4.x/2.directory-structure/3.tsconfig",{"title":247,"titleTemplate":6,"icon":248,"path":1277,"stem":1278,"children":1279,"page":108},"/docs/4.x/guide","docs/4.x/3.guide",[1280,1305,1318,1328,1353,1369],{"title":253,"titleTemplate":254,"icon":255,"path":1281,"stem":1282,"children":1283,"page":108},"/docs/4.x/guide/concepts","docs/4.x/3.guide/1.concepts",[1284,1287,1290,1293,1296,1299,1302],{"title":260,"path":1285,"stem":1286,"titleTemplate":6},"/docs/4.x/guide/concepts/rendering","docs/4.x/3.guide/1.concepts/1.rendering",{"title":264,"path":1288,"stem":1289,"titleTemplate":6},"/docs/4.x/guide/concepts/nuxt-lifecycle","docs/4.x/3.guide/1.concepts/2.nuxt-lifecycle",{"title":268,"path":1291,"stem":1292,"titleTemplate":6},"/docs/4.x/guide/concepts/auto-imports","docs/4.x/3.guide/1.concepts/3.auto-imports",{"title":272,"path":1294,"stem":1295,"titleTemplate":6},"/docs/4.x/guide/concepts/server-engine","docs/4.x/3.guide/1.concepts/4.server-engine",{"title":276,"path":1297,"stem":1298,"titleTemplate":6},"/docs/4.x/guide/concepts/modules","docs/4.x/3.guide/1.concepts/5.modules",{"title":280,"path":1300,"stem":1301,"titleTemplate":6},"/docs/4.x/guide/concepts/typescript","docs/4.x/3.guide/1.concepts/8.typescript",{"title":284,"path":1303,"stem":1304,"titleTemplate":6},"/docs/4.x/guide/concepts/code-style","docs/4.x/3.guide/1.concepts/9.code-style",{"title":288,"titleTemplate":289,"icon":290,"path":1306,"stem":1307,"children":1308,"page":108},"/docs/4.x/guide/best-practices","docs/4.x/3.guide/2.best-practices",[1309,1312,1315],{"title":295,"path":1310,"stem":1311,"titleTemplate":6},"/docs/4.x/guide/best-practices/hydration","docs/4.x/3.guide/2.best-practices/hydration",{"title":299,"path":1313,"stem":1314,"titleTemplate":6},"/docs/4.x/guide/best-practices/performance","docs/4.x/3.guide/2.best-practices/performance",{"title":303,"path":1316,"stem":1317,"titleTemplate":6},"/docs/4.x/guide/best-practices/plugins","docs/4.x/3.guide/2.best-practices/plugins",{"title":307,"titleTemplate":308,"icon":309,"path":1319,"stem":1320,"children":1321,"page":108},"/docs/4.x/guide/ai","docs/4.x/3.guide/3.ai",[1322,1325],{"title":314,"path":1323,"stem":1324,"titleTemplate":6},"/docs/4.x/guide/ai/mcp","docs/4.x/3.guide/3.ai/1.mcp",{"title":318,"path":1326,"stem":1327,"titleTemplate":6},"/docs/4.x/guide/ai/llms-txt","docs/4.x/3.guide/3.ai/2.llms-txt",{"title":322,"titleTemplate":323,"icon":324,"path":1329,"stem":1330,"children":1331,"page":108},"/docs/4.x/guide/modules","docs/4.x/3.guide/4.modules",[1332,1335,1338,1341,1344,1347,1350],{"title":329,"path":1333,"stem":1334,"titleTemplate":6},"/docs/4.x/guide/modules/getting-started","docs/4.x/3.guide/4.modules/1.getting-started",{"title":333,"path":1336,"stem":1337,"titleTemplate":6},"/docs/4.x/guide/modules/module-anatomy","docs/4.x/3.guide/4.modules/2.module-anatomy",{"title":337,"path":1339,"stem":1340,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-basics","docs/4.x/3.guide/4.modules/3.recipes-basics",{"title":341,"path":1342,"stem":1343,"titleTemplate":6},"/docs/4.x/guide/modules/recipes-advanced","docs/4.x/3.guide/4.modules/4.recipes-advanced",{"title":345,"path":1345,"stem":1346,"titleTemplate":6},"/docs/4.x/guide/modules/testing","docs/4.x/3.guide/4.modules/5.testing",{"title":349,"path":1348,"stem":1349,"titleTemplate":6},"/docs/4.x/guide/modules/best-practices","docs/4.x/3.guide/4.modules/6.best-practices",{"title":353,"path":1351,"stem":1352,"titleTemplate":6},"/docs/4.x/guide/modules/ecosystem","docs/4.x/3.guide/4.modules/7.ecosystem",{"title":357,"titleTemplate":358,"icon":359,"path":1354,"stem":1355,"children":1356,"page":108},"/docs/4.x/guide/recipes","docs/4.x/3.guide/5.recipes",[1357,1360,1363,1366],{"title":364,"path":1358,"stem":1359,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-routing","docs/4.x/3.guide/5.recipes/1.custom-routing",{"title":368,"path":1361,"stem":1362,"titleTemplate":6},"/docs/4.x/guide/recipes/vite-plugin","docs/4.x/3.guide/5.recipes/2.vite-plugin",{"title":372,"path":1364,"stem":1365,"titleTemplate":6},"/docs/4.x/guide/recipes/custom-usefetch","docs/4.x/3.guide/5.recipes/3.custom-usefetch",{"title":376,"path":1367,"stem":1368,"titleTemplate":6},"/docs/4.x/guide/recipes/sessions-and-authentication","docs/4.x/3.guide/5.recipes/4.sessions-and-authentication",{"title":380,"titleTemplate":381,"icon":382,"path":1370,"stem":1371,"children":1372,"page":108},"/docs/4.x/guide/going-further","docs/4.x/3.guide/6.going-further",[1373,1376,1379,1382,1385,1388,1391,1394,1397,1400],{"title":387,"path":1374,"stem":1375,"titleTemplate":6},"/docs/4.x/guide/going-further/events","docs/4.x/3.guide/6.going-further/1.events",{"title":391,"path":1377,"stem":1378,"titleTemplate":6},"/docs/4.x/guide/going-further/experimental-features","docs/4.x/3.guide/6.going-further/1.experimental-features",{"title":395,"path":1380,"stem":1381,"titleTemplate":6},"/docs/4.x/guide/going-further/features","docs/4.x/3.guide/6.going-further/1.features",{"title":399,"path":1383,"stem":1384,"titleTemplate":6},"/docs/4.x/guide/going-further/runtime-config","docs/4.x/3.guide/6.going-further/10.runtime-config",{"title":403,"path":1386,"stem":1387,"titleTemplate":6},"/docs/4.x/guide/going-further/nightly-release-channel","docs/4.x/3.guide/6.going-further/11.nightly-release-channel",{"title":407,"path":1389,"stem":1390,"titleTemplate":6},"/docs/4.x/guide/going-further/hooks","docs/4.x/3.guide/6.going-further/2.hooks",{"title":411,"path":1392,"stem":1393,"titleTemplate":6},"/docs/4.x/guide/going-further/kit","docs/4.x/3.guide/6.going-further/4.kit",{"title":415,"path":1395,"stem":1396,"titleTemplate":6},"/docs/4.x/guide/going-further/nuxt-app","docs/4.x/3.guide/6.going-further/6.nuxt-app",{"title":419,"path":1398,"stem":1399,"titleTemplate":6},"/docs/4.x/guide/going-further/layers","docs/4.x/3.guide/6.going-further/7.layers",{"title":423,"path":1401,"stem":1402,"titleTemplate":6},"/docs/4.x/guide/going-further/debugging","docs/4.x/3.guide/6.going-further/9.debugging",{"title":427,"titleTemplate":428,"icon":429,"path":1404,"stem":1405,"children":1406,"page":108},"/docs/4.x/api","docs/4.x/4.api",[1407,1456,1547,1638,1690,1748,1758],{"title":434,"titleTemplate":435,"icon":324,"path":1408,"stem":1409,"children":1410,"page":108},"/docs/4.x/api/components","docs/4.x/4.api/1.components",[1411,1414,1417,1420,1423,1426,1429,1432,1435,1438,1441,1444,1447,1450,1453],{"title":440,"path":1412,"stem":1413,"titleTemplate":6},"/docs/4.x/api/components/client-only","docs/4.x/4.api/1.components/1.client-only",{"title":444,"path":1415,"stem":1416,"titleTemplate":6},"/docs/4.x/api/components/dev-only","docs/4.x/4.api/1.components/1.dev-only",{"title":448,"path":1418,"stem":1419,"titleTemplate":6},"/docs/4.x/api/components/nuxt-client-fallback","docs/4.x/4.api/1.components/1.nuxt-client-fallback",{"title":452,"path":1421,"stem":1422,"titleTemplate":6},"/docs/4.x/api/components/nuxt-picture","docs/4.x/4.api/1.components/10.nuxt-picture",{"title":456,"path":1424,"stem":1425,"titleTemplate":6},"/docs/4.x/api/components/teleports","docs/4.x/4.api/1.components/11.teleports",{"title":460,"path":1427,"stem":1428,"titleTemplate":6},"/docs/4.x/api/components/nuxt-route-announcer","docs/4.x/4.api/1.components/12.nuxt-route-announcer",{"title":464,"path":1430,"stem":1431,"titleTemplate":6},"/docs/4.x/api/components/nuxt-time","docs/4.x/4.api/1.components/13.nuxt-time",{"title":468,"path":1433,"stem":1434,"titleTemplate":6},"/docs/4.x/api/components/nuxt-page","docs/4.x/4.api/1.components/2.nuxt-page",{"title":472,"path":1436,"stem":1437,"titleTemplate":6},"/docs/4.x/api/components/nuxt-layout","docs/4.x/4.api/1.components/3.nuxt-layout",{"title":476,"path":1439,"stem":1440,"titleTemplate":6},"/docs/4.x/api/components/nuxt-link","docs/4.x/4.api/1.components/4.nuxt-link",{"title":480,"path":1442,"stem":1443,"titleTemplate":6},"/docs/4.x/api/components/nuxt-loading-indicator","docs/4.x/4.api/1.components/5.nuxt-loading-indicator",{"title":484,"path":1445,"stem":1446,"titleTemplate":6},"/docs/4.x/api/components/nuxt-error-boundary","docs/4.x/4.api/1.components/6.nuxt-error-boundary",{"title":488,"path":1448,"stem":1449,"titleTemplate":6},"/docs/4.x/api/components/nuxt-welcome","docs/4.x/4.api/1.components/7.nuxt-welcome",{"title":492,"path":1451,"stem":1452,"titleTemplate":6},"/docs/4.x/api/components/nuxt-island","docs/4.x/4.api/1.components/8.nuxt-island",{"title":496,"path":1454,"stem":1455,"titleTemplate":6},"/docs/4.x/api/components/nuxt-img","docs/4.x/4.api/1.components/9.nuxt-img",{"title":500,"titleTemplate":501,"icon":502,"path":1457,"stem":1458,"children":1459,"page":108},"/docs/4.x/api/composables","docs/4.x/4.api/2.composables",[1460,1463,1466,1469,1472,1475,1478,1481,1484,1487,1490,1493,1496,1499,1502,1505,1508,1511,1514,1517,1520,1523,1526,1529,1532,1535,1538,1541,1544],{"title":507,"path":1461,"stem":1462,"titleTemplate":6},"/docs/4.x/api/composables/on-prehydrate","docs/4.x/4.api/2.composables/on-prehydrate",{"title":511,"path":1464,"stem":1465,"titleTemplate":6},"/docs/4.x/api/composables/use-app-config","docs/4.x/4.api/2.composables/use-app-config",{"title":515,"path":1467,"stem":1468,"titleTemplate":6},"/docs/4.x/api/composables/use-async-data","docs/4.x/4.api/2.composables/use-async-data",{"title":519,"path":1470,"stem":1471,"titleTemplate":6},"/docs/4.x/api/composables/use-cookie","docs/4.x/4.api/2.composables/use-cookie",{"title":523,"path":1473,"stem":1474,"titleTemplate":6},"/docs/4.x/api/composables/use-error","docs/4.x/4.api/2.composables/use-error",{"title":527,"path":1476,"stem":1477,"titleTemplate":6},"/docs/4.x/api/composables/use-fetch","docs/4.x/4.api/2.composables/use-fetch",{"title":531,"path":1479,"stem":1480,"titleTemplate":6},"/docs/4.x/api/composables/use-head","docs/4.x/4.api/2.composables/use-head",{"title":535,"path":1482,"stem":1483,"titleTemplate":6},"/docs/4.x/api/composables/use-head-safe","docs/4.x/4.api/2.composables/use-head-safe",{"title":539,"path":1485,"stem":1486,"titleTemplate":6},"/docs/4.x/api/composables/use-hydration","docs/4.x/4.api/2.composables/use-hydration",{"title":543,"path":1488,"stem":1489,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-async-data","docs/4.x/4.api/2.composables/use-lazy-async-data",{"title":547,"path":1491,"stem":1492,"titleTemplate":6},"/docs/4.x/api/composables/use-lazy-fetch","docs/4.x/4.api/2.composables/use-lazy-fetch",{"title":551,"path":1494,"stem":1495,"titleTemplate":6},"/docs/4.x/api/composables/use-loading-indicator","docs/4.x/4.api/2.composables/use-loading-indicator",{"title":555,"path":1497,"stem":1498,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-app","docs/4.x/4.api/2.composables/use-nuxt-app",{"title":559,"path":1500,"stem":1501,"titleTemplate":6},"/docs/4.x/api/composables/use-nuxt-data","docs/4.x/4.api/2.composables/use-nuxt-data",{"title":563,"path":1503,"stem":1504,"titleTemplate":6},"/docs/4.x/api/composables/use-preview-mode","docs/4.x/4.api/2.composables/use-preview-mode",{"title":567,"path":1506,"stem":1507,"titleTemplate":6},"/docs/4.x/api/composables/use-request-event","docs/4.x/4.api/2.composables/use-request-event",{"title":571,"path":1509,"stem":1510,"titleTemplate":6},"/docs/4.x/api/composables/use-request-fetch","docs/4.x/4.api/2.composables/use-request-fetch",{"title":575,"path":1512,"stem":1513,"titleTemplate":6},"/docs/4.x/api/composables/use-request-header","docs/4.x/4.api/2.composables/use-request-header",{"title":579,"path":1515,"stem":1516,"titleTemplate":6},"/docs/4.x/api/composables/use-request-headers","docs/4.x/4.api/2.composables/use-request-headers",{"title":583,"path":1518,"stem":1519,"titleTemplate":6},"/docs/4.x/api/composables/use-request-url","docs/4.x/4.api/2.composables/use-request-url",{"title":587,"path":1521,"stem":1522,"titleTemplate":6},"/docs/4.x/api/composables/use-response-header","docs/4.x/4.api/2.composables/use-response-header",{"title":591,"path":1524,"stem":1525,"titleTemplate":6},"/docs/4.x/api/composables/use-route","docs/4.x/4.api/2.composables/use-route",{"title":595,"path":1527,"stem":1528,"titleTemplate":6},"/docs/4.x/api/composables/use-route-announcer","docs/4.x/4.api/2.composables/use-route-announcer",{"title":599,"path":1530,"stem":1531,"titleTemplate":6},"/docs/4.x/api/composables/use-router","docs/4.x/4.api/2.composables/use-router",{"title":603,"path":1533,"stem":1534,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-config","docs/4.x/4.api/2.composables/use-runtime-config",{"title":607,"path":1536,"stem":1537,"titleTemplate":6},"/docs/4.x/api/composables/use-runtime-hook","docs/4.x/4.api/2.composables/use-runtime-hook",{"title":611,"path":1539,"stem":1540,"titleTemplate":6},"/docs/4.x/api/composables/use-seo-meta","docs/4.x/4.api/2.composables/use-seo-meta",{"title":615,"path":1542,"stem":1543,"titleTemplate":6},"/docs/4.x/api/composables/use-server-seo-meta","docs/4.x/4.api/2.composables/use-server-seo-meta",{"title":619,"path":1545,"stem":1546,"titleTemplate":6},"/docs/4.x/api/composables/use-state","docs/4.x/4.api/2.composables/use-state",{"title":623,"titleTemplate":624,"icon":625,"path":1548,"stem":1549,"children":1550,"page":108},"/docs/4.x/api/utils","docs/4.x/4.api/3.utils",[1551,1554,1557,1560,1563,1566,1569,1572,1575,1578,1581,1584,1587,1590,1593,1596,1599,1602,1605,1608,1611,1614,1617,1620,1623,1626,1629,1632,1635],{"title":630,"path":1552,"stem":1553,"titleTemplate":6},"/docs/4.x/api/utils/dollarfetch","docs/4.x/4.api/3.utils/$fetch",{"title":634,"path":1555,"stem":1556,"titleTemplate":6},"/docs/4.x/api/utils/abort-navigation","docs/4.x/4.api/3.utils/abort-navigation",{"title":638,"path":1558,"stem":1559,"titleTemplate":6},"/docs/4.x/api/utils/add-route-middleware","docs/4.x/4.api/3.utils/add-route-middleware",{"title":642,"path":1561,"stem":1562,"titleTemplate":6},"/docs/4.x/api/utils/call-once","docs/4.x/4.api/3.utils/call-once",{"title":646,"path":1564,"stem":1565,"titleTemplate":6},"/docs/4.x/api/utils/clear-error","docs/4.x/4.api/3.utils/clear-error",{"title":650,"path":1567,"stem":1568,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-data","docs/4.x/4.api/3.utils/clear-nuxt-data",{"title":654,"path":1570,"stem":1571,"titleTemplate":6},"/docs/4.x/api/utils/clear-nuxt-state","docs/4.x/4.api/3.utils/clear-nuxt-state",{"title":658,"path":1573,"stem":1574,"titleTemplate":6},"/docs/4.x/api/utils/create-error","docs/4.x/4.api/3.utils/create-error",{"title":662,"path":1576,"stem":1577,"titleTemplate":6},"/docs/4.x/api/utils/define-lazy-hydration-component","docs/4.x/4.api/3.utils/define-lazy-hydration-component",{"title":666,"path":1579,"stem":1580,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-component","docs/4.x/4.api/3.utils/define-nuxt-component",{"title":670,"path":1582,"stem":1583,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-plugin","docs/4.x/4.api/3.utils/define-nuxt-plugin",{"title":674,"path":1585,"stem":1586,"titleTemplate":6},"/docs/4.x/api/utils/define-nuxt-route-middleware","docs/4.x/4.api/3.utils/define-nuxt-route-middleware",{"title":678,"path":1588,"stem":1589,"titleTemplate":6},"/docs/4.x/api/utils/define-page-meta","docs/4.x/4.api/3.utils/define-page-meta",{"title":682,"path":1591,"stem":1592,"titleTemplate":6},"/docs/4.x/api/utils/define-route-rules","docs/4.x/4.api/3.utils/define-route-rules",{"title":686,"path":1594,"stem":1595,"titleTemplate":6},"/docs/4.x/api/utils/navigate-to","docs/4.x/4.api/3.utils/navigate-to",{"title":690,"path":1597,"stem":1598,"titleTemplate":6},"/docs/4.x/api/utils/on-before-route-leave","docs/4.x/4.api/3.utils/on-before-route-leave",{"title":694,"path":1600,"stem":1601,"titleTemplate":6},"/docs/4.x/api/utils/on-before-route-update","docs/4.x/4.api/3.utils/on-before-route-update",{"title":698,"path":1603,"stem":1604,"titleTemplate":6},"/docs/4.x/api/utils/on-nuxt-ready","docs/4.x/4.api/3.utils/on-nuxt-ready",{"title":702,"path":1606,"stem":1607,"titleTemplate":6},"/docs/4.x/api/utils/prefetch-components","docs/4.x/4.api/3.utils/prefetch-components",{"title":706,"path":1609,"stem":1610,"titleTemplate":6},"/docs/4.x/api/utils/preload-components","docs/4.x/4.api/3.utils/preload-components",{"title":710,"path":1612,"stem":1613,"titleTemplate":6},"/docs/4.x/api/utils/preload-route-components","docs/4.x/4.api/3.utils/preload-route-components",{"title":714,"path":1615,"stem":1616,"titleTemplate":6},"/docs/4.x/api/utils/prerender-routes","docs/4.x/4.api/3.utils/prerender-routes",{"title":718,"path":1618,"stem":1619,"titleTemplate":6},"/docs/4.x/api/utils/refresh-cookie","docs/4.x/4.api/3.utils/refresh-cookie",{"title":722,"path":1621,"stem":1622,"titleTemplate":6},"/docs/4.x/api/utils/refresh-nuxt-data","docs/4.x/4.api/3.utils/refresh-nuxt-data",{"title":726,"path":1624,"stem":1625,"titleTemplate":6},"/docs/4.x/api/utils/reload-nuxt-app","docs/4.x/4.api/3.utils/reload-nuxt-app",{"title":730,"path":1627,"stem":1628,"titleTemplate":6},"/docs/4.x/api/utils/set-page-layout","docs/4.x/4.api/3.utils/set-page-layout",{"title":734,"path":1630,"stem":1631,"titleTemplate":6},"/docs/4.x/api/utils/set-response-status","docs/4.x/4.api/3.utils/set-response-status",{"title":738,"path":1633,"stem":1634,"titleTemplate":6},"/docs/4.x/api/utils/show-error","docs/4.x/4.api/3.utils/show-error",{"title":742,"path":1636,"stem":1637,"titleTemplate":6},"/docs/4.x/api/utils/update-app-config","docs/4.x/4.api/3.utils/update-app-config",{"title":746,"titleTemplate":747,"icon":748,"path":1639,"stem":1640,"children":1641,"page":108},"/docs/4.x/api/commands","docs/4.x/4.api/4.commands",[1642,1645,1648,1651,1654,1657,1660,1663,1666,1669,1672,1675,1678,1681,1684,1687],{"title":753,"path":1643,"stem":1644,"titleTemplate":6},"/docs/4.x/api/commands/add","docs/4.x/4.api/4.commands/add",{"title":757,"path":1646,"stem":1647,"titleTemplate":6},"/docs/4.x/api/commands/analyze","docs/4.x/4.api/4.commands/analyze",{"title":761,"path":1649,"stem":1650,"titleTemplate":6},"/docs/4.x/api/commands/build","docs/4.x/4.api/4.commands/build",{"title":765,"path":1652,"stem":1653,"titleTemplate":6},"/docs/4.x/api/commands/build-module","docs/4.x/4.api/4.commands/build-module",{"title":769,"path":1655,"stem":1656,"titleTemplate":6},"/docs/4.x/api/commands/cleanup","docs/4.x/4.api/4.commands/cleanup",{"title":773,"path":1658,"stem":1659,"titleTemplate":6},"/docs/4.x/api/commands/dev","docs/4.x/4.api/4.commands/dev",{"title":777,"path":1661,"stem":1662,"titleTemplate":6},"/docs/4.x/api/commands/devtools","docs/4.x/4.api/4.commands/devtools",{"title":781,"path":1664,"stem":1665,"titleTemplate":6},"/docs/4.x/api/commands/generate","docs/4.x/4.api/4.commands/generate",{"title":785,"path":1667,"stem":1668,"titleTemplate":6},"/docs/4.x/api/commands/info","docs/4.x/4.api/4.commands/info",{"title":789,"path":1670,"stem":1671,"titleTemplate":6},"/docs/4.x/api/commands/init","docs/4.x/4.api/4.commands/init",{"title":793,"path":1673,"stem":1674,"titleTemplate":6},"/docs/4.x/api/commands/module","docs/4.x/4.api/4.commands/module",{"title":797,"path":1676,"stem":1677,"titleTemplate":6},"/docs/4.x/api/commands/prepare","docs/4.x/4.api/4.commands/prepare",{"title":801,"path":1679,"stem":1680,"titleTemplate":6},"/docs/4.x/api/commands/preview","docs/4.x/4.api/4.commands/preview",{"title":805,"path":1682,"stem":1683,"titleTemplate":6},"/docs/4.x/api/commands/test","docs/4.x/4.api/4.commands/test",{"title":809,"path":1685,"stem":1686,"titleTemplate":6},"/docs/4.x/api/commands/typecheck","docs/4.x/4.api/4.commands/typecheck",{"title":813,"path":1688,"stem":1689,"titleTemplate":6},"/docs/4.x/api/commands/upgrade","docs/4.x/4.api/4.commands/upgrade",{"title":411,"titleTemplate":817,"icon":818,"path":1691,"stem":1692,"children":1693,"page":108},"/docs/4.x/api/kit","docs/4.x/4.api/5.kit",[1694,1697,1700,1703,1706,1709,1712,1715,1718,1721,1724,1727,1730,1733,1736,1739,1742,1745],{"title":276,"path":1695,"stem":1696,"titleTemplate":6},"/docs/4.x/api/kit/modules","docs/4.x/4.api/5.kit/1.modules",{"title":399,"path":1698,"stem":1699,"titleTemplate":6},"/docs/4.x/api/kit/runtime-config","docs/4.x/4.api/5.kit/10.runtime-config",{"title":829,"path":1701,"stem":1702,"titleTemplate":6},"/docs/4.x/api/kit/templates","docs/4.x/4.api/5.kit/10.templates",{"title":833,"path":1704,"stem":1705,"titleTemplate":6},"/docs/4.x/api/kit/nitro","docs/4.x/4.api/5.kit/11.nitro",{"title":837,"path":1707,"stem":1708,"titleTemplate":6},"/docs/4.x/api/kit/resolving","docs/4.x/4.api/5.kit/12.resolving",{"title":841,"path":1710,"stem":1711,"titleTemplate":6},"/docs/4.x/api/kit/logging","docs/4.x/4.api/5.kit/13.logging",{"title":845,"path":1713,"stem":1714,"titleTemplate":6},"/docs/4.x/api/kit/builder","docs/4.x/4.api/5.kit/14.builder",{"title":849,"path":1716,"stem":1717,"titleTemplate":6},"/docs/4.x/api/kit/examples","docs/4.x/4.api/5.kit/15.examples",{"title":84,"path":1719,"stem":1720,"titleTemplate":6},"/docs/4.x/api/kit/layers","docs/4.x/4.api/5.kit/16.layers",{"title":856,"path":1722,"stem":1723,"titleTemplate":6},"/docs/4.x/api/kit/programmatic","docs/4.x/4.api/5.kit/2.programmatic",{"title":860,"path":1725,"stem":1726,"titleTemplate":6},"/docs/4.x/api/kit/compatibility","docs/4.x/4.api/5.kit/3.compatibility",{"title":268,"path":1728,"stem":1729,"titleTemplate":6},"/docs/4.x/api/kit/autoimports","docs/4.x/4.api/5.kit/4.autoimports",{"title":434,"path":1731,"stem":1732,"titleTemplate":6},"/docs/4.x/api/kit/components","docs/4.x/4.api/5.kit/5.components",{"title":870,"path":1734,"stem":1735,"titleTemplate":6},"/docs/4.x/api/kit/context","docs/4.x/4.api/5.kit/6.context",{"title":874,"path":1737,"stem":1738,"titleTemplate":6},"/docs/4.x/api/kit/pages","docs/4.x/4.api/5.kit/7.pages",{"title":878,"path":1740,"stem":1741,"titleTemplate":6},"/docs/4.x/api/kit/layout","docs/4.x/4.api/5.kit/8.layout",{"title":882,"path":1743,"stem":1744,"titleTemplate":6},"/docs/4.x/api/kit/head","docs/4.x/4.api/5.kit/9.head",{"title":886,"path":1746,"stem":1747,"titleTemplate":6},"/docs/4.x/api/kit/plugins","docs/4.x/4.api/5.kit/9.plugins",{"title":890,"titleTemplate":6,"icon":891,"path":1749,"stem":1750,"children":1751,"page":108},"/docs/4.x/api/advanced","docs/4.x/4.api/6.advanced",[1752,1755],{"title":407,"path":1753,"stem":1754,"titleTemplate":6},"/docs/4.x/api/advanced/hooks","docs/4.x/4.api/6.advanced/1.hooks",{"title":899,"path":1756,"stem":1757,"titleTemplate":6},"/docs/4.x/api/advanced/import-meta","docs/4.x/4.api/6.advanced/2.import-meta",{"title":903,"path":1759,"stem":1760,"titleTemplate":906,"icon":32},"/docs/4.x/api/nuxt-config","docs/4.x/4.api/6.nuxt-config",{"title":849,"titleTemplate":908,"icon":909,"path":1762,"stem":1763,"children":1764,"page":108},"/docs/4.x/examples","docs/4.x/4.examples",[1765,1768,1787,1800,1831],{"title":914,"path":1766,"stem":1767,"titleTemplate":6},"/docs/4.x/examples/hello-world","docs/4.x/4.examples/0.hello-world",{"title":395,"path":1769,"stem":1770,"children":1771,"page":108},"/docs/4.x/examples/features","docs/4.x/4.examples/1.features",[1772,1775,1778,1781,1784],{"title":922,"path":1773,"stem":1774,"titleTemplate":6},"/docs/4.x/examples/features/auto-imports","docs/4.x/4.examples/1.features/1.auto-imports",{"title":64,"path":1776,"stem":1777,"titleTemplate":6},"/docs/4.x/examples/features/data-fetching","docs/4.x/4.examples/1.features/2.data-fetching",{"title":69,"path":1779,"stem":1780,"titleTemplate":6},"/docs/4.x/examples/features/state-management","docs/4.x/4.examples/1.features/3.state-management",{"title":932,"path":1782,"stem":1783,"titleTemplate":6},"/docs/4.x/examples/features/meta-tags","docs/4.x/4.examples/1.features/4.meta-tags",{"title":936,"path":1785,"stem":1786,"titleTemplate":6},"/docs/4.x/examples/features/layouts","docs/4.x/4.examples/1.features/5.layouts",{"title":49,"path":1788,"stem":1789,"children":1790,"page":108},"/docs/4.x/examples/routing","docs/4.x/4.examples/2.routing",[1791,1794,1797],{"title":944,"path":1792,"stem":1793,"titleTemplate":6},"/docs/4.x/examples/routing/middleware","docs/4.x/4.examples/2.routing/middleware",{"title":874,"path":1795,"stem":1796,"titleTemplate":6},"/docs/4.x/examples/routing/pages","docs/4.x/4.examples/2.routing/pages",{"title":951,"path":1798,"stem":1799,"titleTemplate":6},"/docs/4.x/examples/routing/universal-router","docs/4.x/4.examples/2.routing/universal-router",{"title":890,"path":1801,"stem":1802,"children":1803,"page":108},"/docs/4.x/examples/advanced","docs/4.x/4.examples/4.advanced",[1804,1807,1810,1813,1816,1819,1822,1825,1828],{"title":84,"path":1805,"stem":1806,"titleTemplate":6},"/docs/4.x/examples/advanced/config-extends","docs/4.x/4.examples/4.advanced/config-extends",{"title":74,"path":1808,"stem":1809,"titleTemplate":6},"/docs/4.x/examples/advanced/error-handling","docs/4.x/4.examples/4.advanced/error-handling",{"title":965,"path":1811,"stem":1812,"titleTemplate":6},"/docs/4.x/examples/advanced/jsx","docs/4.x/4.examples/4.advanced/jsx",{"title":969,"path":1814,"stem":1815,"titleTemplate":6},"/docs/4.x/examples/advanced/locale","docs/4.x/4.examples/4.advanced/locale",{"title":973,"path":1817,"stem":1818,"titleTemplate":6},"/docs/4.x/examples/advanced/module-extend-pages","docs/4.x/4.examples/4.advanced/module-extend-pages",{"title":977,"path":1820,"stem":1821,"titleTemplate":6},"/docs/4.x/examples/advanced/teleport","docs/4.x/4.examples/4.advanced/teleport",{"title":99,"path":1823,"stem":1824,"titleTemplate":6},"/docs/4.x/examples/advanced/testing","docs/4.x/4.examples/4.advanced/testing",{"title":519,"path":1826,"stem":1827,"titleTemplate":6},"/docs/4.x/examples/advanced/use-cookie","docs/4.x/4.examples/4.advanced/use-cookie",{"title":987,"path":1829,"stem":1830,"titleTemplate":6},"/docs/4.x/examples/advanced/use-custom-fetch-composable","docs/4.x/4.examples/4.advanced/use-custom-fetch-composable",{"title":991,"path":1832,"stem":1833,"children":1834,"page":108},"/docs/4.x/examples/experimental","docs/4.x/4.examples/7.experimental",[1835],{"title":996,"path":1836,"stem":1837,"titleTemplate":6},"/docs/4.x/examples/experimental/wasm","docs/4.x/4.examples/7.experimental/wasm",{"title":1000,"titleTemplate":1001,"icon":1002,"path":1839,"stem":1840,"children":1841,"page":108},"/docs/4.x/community","docs/4.x/5.community",[1842,1845,1848,1851,1854,1857],{"title":1007,"path":1843,"stem":1844,"titleTemplate":6,"icon":1010},"/docs/4.x/community/getting-help","docs/4.x/5.community/2.getting-help",{"title":1012,"path":1846,"stem":1847,"titleTemplate":6,"icon":1015},"/docs/4.x/community/reporting-bugs","docs/4.x/5.community/3.reporting-bugs",{"title":1017,"path":1849,"stem":1850,"titleTemplate":6,"icon":1020},"/docs/4.x/community/contribution","docs/4.x/5.community/4.contribution",{"title":1022,"path":1852,"stem":1853,"titleTemplate":6,"icon":1025},"/docs/4.x/community/framework-contribution","docs/4.x/5.community/5.framework-contribution",{"title":1027,"path":1855,"stem":1856,"titleTemplate":6,"icon":1030},"/docs/4.x/community/roadmap","docs/4.x/5.community/6.roadmap",{"title":1032,"path":1858,"stem":1859,"titleTemplate":6,"icon":1035},"/docs/4.x/community/changelog","docs/4.x/5.community/7.changelog",{"title":1037,"titleTemplate":1038,"icon":1039,"path":1861,"stem":1862,"children":1863,"page":108},"/docs/4.x/bridge","docs/4.x/6.bridge",[1864,1867,1870,1873,1876,1879,1882,1885,1888,1891],{"title":1044,"path":1865,"stem":1866,"titleTemplate":6},"/docs/4.x/bridge/overview","docs/4.x/6.bridge/1.overview",{"title":29,"path":1868,"stem":1869,"titleTemplate":6},"/docs/4.x/bridge/configuration","docs/4.x/6.bridge/10.configuration",{"title":280,"path":1871,"stem":1872,"titleTemplate":6},"/docs/4.x/bridge/typescript","docs/4.x/6.bridge/2.typescript",{"title":1054,"path":1874,"stem":1875,"titleTemplate":6},"/docs/4.x/bridge/bridge-composition-api","docs/4.x/6.bridge/3.bridge-composition-api",{"title":1058,"path":1877,"stem":1878,"titleTemplate":6},"/docs/4.x/bridge/plugins-and-middleware","docs/4.x/6.bridge/4.plugins-and-middleware",{"title":1062,"path":1880,"stem":1881,"titleTemplate":6},"/docs/4.x/bridge/nuxt3-compatible-api","docs/4.x/6.bridge/5.nuxt3-compatible-api",{"title":932,"path":1883,"stem":1884,"titleTemplate":6},"/docs/4.x/bridge/meta","docs/4.x/6.bridge/6.meta",{"title":399,"path":1886,"stem":1887,"titleTemplate":6},"/docs/4.x/bridge/runtime-config","docs/4.x/6.bridge/7.runtime-config",{"title":833,"path":1889,"stem":1890,"titleTemplate":6},"/docs/4.x/bridge/nitro","docs/4.x/6.bridge/8.nitro",{"title":1075,"path":1892,"stem":1893,"titleTemplate":6},"/docs/4.x/bridge/vite","docs/4.x/6.bridge/9.vite",{"title":1079,"titleTemplate":1080,"icon":107,"path":1895,"stem":1896,"children":1897,"page":108},"/docs/4.x/migration","docs/4.x/7.migration",[1898,1901,1904,1907,1910,1913,1916,1919,1922,1925,1928],{"title":1044,"path":1899,"stem":1900,"titleTemplate":6},"/docs/4.x/migration/overview","docs/4.x/7.migration/1.overview",{"title":1088,"path":1902,"stem":1903,"titleTemplate":6},"/docs/4.x/migration/bundling","docs/4.x/7.migration/10.bundling",{"title":79,"path":1905,"stem":1906,"titleTemplate":6},"/docs/4.x/migration/server","docs/4.x/7.migration/11.server",{"title":29,"path":1908,"stem":1909,"titleTemplate":6},"/docs/4.x/migration/configuration","docs/4.x/7.migration/2.configuration",{"title":276,"path":1911,"stem":1912,"titleTemplate":6},"/docs/4.x/migration/module-authors","docs/4.x/7.migration/20.module-authors",{"title":922,"path":1914,"stem":1915,"titleTemplate":6},"/docs/4.x/migration/auto-imports","docs/4.x/7.migration/3.auto-imports",{"title":932,"path":1917,"stem":1918,"titleTemplate":6},"/docs/4.x/migration/meta","docs/4.x/7.migration/4.meta",{"title":1058,"path":1920,"stem":1921,"titleTemplate":6},"/docs/4.x/migration/plugins-and-middleware","docs/4.x/7.migration/5.plugins-and-middleware",{"title":1110,"path":1923,"stem":1924,"titleTemplate":6},"/docs/4.x/migration/pages-and-layouts","docs/4.x/7.migration/6.pages-and-layouts",{"title":1114,"path":1926,"stem":1927,"titleTemplate":6},"/docs/4.x/migration/component-options","docs/4.x/7.migration/7.component-options",{"title":399,"path":1929,"stem":1930,"titleTemplate":6},"/docs/4.x/migration/runtime-config","docs/4.x/7.migration/8.runtime-config",{"title":1932,"path":1933,"stem":1934,"children":1935,"page":108},"Blog","/blog","blog",[1936,1940,1944,1948,1952,1956,1960,1964,1968,1972,1976,1980,1984,1988,1992,1996,2000,2004,2008,2012,2016],{"title":1937,"path":1938,"stem":1939},"Announcing 3.0","/blog/v3","blog/1.v3",{"title":1941,"path":1942,"stem":1943},"Nuxt 3.3","/blog/v3-3","blog/10.v3-3",{"title":1945,"path":1946,"stem":1947},"Nuxt 3.4","/blog/v3-4","blog/11.v3-4",{"title":1949,"path":1950,"stem":1951},"Nuxt 3.5","/blog/v3-5","blog/12.v3-5",{"title":1953,"path":1954,"stem":1955},"Nuxt 3.6","/blog/v3-6","blog/13.v3-6",{"title":1957,"path":1958,"stem":1959},"Nuxt on the Edge","/blog/nuxt-on-the-edge","blog/14.nuxt-on-the-edge",{"title":1961,"path":1962,"stem":1963},"Nuxt DevTools v1.0","/blog/nuxt-devtools-v1-0","blog/18.nuxt-devtools-v1-0",{"title":1965,"path":1966,"stem":1967},"Nuxt: A vision for 2023","/blog/vision-2023","blog/2.vision-2023",{"title":1969,"path":1970,"stem":1971},"The Evolution of Shiki v1.0","/blog/shiki-v1","blog/21.shiki-v1",{"title":1973,"path":1974,"stem":1975},"Refreshed Nuxt ESLint Integrations","/blog/eslint-module","blog/24.eslint-module",{"title":1977,"path":1978,"stem":1979},"Introducing Nuxt Scripts","/blog/nuxt-scripts","blog/26.nuxt-scripts",{"title":1981,"path":1982,"stem":1983},"Introducing Nuxt Icon v1","/blog/nuxt-icon-v1-0","blog/29.nuxt-icon-v1-0",{"title":1985,"path":1986,"stem":1987},"Introducing Nuxt DevTools","/blog/introducing-nuxt-devtools","blog/3.introducing-nuxt-devtools",{"title":1989,"path":1990,"stem":1991},"Announcing Nuxt 3 Release Candidate","/blog/nuxt3-rc","blog/3.nuxt3-rc",{"title":1993,"path":1994,"stem":1995},"Nuxt 2 End-of-Life (EOL)","/blog/nuxt2-eol","blog/4.nuxt2-eol",{"title":1997,"path":1998,"stem":1999},"Introducing Nuxt 3 Beta","/blog/nuxt3-beta","blog/4.nuxt3-beta",{"title":2001,"path":2002,"stem":2003},"Going Full Static","/blog/going-full-static","blog/5.going-full-static",{"title":2005,"path":2006,"stem":2007},"Introducing Smart Prefetching","/blog/introducing-smart-prefetching","blog/6.introducing-smart-prefetching",{"title":2009,"path":2010,"stem":2011},"Understanding how fetch works in Nuxt 2.12","/blog/understanding-how-fetch-works-in-nuxt-2-12","blog/7.understanding-how-fetch-works-in-nuxt-2-12",{"title":2013,"path":2014,"stem":2015},"Nuxt 2 Static Improvements","/blog/nuxt-static-improvements","blog/8.nuxt-static-improvements",{"title":2017,"path":2018,"stem":2019},"Nuxt 2: From Terminal to Browser","/blog/nuxtjs-from-terminal-to-browser","blog/9.nuxtjs-from-terminal-to-browser",{"v3":2021,"v4":2022,"v2":2023},"3.21.1","4.3.1","2.18.1",{"id":2025,"title":99,"body":2026,"description":7806,"extension":7807,"links":6,"meta":7808,"navigation":7809,"path":1177,"seo":7810,"stem":1178,"titleTemplate":6,"__hash__":7811},"docsv4/docs/4.x/1.getting-started/17.testing.md",{"type":2027,"value":2028,"toc":7789},"minimark",[2029,2041,2056,2061,2065,2071,2112,2231,2235,2251,2256,2707,2731,2740,2744,2753,2776,2781,2784,2914,2931,3001,3011,3015,3018,3090,3093,3097,3121,3129,3134,3137,3220,3230,3234,3237,3314,3339,3343,3348,3354,3361,3367,3381,3391,3511,3515,3520,3526,3531,3554,3557,3707,3877,3883,3892,3907,3915,3921,3924,4068,4226,4232,4241,4342,4360,4380,4611,4617,4622,4629,4860,4868,5045,5051,5056,5063,5068,5139,5146,5243,5262,5266,5274,5288,5293,5378,5383,5454,5459,5465,6059,6065,6069,6093,6096,6105,6243,6262,6268,6272,6311,6315,6360,6363,6539,6546,6549,6552,6561,6822,6826,6832,6835,6887,6893,6896,6968,6974,6977,7032,7036,7042,7048,7067,7122,7126,7134,7226,7233,7406,7412,7423,7571,7574,7785],[2030,2031,2032],"tip",{},[2033,2034,2035,2036,2040],"p",{},"If you are a module author, you can find more specific information in the ",[2037,2038,2039],"a",{"href":1345},"Module Author's guide",".",[2033,2042,2043,2044,2048,2049,2055],{},"Nuxt offers first-class support for end-to-end and unit testing of your Nuxt application via ",[2045,2046,2047],"code",{},"@nuxt/test-utils",", a library of test utilities and configuration that currently powers the ",[2037,2050,2054],{"href":2051,"rel":2052},"https://github.com/nuxt/nuxt/tree/main/test",[2053],"nofollow","tests we use on Nuxt itself"," and tests throughout the module ecosystem.",[2057,2058],"video-accordion",{"title":2059,"video-id":2060},"Watch a video from Alexander Lichter about getting started with @nuxt/test-utils","yGzwk9xi9gU",[2062,2063,24],"h2",{"id":2064},"installation",[2033,2066,2067,2068,2070],{},"In order to allow you to manage your other testing dependencies, ",[2045,2069,2047],{}," ships with various optional peer dependencies. For example:",[2072,2073,2074,2086,2102],"ul",{},[2075,2076,2077,2078,2081,2082,2085],"li",{},"you can choose between ",[2045,2079,2080],{},"happy-dom"," and ",[2045,2083,2084],{},"jsdom"," for a runtime Nuxt environment",[2075,2087,2077,2088,2091,2092,2091,2095,2081,2098,2101],{},[2045,2089,2090],{},"vitest",", ",[2045,2093,2094],{},"cucumber",[2045,2096,2097],{},"jest",[2045,2099,2100],{},"playwright"," for end-to-end test runners",[2075,2103,2104,2107,2108,2111],{},[2045,2105,2106],{},"playwright-core"," is only required if you wish to use the built-in browser testing utilities (and are not using ",[2045,2109,2110],{},"@playwright/test"," as your test runner)",[2113,2114,2116,2156,2182,2207],"code-group",{"sync":2115},"pm",[2117,2118,2124],"pre",{"className":2119,"code":2120,"filename":2121,"language":2122,"meta":2123,"style":2123},"language-bash shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","npm i --save-dev @nuxt/test-utils vitest @vue/test-utils happy-dom playwright-core\n","npm","bash","",[2045,2125,2126],{"__ignoreMap":2123},[2127,2128,2131,2134,2138,2141,2144,2147,2150,2153],"span",{"class":2129,"line":2130},"line",1,[2127,2132,2121],{"class":2133},"s52Pk",[2127,2135,2137],{"class":2136},"sGFVr"," i",[2127,2139,2140],{"class":2136}," --save-dev",[2127,2142,2143],{"class":2136}," @nuxt/test-utils",[2127,2145,2146],{"class":2136}," vitest",[2127,2148,2149],{"class":2136}," @vue/test-utils",[2127,2151,2152],{"class":2136}," happy-dom",[2127,2154,2155],{"class":2136}," playwright-core\n",[2117,2157,2160],{"className":2119,"code":2158,"filename":2159,"language":2122,"meta":2123,"style":2123},"yarn add --dev @nuxt/test-utils vitest @vue/test-utils happy-dom playwright-core\n","yarn",[2045,2161,2162],{"__ignoreMap":2123},[2127,2163,2164,2166,2169,2172,2174,2176,2178,2180],{"class":2129,"line":2130},[2127,2165,2159],{"class":2133},[2127,2167,2168],{"class":2136}," add",[2127,2170,2171],{"class":2136}," --dev",[2127,2173,2143],{"class":2136},[2127,2175,2146],{"class":2136},[2127,2177,2149],{"class":2136},[2127,2179,2152],{"class":2136},[2127,2181,2155],{"class":2136},[2117,2183,2186],{"className":2119,"code":2184,"filename":2185,"language":2122,"meta":2123,"style":2123},"pnpm add -D @nuxt/test-utils vitest @vue/test-utils happy-dom playwright-core\n","pnpm",[2045,2187,2188],{"__ignoreMap":2123},[2127,2189,2190,2192,2194,2197,2199,2201,2203,2205],{"class":2129,"line":2130},[2127,2191,2185],{"class":2133},[2127,2193,2168],{"class":2136},[2127,2195,2196],{"class":2136}," -D",[2127,2198,2143],{"class":2136},[2127,2200,2146],{"class":2136},[2127,2202,2149],{"class":2136},[2127,2204,2152],{"class":2136},[2127,2206,2155],{"class":2136},[2117,2208,2211],{"className":2119,"code":2209,"filename":2210,"language":2122,"meta":2123,"style":2123},"bun add --dev @nuxt/test-utils vitest @vue/test-utils happy-dom playwright-core\n","bun",[2045,2212,2213],{"__ignoreMap":2123},[2127,2214,2215,2217,2219,2221,2223,2225,2227,2229],{"class":2129,"line":2130},[2127,2216,2210],{"class":2133},[2127,2218,2168],{"class":2136},[2127,2220,2171],{"class":2136},[2127,2222,2143],{"class":2136},[2127,2224,2146],{"class":2136},[2127,2226,2149],{"class":2136},[2127,2228,2152],{"class":2136},[2127,2230,2155],{"class":2136},[2062,2232,2234],{"id":2233},"unit-testing","Unit Testing",[2033,2236,2237,2238,2243,2244,2250],{},"We currently ship an environment for unit testing code that needs a ",[2037,2239,2242],{"href":2240,"rel":2241},"https://nuxt.com",[2053],"Nuxt"," runtime environment. It currently ",[2245,2246,2247,2248],"em",{},"only has support for ",[2045,2249,2090],{}," (although contribution to add other runtimes would be welcome).",[2252,2253,2255],"h3",{"id":2254},"setup","Setup",[2257,2258,2259,2343],"ol",{},[2075,2260,2261,2262,2265,2266,2269,2270],{},"Add ",[2045,2263,2264],{},"@nuxt/test-utils/module"," to your ",[2045,2267,2268],{},"nuxt.config"," file (optional). It adds a Vitest integration to your Nuxt DevTools which supports running your unit tests in development.",[2117,2271,2276],{"className":2272,"code":2273,"language":2274,"meta":2275,"style":2123},"language-ts shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","export default defineNuxtConfig({\n  modules: [\n    '@nuxt/test-utils/module',\n  ],\n})\n","ts","twoslash",[2045,2277,2278,2299,2312,2326,2334],{"__ignoreMap":2123},[2127,2279,2280,2284,2287,2291,2295],{"class":2129,"line":2130},[2127,2281,2283],{"class":2282},"s8R28","export",[2127,2285,2286],{"class":2282}," default",[2127,2288,2290],{"class":2289},"s3cPz"," defineNuxtConfig",[2127,2292,2294],{"class":2293},"sZSNi","(",[2127,2296,2298],{"class":2297},"sDfIl","{\n",[2127,2300,2302,2306,2309],{"class":2129,"line":2301},2,[2127,2303,2305],{"class":2304},"sRlkE","  modules",[2127,2307,2308],{"class":2297},":",[2127,2310,2311],{"class":2293}," [\n",[2127,2313,2315,2318,2320,2323],{"class":2129,"line":2314},3,[2127,2316,2317],{"class":2297},"    '",[2127,2319,2264],{"class":2136},[2127,2321,2322],{"class":2297},"'",[2127,2324,2325],{"class":2297},",\n",[2127,2327,2329,2332],{"class":2129,"line":2328},4,[2127,2330,2331],{"class":2293},"  ]",[2127,2333,2325],{"class":2297},[2127,2335,2337,2340],{"class":2129,"line":2336},5,[2127,2338,2339],{"class":2297},"}",[2127,2341,2342],{"class":2293},")\n",[2075,2344,2345,2346,2349,2350],{},"Create a ",[2045,2347,2348],{},"vitest.config.ts"," with the following content:",[2117,2351,2353],{"className":2272,"code":2352,"language":2274,"meta":2275,"style":2123},"import { defineConfig } from 'vitest/config'\nimport { defineVitestProject } from '@nuxt/test-utils/config'\n\nexport default defineConfig({\n  test: {\n    projects: [\n      {\n        test: {\n          name: 'unit',\n          include: ['test/unit/*.{test,spec}.ts'],\n          environment: 'node',\n        },\n      },\n      {\n        test: {\n          name: 'e2e',\n          include: ['test/e2e/*.{test,spec}.ts'],\n          environment: 'node',\n        },\n      },\n      await defineVitestProject({\n        test: {\n          name: 'nuxt',\n          include: ['test/nuxt/*.{test,spec}.ts'],\n          environment: 'nuxt',\n        },\n      }),\n    ],\n  },\n})\n",[2045,2354,2355,2381,2401,2406,2418,2428,2438,2444,2454,2471,2494,2511,2517,2523,2528,2537,2553,2573,2588,2593,2598,2610,2619,2635,2655,2670,2675,2686,2694,2700],{"__ignoreMap":2123},[2127,2356,2357,2360,2363,2366,2369,2372,2375,2378],{"class":2129,"line":2130},[2127,2358,2359],{"class":2282},"import",[2127,2361,2362],{"class":2297}," {",[2127,2364,2365],{"class":2293}," defineConfig",[2127,2367,2368],{"class":2297}," }",[2127,2370,2371],{"class":2282}," from",[2127,2373,2374],{"class":2297}," '",[2127,2376,2377],{"class":2136},"vitest/config",[2127,2379,2380],{"class":2297},"'\n",[2127,2382,2383,2385,2387,2390,2392,2394,2396,2399],{"class":2129,"line":2301},[2127,2384,2359],{"class":2282},[2127,2386,2362],{"class":2297},[2127,2388,2389],{"class":2293}," defineVitestProject",[2127,2391,2368],{"class":2297},[2127,2393,2371],{"class":2282},[2127,2395,2374],{"class":2297},[2127,2397,2398],{"class":2136},"@nuxt/test-utils/config",[2127,2400,2380],{"class":2297},[2127,2402,2403],{"class":2129,"line":2314},[2127,2404,2405],{"emptyLinePlaceholder":1196},"\n",[2127,2407,2408,2410,2412,2414,2416],{"class":2129,"line":2328},[2127,2409,2283],{"class":2282},[2127,2411,2286],{"class":2282},[2127,2413,2365],{"class":2289},[2127,2415,2294],{"class":2293},[2127,2417,2298],{"class":2297},[2127,2419,2420,2423,2425],{"class":2129,"line":2336},[2127,2421,2422],{"class":2304},"  test",[2127,2424,2308],{"class":2297},[2127,2426,2427],{"class":2297}," {\n",[2127,2429,2431,2434,2436],{"class":2129,"line":2430},6,[2127,2432,2433],{"class":2304},"    projects",[2127,2435,2308],{"class":2297},[2127,2437,2311],{"class":2293},[2127,2439,2441],{"class":2129,"line":2440},7,[2127,2442,2443],{"class":2297},"      {\n",[2127,2445,2447,2450,2452],{"class":2129,"line":2446},8,[2127,2448,2449],{"class":2304},"        test",[2127,2451,2308],{"class":2297},[2127,2453,2427],{"class":2297},[2127,2455,2457,2460,2462,2464,2467,2469],{"class":2129,"line":2456},9,[2127,2458,2459],{"class":2304},"          name",[2127,2461,2308],{"class":2297},[2127,2463,2374],{"class":2297},[2127,2465,2466],{"class":2136},"unit",[2127,2468,2322],{"class":2297},[2127,2470,2325],{"class":2297},[2127,2472,2474,2477,2479,2482,2484,2487,2489,2492],{"class":2129,"line":2473},10,[2127,2475,2476],{"class":2304},"          include",[2127,2478,2308],{"class":2297},[2127,2480,2481],{"class":2293}," [",[2127,2483,2322],{"class":2297},[2127,2485,2486],{"class":2136},"test/unit/*.{test,spec}.ts",[2127,2488,2322],{"class":2297},[2127,2490,2491],{"class":2293},"]",[2127,2493,2325],{"class":2297},[2127,2495,2497,2500,2502,2504,2507,2509],{"class":2129,"line":2496},11,[2127,2498,2499],{"class":2304},"          environment",[2127,2501,2308],{"class":2297},[2127,2503,2374],{"class":2297},[2127,2505,2506],{"class":2136},"node",[2127,2508,2322],{"class":2297},[2127,2510,2325],{"class":2297},[2127,2512,2514],{"class":2129,"line":2513},12,[2127,2515,2516],{"class":2297},"        },\n",[2127,2518,2520],{"class":2129,"line":2519},13,[2127,2521,2522],{"class":2297},"      },\n",[2127,2524,2526],{"class":2129,"line":2525},14,[2127,2527,2443],{"class":2297},[2127,2529,2531,2533,2535],{"class":2129,"line":2530},15,[2127,2532,2449],{"class":2304},[2127,2534,2308],{"class":2297},[2127,2536,2427],{"class":2297},[2127,2538,2540,2542,2544,2546,2549,2551],{"class":2129,"line":2539},16,[2127,2541,2459],{"class":2304},[2127,2543,2308],{"class":2297},[2127,2545,2374],{"class":2297},[2127,2547,2548],{"class":2136},"e2e",[2127,2550,2322],{"class":2297},[2127,2552,2325],{"class":2297},[2127,2554,2556,2558,2560,2562,2564,2567,2569,2571],{"class":2129,"line":2555},17,[2127,2557,2476],{"class":2304},[2127,2559,2308],{"class":2297},[2127,2561,2481],{"class":2293},[2127,2563,2322],{"class":2297},[2127,2565,2566],{"class":2136},"test/e2e/*.{test,spec}.ts",[2127,2568,2322],{"class":2297},[2127,2570,2491],{"class":2293},[2127,2572,2325],{"class":2297},[2127,2574,2576,2578,2580,2582,2584,2586],{"class":2129,"line":2575},18,[2127,2577,2499],{"class":2304},[2127,2579,2308],{"class":2297},[2127,2581,2374],{"class":2297},[2127,2583,2506],{"class":2136},[2127,2585,2322],{"class":2297},[2127,2587,2325],{"class":2297},[2127,2589,2591],{"class":2129,"line":2590},19,[2127,2592,2516],{"class":2297},[2127,2594,2596],{"class":2129,"line":2595},20,[2127,2597,2522],{"class":2297},[2127,2599,2601,2604,2606,2608],{"class":2129,"line":2600},21,[2127,2602,2603],{"class":2282},"      await",[2127,2605,2389],{"class":2289},[2127,2607,2294],{"class":2293},[2127,2609,2298],{"class":2297},[2127,2611,2613,2615,2617],{"class":2129,"line":2612},22,[2127,2614,2449],{"class":2304},[2127,2616,2308],{"class":2297},[2127,2618,2427],{"class":2297},[2127,2620,2622,2624,2626,2628,2631,2633],{"class":2129,"line":2621},23,[2127,2623,2459],{"class":2304},[2127,2625,2308],{"class":2297},[2127,2627,2374],{"class":2297},[2127,2629,2630],{"class":2136},"nuxt",[2127,2632,2322],{"class":2297},[2127,2634,2325],{"class":2297},[2127,2636,2638,2640,2642,2644,2646,2649,2651,2653],{"class":2129,"line":2637},24,[2127,2639,2476],{"class":2304},[2127,2641,2308],{"class":2297},[2127,2643,2481],{"class":2293},[2127,2645,2322],{"class":2297},[2127,2647,2648],{"class":2136},"test/nuxt/*.{test,spec}.ts",[2127,2650,2322],{"class":2297},[2127,2652,2491],{"class":2293},[2127,2654,2325],{"class":2297},[2127,2656,2658,2660,2662,2664,2666,2668],{"class":2129,"line":2657},25,[2127,2659,2499],{"class":2304},[2127,2661,2308],{"class":2297},[2127,2663,2374],{"class":2297},[2127,2665,2630],{"class":2136},[2127,2667,2322],{"class":2297},[2127,2669,2325],{"class":2297},[2127,2671,2673],{"class":2129,"line":2672},26,[2127,2674,2516],{"class":2297},[2127,2676,2678,2681,2684],{"class":2129,"line":2677},27,[2127,2679,2680],{"class":2297},"      }",[2127,2682,2683],{"class":2293},")",[2127,2685,2325],{"class":2297},[2127,2687,2689,2692],{"class":2129,"line":2688},28,[2127,2690,2691],{"class":2293},"    ]",[2127,2693,2325],{"class":2297},[2127,2695,2697],{"class":2129,"line":2696},29,[2127,2698,2699],{"class":2297},"  },\n",[2127,2701,2703,2705],{"class":2129,"line":2702},30,[2127,2704,2339],{"class":2297},[2127,2706,2342],{"class":2293},[2030,2708,2709,2722],{},[2033,2710,2711,2712,2714,2715,2718,2719,2721],{},"When importing ",[2045,2713,2047],{}," in your vitest config, It is necessary to have ",[2045,2716,2717],{},"\"type\": \"module\""," specified in your ",[2045,2720,237],{}," or rename your vitest config file appropriately.",[2723,2724,2725],"blockquote",{},[2033,2726,2727,2728,2040],{},"i.e., ",[2045,2729,2730],{},"vitest.config.m{ts,js}",[2030,2732,2733],{},[2033,2734,2735,2736,2739],{},"It is possible to set environment variables for testing by using the ",[2045,2737,2738],{},".env.test"," file.",[2252,2741,2743],{"id":2742},"using-a-nuxt-runtime-environment","Using a Nuxt Runtime Environment",[2033,2745,2746,2747,2752],{},"Using ",[2037,2748,2751],{"href":2749,"rel":2750},"https://vitest.dev/guide/projects.html#test-projects",[2053],"Vitest projects",", you have fine-grained control over which tests run in which environment:",[2072,2754,2755,2766],{},[2075,2756,2757,2761,2762,2765],{},[2758,2759,2760],"strong",{},"Unit tests",": Place regular unit tests in ",[2045,2763,2764],{},"test/unit/"," - these run in a Node environment for speed",[2075,2767,2768,2771,2772,2775],{},[2758,2769,2770],{},"Nuxt tests",": Place tests that rely on the Nuxt runtime environment in ",[2045,2773,2774],{},"test/nuxt/"," - these will run within a Nuxt runtime environment",[2777,2778,2780],"h4",{"id":2779},"alternative-simple-setup","Alternative: Simple Setup",[2033,2782,2783],{},"If you prefer a simpler setup and want all tests to run in the Nuxt environment, you can use the basic configuration:",[2117,2785,2787],{"className":2272,"code":2786,"language":2274,"meta":2275,"style":2123},"import { defineVitestConfig } from '@nuxt/test-utils/config'\n\nexport default defineVitestConfig({\n  test: {\n    environment: 'nuxt',\n    // you can optionally set Nuxt-specific environment options\n    // environmentOptions: {\n    //   nuxt: {\n    //     rootDir: fileURLToPath(new URL('./playground', import.meta.url)),\n    //     domEnvironment: 'happy-dom', // 'happy-dom' (default) or 'jsdom'\n    //     overrides: {\n    //       // other Nuxt config you want to pass\n    //     }\n    //   }\n    // }\n  },\n})\n",[2045,2788,2789,2808,2812,2824,2832,2847,2853,2858,2863,2868,2876,2881,2889,2894,2899,2904,2908],{"__ignoreMap":2123},[2127,2790,2791,2793,2795,2798,2800,2802,2804,2806],{"class":2129,"line":2130},[2127,2792,2359],{"class":2282},[2127,2794,2362],{"class":2297},[2127,2796,2797],{"class":2293}," defineVitestConfig",[2127,2799,2368],{"class":2297},[2127,2801,2371],{"class":2282},[2127,2803,2374],{"class":2297},[2127,2805,2398],{"class":2136},[2127,2807,2380],{"class":2297},[2127,2809,2810],{"class":2129,"line":2301},[2127,2811,2405],{"emptyLinePlaceholder":1196},[2127,2813,2814,2816,2818,2820,2822],{"class":2129,"line":2314},[2127,2815,2283],{"class":2282},[2127,2817,2286],{"class":2282},[2127,2819,2797],{"class":2289},[2127,2821,2294],{"class":2293},[2127,2823,2298],{"class":2297},[2127,2825,2826,2828,2830],{"class":2129,"line":2328},[2127,2827,2422],{"class":2304},[2127,2829,2308],{"class":2297},[2127,2831,2427],{"class":2297},[2127,2833,2834,2837,2839,2841,2843,2845],{"class":2129,"line":2336},[2127,2835,2836],{"class":2304},"    environment",[2127,2838,2308],{"class":2297},[2127,2840,2374],{"class":2297},[2127,2842,2630],{"class":2136},[2127,2844,2322],{"class":2297},[2127,2846,2325],{"class":2297},[2127,2848,2849],{"class":2129,"line":2430},[2127,2850,2852],{"class":2851},"sWuyu","    // you can optionally set Nuxt-specific environment options\n",[2127,2854,2855],{"class":2129,"line":2440},[2127,2856,2857],{"class":2851},"    // environmentOptions: {\n",[2127,2859,2860],{"class":2129,"line":2446},[2127,2861,2862],{"class":2851},"    //   nuxt: {\n",[2127,2864,2865],{"class":2129,"line":2456},[2127,2866,2867],{"class":2851},"    //     rootDir: fileURLToPath(new URL('./playground', import.meta.url)),\n",[2127,2869,2870,2873],{"class":2129,"line":2473},[2127,2871,2872],{"class":2851},"    //     domEnvironment: 'happy-dom',",[2127,2874,2875],{"class":2851}," // 'happy-dom' (default) or 'jsdom'\n",[2127,2877,2878],{"class":2129,"line":2496},[2127,2879,2880],{"class":2851},"    //     overrides: {\n",[2127,2882,2883,2886],{"class":2129,"line":2513},[2127,2884,2885],{"class":2851},"    //",[2127,2887,2888],{"class":2851},"       // other Nuxt config you want to pass\n",[2127,2890,2891],{"class":2129,"line":2519},[2127,2892,2893],{"class":2851},"    //     }\n",[2127,2895,2896],{"class":2129,"line":2525},[2127,2897,2898],{"class":2851},"    //   }\n",[2127,2900,2901],{"class":2129,"line":2530},[2127,2902,2903],{"class":2851},"    // }\n",[2127,2905,2906],{"class":2129,"line":2539},[2127,2907,2699],{"class":2297},[2127,2909,2910,2912],{"class":2129,"line":2555},[2127,2911,2339],{"class":2297},[2127,2913,2342],{"class":2293},[2033,2915,2916,2917,2920,2921,2924,2925,2930],{},"If you're using the simple setup with ",[2045,2918,2919],{},"environment: 'nuxt'"," by default, you can opt ",[2245,2922,2923],{},"out"," of the ",[2037,2926,2929],{"href":2927,"rel":2928},"https://vitest.dev/guide/environment.html#test-environment",[2053],"Nuxt environment"," per test file as needed.",[2117,2932,2934],{"className":2272,"code":2933,"language":2274,"meta":2275,"style":2123},"// @vitest-environment node\nimport { test } from 'vitest'\n\ntest('my test', () => {\n  // ... test without Nuxt environment!\n})\n",[2045,2935,2936,2941,2960,2964,2990,2995],{"__ignoreMap":2123},[2127,2937,2938],{"class":2129,"line":2130},[2127,2939,2940],{"class":2851},"// @vitest-environment node\n",[2127,2942,2943,2945,2947,2950,2952,2954,2956,2958],{"class":2129,"line":2301},[2127,2944,2359],{"class":2282},[2127,2946,2362],{"class":2297},[2127,2948,2949],{"class":2293}," test",[2127,2951,2368],{"class":2297},[2127,2953,2371],{"class":2282},[2127,2955,2374],{"class":2297},[2127,2957,2090],{"class":2136},[2127,2959,2380],{"class":2297},[2127,2961,2962],{"class":2129,"line":2314},[2127,2963,2405],{"emptyLinePlaceholder":1196},[2127,2965,2966,2969,2971,2973,2976,2978,2981,2984,2988],{"class":2129,"line":2328},[2127,2967,2968],{"class":2289},"test",[2127,2970,2294],{"class":2293},[2127,2972,2322],{"class":2297},[2127,2974,2975],{"class":2136},"my test",[2127,2977,2322],{"class":2297},[2127,2979,2980],{"class":2297},",",[2127,2982,2983],{"class":2297}," ()",[2127,2985,2987],{"class":2986},"smZ93"," =>",[2127,2989,2427],{"class":2297},[2127,2991,2992],{"class":2129,"line":2336},[2127,2993,2994],{"class":2851},"  // ... test without Nuxt environment!\n",[2127,2996,2997,2999],{"class":2129,"line":2430},[2127,2998,2339],{"class":2297},[2127,3000,2342],{"class":2293},[3002,3003,3004],"warning",{},[2033,3005,3006,3007,3010],{},"This approach is not recommended as it creates a hybrid environment where Nuxt Vite plugins run but the Nuxt entry and ",[2045,3008,3009],{},"nuxtApp"," are not initialized. This can lead to hard-to-debug errors.",[2252,3012,3014],{"id":3013},"organizing-your-tests","Organizing Your Tests",[2033,3016,3017],{},"With the project-based setup, you might organize your tests as follows:",[2117,3019,3022],{"className":2119,"code":3020,"filename":3021,"language":2122,"meta":2123,"style":2123},"test/\n├── e2e/\n│   └── ssr.test.ts\n├── nuxt/\n│   ├── components.test.ts\n│   └── composables.test.ts\n├── unit/\n│   └── utils.test.ts\n","Directory structure",[2045,3023,3024,3029,3037,3048,3055,3065,3074,3081],{"__ignoreMap":2123},[2127,3025,3026],{"class":2129,"line":2130},[2127,3027,3028],{"class":2133},"test/\n",[2127,3030,3031,3034],{"class":2129,"line":2301},[2127,3032,3033],{"class":2133},"├──",[2127,3035,3036],{"class":2136}," e2e/\n",[2127,3038,3039,3042,3045],{"class":2129,"line":2314},[2127,3040,3041],{"class":2133},"│",[2127,3043,3044],{"class":2136},"   └──",[2127,3046,3047],{"class":2136}," ssr.test.ts\n",[2127,3049,3050,3052],{"class":2129,"line":2328},[2127,3051,3033],{"class":2133},[2127,3053,3054],{"class":2136}," nuxt/\n",[2127,3056,3057,3059,3062],{"class":2129,"line":2336},[2127,3058,3041],{"class":2133},[2127,3060,3061],{"class":2136},"   ├──",[2127,3063,3064],{"class":2136}," components.test.ts\n",[2127,3066,3067,3069,3071],{"class":2129,"line":2430},[2127,3068,3041],{"class":2133},[2127,3070,3044],{"class":2136},[2127,3072,3073],{"class":2136}," composables.test.ts\n",[2127,3075,3076,3078],{"class":2129,"line":2440},[2127,3077,3033],{"class":2133},[2127,3079,3080],{"class":2136}," unit/\n",[2127,3082,3083,3085,3087],{"class":2129,"line":2446},[2127,3084,3041],{"class":2133},[2127,3086,3044],{"class":2136},[2127,3088,3089],{"class":2136}," utils.test.ts\n",[2033,3091,3092],{},"You can of course opt for any test structure, but keeping the Nuxt runtime environment separated from Nuxt end-to-end tests is important for test stability.",[2777,3094,3096],{"id":3095},"typescript-support-in-tests","TypeScript Support in Tests",[2033,3098,3099,3100,2081,3102,3105,3106,3110,3111,2091,3114,2091,3117,3120],{},"By default, test files in ",[2045,3101,2774],{},[2045,3103,3104],{},"tests/nuxt/"," directories are included in the ",[2037,3107,3109],{"href":3108},"/docs/4.x/guide/concepts/typescript#how-nuxt-uses-project-references","Nuxt app TypeScript context",". That means they will recognise Nuxt aliases (like ",[2045,3112,3113],{},"~/",[2045,3115,3116],{},"@/",[2045,3118,3119],{},"#imports",") and TypeScript will be aware of auto-imports that work in your Nuxt app.",[2030,3122,3123],{},[2033,3124,3125,3126,3128],{},"This matches the recommended structure where only tests that need the Nuxt runtime environment are placed in these directories. Unit tests in other directories like ",[2045,3127,2764],{}," can be added manually if needed.",[3130,3131,3133],"h5",{"id":3132},"adding-other-test-directories","Adding other test directories",[2033,3135,3136],{},"If you have tests in other directories that you will be running in the Nuxt Vitest environment, you can include them in the Nuxt app TypeScript context by adding them to your configuration:",[2117,3138,3140],{"className":2272,"code":3139,"filename":233,"language":2274,"meta":2123,"style":2123},"export default defineNuxtConfig({\n  typescript: {\n    tsConfig: {\n      include: [\n        // this path is relative to the generated .nuxt/tsconfig.json\n        '../test/other-nuxt-context/**/*',\n      ],\n    },\n  },\n})\n",[2045,3141,3142,3154,3163,3172,3181,3186,3198,3205,3210,3214],{"__ignoreMap":2123},[2127,3143,3144,3146,3148,3150,3152],{"class":2129,"line":2130},[2127,3145,2283],{"class":2282},[2127,3147,2286],{"class":2282},[2127,3149,2290],{"class":2289},[2127,3151,2294],{"class":2293},[2127,3153,2298],{"class":2297},[2127,3155,3156,3159,3161],{"class":2129,"line":2301},[2127,3157,3158],{"class":2304},"  typescript",[2127,3160,2308],{"class":2297},[2127,3162,2427],{"class":2297},[2127,3164,3165,3168,3170],{"class":2129,"line":2314},[2127,3166,3167],{"class":2304},"    tsConfig",[2127,3169,2308],{"class":2297},[2127,3171,2427],{"class":2297},[2127,3173,3174,3177,3179],{"class":2129,"line":2328},[2127,3175,3176],{"class":2304},"      include",[2127,3178,2308],{"class":2297},[2127,3180,2311],{"class":2293},[2127,3182,3183],{"class":2129,"line":2336},[2127,3184,3185],{"class":2851},"        // this path is relative to the generated .nuxt/tsconfig.json\n",[2127,3187,3188,3191,3194,3196],{"class":2129,"line":2430},[2127,3189,3190],{"class":2297},"        '",[2127,3192,3193],{"class":2136},"../test/other-nuxt-context/**/*",[2127,3195,2322],{"class":2297},[2127,3197,2325],{"class":2297},[2127,3199,3200,3203],{"class":2129,"line":2440},[2127,3201,3202],{"class":2293},"      ]",[2127,3204,2325],{"class":2297},[2127,3206,3207],{"class":2129,"line":2446},[2127,3208,3209],{"class":2297},"    },\n",[2127,3211,3212],{"class":2129,"line":2456},[2127,3213,2699],{"class":2297},[2127,3215,3216,3218],{"class":2129,"line":2473},[2127,3217,2339],{"class":2297},[2127,3219,2342],{"class":2293},[3221,3222,3223],"important",{},[2033,3224,3225,3226,3229],{},"Unit tests should not depend on Nuxt runtime features like auto-imports or composables. Only add TypeScript path alias support if your tests import from your source files (e.g., ",[2045,3227,3228],{},"~/utils/helpers","), not for Nuxt-specific features.",[2777,3231,3233],{"id":3232},"running-tests","Running Tests",[2033,3235,3236],{},"With the project setup, you can run different test suites:",[2117,3238,3240],{"className":2119,"code":3239,"language":2122,"meta":2123,"style":2123},"# Run all tests\nnpx vitest\n\n# Run only unit tests\nnpx vitest --project unit\n\n# Run only Nuxt tests\nnpx vitest --project nuxt\n\n# Run tests in watch mode\nnpx vitest --watch\n",[2045,3241,3242,3247,3255,3259,3264,3276,3280,3285,3296,3300,3305],{"__ignoreMap":2123},[2127,3243,3244],{"class":2129,"line":2130},[2127,3245,3246],{"class":2851},"# Run all tests\n",[2127,3248,3249,3252],{"class":2129,"line":2301},[2127,3250,3251],{"class":2133},"npx",[2127,3253,3254],{"class":2136}," vitest\n",[2127,3256,3257],{"class":2129,"line":2314},[2127,3258,2405],{"emptyLinePlaceholder":1196},[2127,3260,3261],{"class":2129,"line":2328},[2127,3262,3263],{"class":2851},"# Run only unit tests\n",[2127,3265,3266,3268,3270,3273],{"class":2129,"line":2336},[2127,3267,3251],{"class":2133},[2127,3269,2146],{"class":2136},[2127,3271,3272],{"class":2136}," --project",[2127,3274,3275],{"class":2136}," unit\n",[2127,3277,3278],{"class":2129,"line":2430},[2127,3279,2405],{"emptyLinePlaceholder":1196},[2127,3281,3282],{"class":2129,"line":2440},[2127,3283,3284],{"class":2851},"# Run only Nuxt tests\n",[2127,3286,3287,3289,3291,3293],{"class":2129,"line":2446},[2127,3288,3251],{"class":2133},[2127,3290,2146],{"class":2136},[2127,3292,3272],{"class":2136},[2127,3294,3295],{"class":2136}," nuxt\n",[2127,3297,3298],{"class":2129,"line":2456},[2127,3299,2405],{"emptyLinePlaceholder":1196},[2127,3301,3302],{"class":2129,"line":2473},[2127,3303,3304],{"class":2851},"# Run tests in watch mode\n",[2127,3306,3307,3309,3311],{"class":2129,"line":2496},[2127,3308,3251],{"class":2133},[2127,3310,2146],{"class":2136},[2127,3312,3313],{"class":2136}," --watch\n",[3002,3315,3316,3336],{},[2033,3317,3318,3319,3325,3326,3332,3333,3335],{},"When you run your tests within the Nuxt environment, they will be running in a ",[2037,3320,3323],{"href":3321,"rel":3322},"https://github.com/capricorn86/happy-dom",[2053],[2045,3324,2080],{}," or ",[2037,3327,3330],{"href":3328,"rel":3329},"https://github.com/jsdom/jsdom",[2053],[2045,3331,2084],{}," environment. Before your tests run, a global Nuxt app will be initialized (including, for example, running any plugins or code you've defined in your ",[2045,3334,219],{},").",[2033,3337,3338],{},"This means you should take particular care not to mutate the global state in your tests (or, if you need to, to reset it afterwards).",[2252,3340,3342],{"id":3341},"built-in-mocks","🎭 Built-In Mocks",[2033,3344,3345,3347],{},[2045,3346,2047],{}," provides some built-in mocks for the DOM environment.",[2777,3349,3351],{"id":3350},"intersectionobserver",[2045,3352,3353],{},"intersectionObserver",[2033,3355,3356,3357,3360],{},"Default ",[2045,3358,3359],{},"true",", creates a dummy class without any functionality for the IntersectionObserver API",[2777,3362,3364],{"id":3363},"indexeddb",[2045,3365,3366],{},"indexedDB",[2033,3368,3356,3369,3372,3373,3380],{},[2045,3370,3371],{},"false",", uses ",[2037,3374,3377],{"href":3375,"rel":3376},"https://github.com/dumbmatter/fakeIndexedDB",[2053],[2045,3378,3379],{},"fake-indexeddb"," to create a functional mock of the IndexedDB API",[2033,3382,3383,3384,3387,3388,3390],{},"These can be configured in the ",[2045,3385,3386],{},"environmentOptions"," section of your ",[2045,3389,2348],{}," file:",[2117,3392,3394],{"className":2272,"code":3393,"language":2274,"meta":2275,"style":2123},"import { defineVitestConfig } from '@nuxt/test-utils/config'\n\nexport default defineVitestConfig({\n  test: {\n    environmentOptions: {\n      nuxt: {\n        mock: {\n          intersectionObserver: true,\n          indexedDb: true,\n        },\n      },\n    },\n  },\n})\n",[2045,3395,3396,3414,3418,3430,3438,3447,3456,3465,3478,3489,3493,3497,3501,3505],{"__ignoreMap":2123},[2127,3397,3398,3400,3402,3404,3406,3408,3410,3412],{"class":2129,"line":2130},[2127,3399,2359],{"class":2282},[2127,3401,2362],{"class":2297},[2127,3403,2797],{"class":2293},[2127,3405,2368],{"class":2297},[2127,3407,2371],{"class":2282},[2127,3409,2374],{"class":2297},[2127,3411,2398],{"class":2136},[2127,3413,2380],{"class":2297},[2127,3415,3416],{"class":2129,"line":2301},[2127,3417,2405],{"emptyLinePlaceholder":1196},[2127,3419,3420,3422,3424,3426,3428],{"class":2129,"line":2314},[2127,3421,2283],{"class":2282},[2127,3423,2286],{"class":2282},[2127,3425,2797],{"class":2289},[2127,3427,2294],{"class":2293},[2127,3429,2298],{"class":2297},[2127,3431,3432,3434,3436],{"class":2129,"line":2328},[2127,3433,2422],{"class":2304},[2127,3435,2308],{"class":2297},[2127,3437,2427],{"class":2297},[2127,3439,3440,3443,3445],{"class":2129,"line":2336},[2127,3441,3442],{"class":2304},"    environmentOptions",[2127,3444,2308],{"class":2297},[2127,3446,2427],{"class":2297},[2127,3448,3449,3452,3454],{"class":2129,"line":2430},[2127,3450,3451],{"class":2304},"      nuxt",[2127,3453,2308],{"class":2297},[2127,3455,2427],{"class":2297},[2127,3457,3458,3461,3463],{"class":2129,"line":2440},[2127,3459,3460],{"class":2304},"        mock",[2127,3462,2308],{"class":2297},[2127,3464,2427],{"class":2297},[2127,3466,3467,3470,3472,3476],{"class":2129,"line":2446},[2127,3468,3469],{"class":2304},"          intersectionObserver",[2127,3471,2308],{"class":2297},[2127,3473,3475],{"class":3474},"sbKd-"," true",[2127,3477,2325],{"class":2297},[2127,3479,3480,3483,3485,3487],{"class":2129,"line":2456},[2127,3481,3482],{"class":2304},"          indexedDb",[2127,3484,2308],{"class":2297},[2127,3486,3475],{"class":3474},[2127,3488,2325],{"class":2297},[2127,3490,3491],{"class":2129,"line":2473},[2127,3492,2516],{"class":2297},[2127,3494,3495],{"class":2129,"line":2496},[2127,3496,2522],{"class":2297},[2127,3498,3499],{"class":2129,"line":2513},[2127,3500,3209],{"class":2297},[2127,3502,3503],{"class":2129,"line":2519},[2127,3504,2699],{"class":2297},[2127,3506,3507,3509],{"class":2129,"line":2525},[2127,3508,2339],{"class":2297},[2127,3510,2342],{"class":2293},[2252,3512,3514],{"id":3513},"️-helpers","🛠️ Helpers",[2033,3516,3517,3519],{},[2045,3518,2047],{}," provides a number of helpers to make testing Nuxt apps easier.",[2777,3521,3523],{"id":3522},"mountsuspended",[2045,3524,3525],{},"mountSuspended",[2033,3527,3528,3530],{},[2045,3529,3525],{}," allows you to mount any Vue component within the Nuxt environment, allowing async setup and access to injections from your Nuxt plugins.",[3532,3533,3534],"note",{},[2033,3535,3536,3537,3539,3540,3543,3544,3547,3548,3553],{},"Under the hood, ",[2045,3538,3525],{}," wraps ",[2045,3541,3542],{},"mount"," from ",[2045,3545,3546],{},"@vue/test-utils",", so you can check out ",[2037,3549,3552],{"href":3550,"rel":3551},"https://test-utils.vuejs.org/guide/",[2053],"the Vue Test Utils documentation"," for more on the options you can pass, and how to use this utility.",[2033,3555,3556],{},"For example:",[2117,3558,3560],{"className":2272,"code":3559,"language":2274,"meta":2275,"style":2123},"// @noErrors\nimport { expect, it } from 'vitest'\nimport type { Component } from 'vue'\n\ndeclare module '#components' {\n  export const SomeComponent: Component\n}\n// ---cut---\n// tests/components/SomeComponents.nuxt.spec.ts\nimport { mountSuspended } from '@nuxt/test-utils/runtime'\nimport { SomeComponent } from '#components'\n\nit('can mount some component', async () => {\n  const component = await mountSuspended(SomeComponent)\n  expect(component.text()).toMatchInlineSnapshot(\n    '\"This is an auto-imported component\"',\n  )\n})\n",[2045,3561,3562,3567,3587,3607,3611,3636,3659,3685,3696,3701],{"__ignoreMap":2123},[2127,3563,3564],{"class":2129,"line":2130},[2127,3565,3566],{"class":2851},"// tests/components/SomeComponents.nuxt.spec.ts\n",[2127,3568,3569,3571,3573,3576,3578,3580,3582,3585],{"class":2129,"line":2301},[2127,3570,2359],{"class":2282},[2127,3572,2362],{"class":2297},[2127,3574,3575],{"class":2293}," mountSuspended",[2127,3577,2368],{"class":2297},[2127,3579,2371],{"class":2282},[2127,3581,2374],{"class":2297},[2127,3583,3584],{"class":2136},"@nuxt/test-utils/runtime",[2127,3586,2380],{"class":2297},[2127,3588,3589,3591,3593,3596,3598,3600,3602,3605],{"class":2129,"line":2314},[2127,3590,2359],{"class":2282},[2127,3592,2362],{"class":2297},[2127,3594,3595],{"class":2293}," SomeComponent",[2127,3597,2368],{"class":2297},[2127,3599,2371],{"class":2282},[2127,3601,2374],{"class":2297},[2127,3603,3604],{"class":2136},"#components",[2127,3606,2380],{"class":2297},[2127,3608,3609],{"class":2129,"line":2328},[2127,3610,2405],{"emptyLinePlaceholder":1196},[2127,3612,3613,3616,3618,3620,3623,3625,3627,3630,3632,3634],{"class":2129,"line":2336},[2127,3614,3615],{"class":2289},"it",[2127,3617,2294],{"class":2293},[2127,3619,2322],{"class":2297},[2127,3621,3622],{"class":2136},"can mount some component",[2127,3624,2322],{"class":2297},[2127,3626,2980],{"class":2297},[2127,3628,3629],{"class":2986}," async",[2127,3631,2983],{"class":2297},[2127,3633,2987],{"class":2986},[2127,3635,2427],{"class":2297},[2127,3637,3638,3641,3644,3647,3650,3652,3654,3657],{"class":2129,"line":2430},[2127,3639,3640],{"class":2986},"  const",[2127,3642,3643],{"class":2293}," component",[2127,3645,3646],{"class":2297}," =",[2127,3648,3649],{"class":2282}," await",[2127,3651,3575],{"class":2289},[2127,3653,2294],{"class":2304},[2127,3655,3656],{"class":2293},"SomeComponent",[2127,3658,2342],{"class":2304},[2127,3660,3661,3664,3666,3669,3671,3674,3677,3679,3682],{"class":2129,"line":2440},[2127,3662,3663],{"class":2289},"  expect",[2127,3665,2294],{"class":2304},[2127,3667,3668],{"class":2293},"component",[2127,3670,2040],{"class":2297},[2127,3672,3673],{"class":2289},"text",[2127,3675,3676],{"class":2304},"())",[2127,3678,2040],{"class":2297},[2127,3680,3681],{"class":2289},"toMatchInlineSnapshot",[2127,3683,3684],{"class":2304},"(\n",[2127,3686,3687,3689,3692,3694],{"class":2129,"line":2446},[2127,3688,2317],{"class":2297},[2127,3690,3691],{"class":2136},"\"This is an auto-imported component\"",[2127,3693,2322],{"class":2297},[2127,3695,2325],{"class":2297},[2127,3697,3698],{"class":2129,"line":2456},[2127,3699,3700],{"class":2304},"  )\n",[2127,3702,3703,3705],{"class":2129,"line":2473},[2127,3704,2339],{"class":2297},[2127,3706,2342],{"class":2293},[2117,3708,3710],{"className":2272,"code":3709,"language":2274,"meta":2275,"style":2123},"// @noErrors\nimport { expect, it } from 'vitest'\n// ---cut---\n// tests/components/SomeComponents.nuxt.spec.ts\nimport { mountSuspended } from '@nuxt/test-utils/runtime'\nimport App from '~/app.vue'\n\n// tests/App.nuxt.spec.ts\nit('can also mount an app', async () => {\n  const component = await mountSuspended(App, { route: '/test' })\n  expect(component.html()).toMatchInlineSnapshot(`\n      \"\u003Cdiv>This is an auto-imported component\u003C/div>\n      \u003Cdiv> I am a global component \u003C/div>\n      \u003Cdiv>/\u003C/div>\n      \u003Ca href=\"/test\"> Test link \u003C/a>\"\n    `)\n})\n",[2045,3711,3712,3716,3734,3751,3755,3760,3783,3820,3844,3849,3854,3859,3864,3871],{"__ignoreMap":2123},[2127,3713,3714],{"class":2129,"line":2130},[2127,3715,3566],{"class":2851},[2127,3717,3718,3720,3722,3724,3726,3728,3730,3732],{"class":2129,"line":2301},[2127,3719,2359],{"class":2282},[2127,3721,2362],{"class":2297},[2127,3723,3575],{"class":2293},[2127,3725,2368],{"class":2297},[2127,3727,2371],{"class":2282},[2127,3729,2374],{"class":2297},[2127,3731,3584],{"class":2136},[2127,3733,2380],{"class":2297},[2127,3735,3736,3738,3741,3744,3746,3749],{"class":2129,"line":2314},[2127,3737,2359],{"class":2282},[2127,3739,3740],{"class":2293}," App ",[2127,3742,3743],{"class":2282},"from",[2127,3745,2374],{"class":2297},[2127,3747,3748],{"class":2136},"~/app.vue",[2127,3750,2380],{"class":2297},[2127,3752,3753],{"class":2129,"line":2328},[2127,3754,2405],{"emptyLinePlaceholder":1196},[2127,3756,3757],{"class":2129,"line":2336},[2127,3758,3759],{"class":2851},"// tests/App.nuxt.spec.ts\n",[2127,3761,3762,3764,3766,3768,3771,3773,3775,3777,3779,3781],{"class":2129,"line":2430},[2127,3763,3615],{"class":2289},[2127,3765,2294],{"class":2293},[2127,3767,2322],{"class":2297},[2127,3769,3770],{"class":2136},"can also mount an app",[2127,3772,2322],{"class":2297},[2127,3774,2980],{"class":2297},[2127,3776,3629],{"class":2986},[2127,3778,2983],{"class":2297},[2127,3780,2987],{"class":2986},[2127,3782,2427],{"class":2297},[2127,3784,3785,3787,3789,3791,3793,3795,3797,3800,3802,3804,3807,3809,3811,3814,3816,3818],{"class":2129,"line":2440},[2127,3786,3640],{"class":2986},[2127,3788,3643],{"class":2293},[2127,3790,3646],{"class":2297},[2127,3792,3649],{"class":2282},[2127,3794,3575],{"class":2289},[2127,3796,2294],{"class":2304},[2127,3798,3799],{"class":2293},"App",[2127,3801,2980],{"class":2297},[2127,3803,2362],{"class":2297},[2127,3805,3806],{"class":2304}," route",[2127,3808,2308],{"class":2297},[2127,3810,2374],{"class":2297},[2127,3812,3813],{"class":2136},"/test",[2127,3815,2322],{"class":2297},[2127,3817,2368],{"class":2297},[2127,3819,2342],{"class":2304},[2127,3821,3822,3824,3826,3828,3830,3833,3835,3837,3839,3841],{"class":2129,"line":2446},[2127,3823,3663],{"class":2289},[2127,3825,2294],{"class":2304},[2127,3827,3668],{"class":2293},[2127,3829,2040],{"class":2297},[2127,3831,3832],{"class":2289},"html",[2127,3834,3676],{"class":2304},[2127,3836,2040],{"class":2297},[2127,3838,3681],{"class":2289},[2127,3840,2294],{"class":2304},[2127,3842,3843],{"class":2297},"`\n",[2127,3845,3846],{"class":2129,"line":2456},[2127,3847,3848],{"class":2136},"      \"\u003Cdiv>This is an auto-imported component\u003C/div>\n",[2127,3850,3851],{"class":2129,"line":2473},[2127,3852,3853],{"class":2136},"      \u003Cdiv> I am a global component \u003C/div>\n",[2127,3855,3856],{"class":2129,"line":2496},[2127,3857,3858],{"class":2136},"      \u003Cdiv>/\u003C/div>\n",[2127,3860,3861],{"class":2129,"line":2513},[2127,3862,3863],{"class":2136},"      \u003Ca href=\"/test\"> Test link \u003C/a>\"\n",[2127,3865,3866,3869],{"class":2129,"line":2519},[2127,3867,3868],{"class":2297},"    `",[2127,3870,2342],{"class":2304},[2127,3872,3873,3875],{"class":2129,"line":2525},[2127,3874,2339],{"class":2297},[2127,3876,2342],{"class":2293},[2777,3878,3880],{"id":3879},"rendersuspended",[2045,3881,3882],{},"renderSuspended",[2033,3884,3885,3887,3888,3891],{},[2045,3886,3882],{}," allows you to render any Vue component within the Nuxt environment using ",[2045,3889,3890],{},"@testing-library/vue",", allowing async setup and access to injections from your Nuxt plugins.",[2033,3893,3894,3895,2081,3898,3901,3902,3906],{},"This should be used together with utilities from Testing Library, e.g. ",[2045,3896,3897],{},"screen",[2045,3899,3900],{},"fireEvent",". Install ",[2037,3903,3890],{"href":3904,"rel":3905},"https://testing-library.com/docs/vue-testing-library/intro/",[2053]," in your project to use these.",[2033,3908,3909,3910,2040],{},"Additionally, Testing Library also relies on testing globals for cleanup. You should turn these on in your ",[2037,3911,3914],{"href":3912,"rel":3913},"https://vitest.dev/config/globals",[2053],"Vitest config",[2033,3916,3917,3918,2040],{},"The passed in component will be rendered inside a ",[2045,3919,3920],{},"\u003Cdiv id=\"test-wrapper\">\u003C/div>",[2033,3922,3923],{},"Examples:",[2117,3925,3927],{"className":2272,"code":3926,"language":2274,"meta":2275,"style":2123},"// @noErrors\nimport { expect, it } from 'vitest'\nimport type { Component } from 'vue'\n\ndeclare module '#components' {\n  export const SomeComponent: Component\n}\n// ---cut---\n// tests/components/SomeComponents.nuxt.spec.ts\nimport { renderSuspended } from '@nuxt/test-utils/runtime'\nimport { SomeComponent } from '#components'\nimport { screen } from '@testing-library/vue'\n\nit('can render some component', async () => {\n  await renderSuspended(SomeComponent)\n  expect(screen.getByText('This is an auto-imported component')).toBeDefined()\n})\n",[2045,3928,3929,3933,3952,3970,3989,3993,4016,4029,4062],{"__ignoreMap":2123},[2127,3930,3931],{"class":2129,"line":2130},[2127,3932,3566],{"class":2851},[2127,3934,3935,3937,3939,3942,3944,3946,3948,3950],{"class":2129,"line":2301},[2127,3936,2359],{"class":2282},[2127,3938,2362],{"class":2297},[2127,3940,3941],{"class":2293}," renderSuspended",[2127,3943,2368],{"class":2297},[2127,3945,2371],{"class":2282},[2127,3947,2374],{"class":2297},[2127,3949,3584],{"class":2136},[2127,3951,2380],{"class":2297},[2127,3953,3954,3956,3958,3960,3962,3964,3966,3968],{"class":2129,"line":2314},[2127,3955,2359],{"class":2282},[2127,3957,2362],{"class":2297},[2127,3959,3595],{"class":2293},[2127,3961,2368],{"class":2297},[2127,3963,2371],{"class":2282},[2127,3965,2374],{"class":2297},[2127,3967,3604],{"class":2136},[2127,3969,2380],{"class":2297},[2127,3971,3972,3974,3976,3979,3981,3983,3985,3987],{"class":2129,"line":2328},[2127,3973,2359],{"class":2282},[2127,3975,2362],{"class":2297},[2127,3977,3978],{"class":2293}," screen",[2127,3980,2368],{"class":2297},[2127,3982,2371],{"class":2282},[2127,3984,2374],{"class":2297},[2127,3986,3890],{"class":2136},[2127,3988,2380],{"class":2297},[2127,3990,3991],{"class":2129,"line":2336},[2127,3992,2405],{"emptyLinePlaceholder":1196},[2127,3994,3995,3997,3999,4001,4004,4006,4008,4010,4012,4014],{"class":2129,"line":2430},[2127,3996,3615],{"class":2289},[2127,3998,2294],{"class":2293},[2127,4000,2322],{"class":2297},[2127,4002,4003],{"class":2136},"can render some component",[2127,4005,2322],{"class":2297},[2127,4007,2980],{"class":2297},[2127,4009,3629],{"class":2986},[2127,4011,2983],{"class":2297},[2127,4013,2987],{"class":2986},[2127,4015,2427],{"class":2297},[2127,4017,4018,4021,4023,4025,4027],{"class":2129,"line":2440},[2127,4019,4020],{"class":2282},"  await",[2127,4022,3941],{"class":2289},[2127,4024,2294],{"class":2304},[2127,4026,3656],{"class":2293},[2127,4028,2342],{"class":2304},[2127,4030,4031,4033,4035,4037,4039,4042,4044,4046,4049,4051,4054,4056,4059],{"class":2129,"line":2446},[2127,4032,3663],{"class":2289},[2127,4034,2294],{"class":2304},[2127,4036,3897],{"class":2293},[2127,4038,2040],{"class":2297},[2127,4040,4041],{"class":2289},"getByText",[2127,4043,2294],{"class":2304},[2127,4045,2322],{"class":2297},[2127,4047,4048],{"class":2136},"This is an auto-imported component",[2127,4050,2322],{"class":2297},[2127,4052,4053],{"class":2304},"))",[2127,4055,2040],{"class":2297},[2127,4057,4058],{"class":2289},"toBeDefined",[2127,4060,4061],{"class":2304},"()\n",[2127,4063,4064,4066],{"class":2129,"line":2456},[2127,4065,2339],{"class":2297},[2127,4067,2342],{"class":2293},[2117,4069,4071],{"className":2272,"code":4070,"language":2274,"meta":2275,"style":2123},"// @noErrors\nimport { expect, it } from 'vitest'\n// ---cut---\n// tests/App.nuxt.spec.ts\nimport { renderSuspended } from '@nuxt/test-utils/runtime'\nimport App from '~/app.vue'\n\nit('can also render an app', async () => {\n  const html = await renderSuspended(App, { route: '/test' })\n  expect(html).toMatchInlineSnapshot(`\n    \"\u003Cdiv id=\"test-wrapper\">\n      \u003Cdiv>This is an auto-imported component\u003C/div>\n      \u003Cdiv> I am a global component \u003C/div>\n      \u003Cdiv>Index page\u003C/div>\u003Ca href=\"/test\"> Test link \u003C/a>\n    \u003C/div>\"\n  `)\n})\n",[2045,4072,4073,4077,4095,4109,4113,4136,4171,4189,4194,4199,4203,4208,4213,4220],{"__ignoreMap":2123},[2127,4074,4075],{"class":2129,"line":2130},[2127,4076,3759],{"class":2851},[2127,4078,4079,4081,4083,4085,4087,4089,4091,4093],{"class":2129,"line":2301},[2127,4080,2359],{"class":2282},[2127,4082,2362],{"class":2297},[2127,4084,3941],{"class":2293},[2127,4086,2368],{"class":2297},[2127,4088,2371],{"class":2282},[2127,4090,2374],{"class":2297},[2127,4092,3584],{"class":2136},[2127,4094,2380],{"class":2297},[2127,4096,4097,4099,4101,4103,4105,4107],{"class":2129,"line":2314},[2127,4098,2359],{"class":2282},[2127,4100,3740],{"class":2293},[2127,4102,3743],{"class":2282},[2127,4104,2374],{"class":2297},[2127,4106,3748],{"class":2136},[2127,4108,2380],{"class":2297},[2127,4110,4111],{"class":2129,"line":2328},[2127,4112,2405],{"emptyLinePlaceholder":1196},[2127,4114,4115,4117,4119,4121,4124,4126,4128,4130,4132,4134],{"class":2129,"line":2336},[2127,4116,3615],{"class":2289},[2127,4118,2294],{"class":2293},[2127,4120,2322],{"class":2297},[2127,4122,4123],{"class":2136},"can also render an app",[2127,4125,2322],{"class":2297},[2127,4127,2980],{"class":2297},[2127,4129,3629],{"class":2986},[2127,4131,2983],{"class":2297},[2127,4133,2987],{"class":2986},[2127,4135,2427],{"class":2297},[2127,4137,4138,4140,4143,4145,4147,4149,4151,4153,4155,4157,4159,4161,4163,4165,4167,4169],{"class":2129,"line":2430},[2127,4139,3640],{"class":2986},[2127,4141,4142],{"class":2293}," html",[2127,4144,3646],{"class":2297},[2127,4146,3649],{"class":2282},[2127,4148,3941],{"class":2289},[2127,4150,2294],{"class":2304},[2127,4152,3799],{"class":2293},[2127,4154,2980],{"class":2297},[2127,4156,2362],{"class":2297},[2127,4158,3806],{"class":2304},[2127,4160,2308],{"class":2297},[2127,4162,2374],{"class":2297},[2127,4164,3813],{"class":2136},[2127,4166,2322],{"class":2297},[2127,4168,2368],{"class":2297},[2127,4170,2342],{"class":2304},[2127,4172,4173,4175,4177,4179,4181,4183,4185,4187],{"class":2129,"line":2440},[2127,4174,3663],{"class":2289},[2127,4176,2294],{"class":2304},[2127,4178,3832],{"class":2293},[2127,4180,2683],{"class":2304},[2127,4182,2040],{"class":2297},[2127,4184,3681],{"class":2289},[2127,4186,2294],{"class":2304},[2127,4188,3843],{"class":2297},[2127,4190,4191],{"class":2129,"line":2446},[2127,4192,4193],{"class":2136},"    \"\u003Cdiv id=\"test-wrapper\">\n",[2127,4195,4196],{"class":2129,"line":2456},[2127,4197,4198],{"class":2136},"      \u003Cdiv>This is an auto-imported component\u003C/div>\n",[2127,4200,4201],{"class":2129,"line":2473},[2127,4202,3853],{"class":2136},[2127,4204,4205],{"class":2129,"line":2496},[2127,4206,4207],{"class":2136},"      \u003Cdiv>Index page\u003C/div>\u003Ca href=\"/test\"> Test link \u003C/a>\n",[2127,4209,4210],{"class":2129,"line":2513},[2127,4211,4212],{"class":2136},"    \u003C/div>\"\n",[2127,4214,4215,4218],{"class":2129,"line":2519},[2127,4216,4217],{"class":2297},"  `",[2127,4219,2342],{"class":2304},[2127,4221,4222,4224],{"class":2129,"line":2525},[2127,4223,2339],{"class":2297},[2127,4225,2342],{"class":2293},[2777,4227,4229],{"id":4228},"mocknuxtimport",[2045,4230,4231],{},"mockNuxtImport",[2033,4233,4234,4236,4237,4240],{},[2045,4235,4231],{}," allows you to mock Nuxt's auto import functionality. For example, to mock ",[2045,4238,4239],{},"useStorage",", you can do so like this:",[2117,4242,4244],{"className":2272,"code":4243,"language":2274,"meta":2275,"style":2123},"import { mockNuxtImport } from '@nuxt/test-utils/runtime'\n\nmockNuxtImport('useStorage', () => {\n  return () => {\n    return { value: 'mocked storage' }\n  }\n})\n\n// your tests here\n",[2045,4245,4246,4265,4269,4289,4300,4322,4327,4333,4337],{"__ignoreMap":2123},[2127,4247,4248,4250,4252,4255,4257,4259,4261,4263],{"class":2129,"line":2130},[2127,4249,2359],{"class":2282},[2127,4251,2362],{"class":2297},[2127,4253,4254],{"class":2293}," mockNuxtImport",[2127,4256,2368],{"class":2297},[2127,4258,2371],{"class":2282},[2127,4260,2374],{"class":2297},[2127,4262,3584],{"class":2136},[2127,4264,2380],{"class":2297},[2127,4266,4267],{"class":2129,"line":2301},[2127,4268,2405],{"emptyLinePlaceholder":1196},[2127,4270,4271,4273,4275,4277,4279,4281,4283,4285,4287],{"class":2129,"line":2314},[2127,4272,4231],{"class":2289},[2127,4274,2294],{"class":2293},[2127,4276,2322],{"class":2297},[2127,4278,4239],{"class":2136},[2127,4280,2322],{"class":2297},[2127,4282,2980],{"class":2297},[2127,4284,2983],{"class":2297},[2127,4286,2987],{"class":2986},[2127,4288,2427],{"class":2297},[2127,4290,4291,4294,4296,4298],{"class":2129,"line":2328},[2127,4292,4293],{"class":2282},"  return",[2127,4295,2983],{"class":2297},[2127,4297,2987],{"class":2986},[2127,4299,2427],{"class":2297},[2127,4301,4302,4305,4307,4310,4312,4314,4317,4319],{"class":2129,"line":2336},[2127,4303,4304],{"class":2282},"    return",[2127,4306,2362],{"class":2297},[2127,4308,4309],{"class":2304}," value",[2127,4311,2308],{"class":2297},[2127,4313,2374],{"class":2297},[2127,4315,4316],{"class":2136},"mocked storage",[2127,4318,2322],{"class":2297},[2127,4320,4321],{"class":2297}," }\n",[2127,4323,4324],{"class":2129,"line":2430},[2127,4325,4326],{"class":2297},"  }\n",[2127,4328,4329,4331],{"class":2129,"line":2440},[2127,4330,2339],{"class":2297},[2127,4332,2342],{"class":2293},[2127,4334,4335],{"class":2129,"line":2446},[2127,4336,2405],{"emptyLinePlaceholder":1196},[2127,4338,4339],{"class":2129,"line":2456},[2127,4340,4341],{"class":2851},"// your tests here\n",[3532,4343,4344],{},[2033,4345,4346,4348,4349,2081,4352,4354,4355,2040],{},[2045,4347,4231],{}," can only be used once per mocked import per test file. It is actually a macro that gets transformed to ",[2045,4350,4351],{},"vi.mock",[2045,4353,4351],{}," is hoisted, as described ",[2037,4356,4359],{"href":4357,"rel":4358},"https://vitest.dev/api/vi#vi-mock",[2053],"in the Vitest docs",[2033,4361,4362,4363,4370,4371,4373,4374,4379],{},"If you need to mock a Nuxt import and provide different implementations between tests, you can do it by creating and exposing your mocks using ",[2037,4364,4367],{"href":4365,"rel":4366},"https://vitest.dev/api/vi#vi-hoisted",[2053],[2045,4368,4369],{},"vi.hoisted",", and then use those mocks in ",[2045,4372,4231],{},". You then have access to the mocked imports, and can change the implementation between tests. Be careful to ",[2037,4375,4378],{"href":4376,"rel":4377},"https://vitest.dev/api/mock#mockrestore",[2053],"restore mocks"," before or after each test to undo mock state changes between runs.",[2117,4381,4383],{"className":2272,"code":4382,"language":2274,"meta":2275,"style":2123},"import { vi } from 'vitest'\nimport { mockNuxtImport } from '@nuxt/test-utils/runtime'\n\nconst { useStorageMock } = vi.hoisted(() => {\n  return {\n    useStorageMock: vi.fn(() => {\n      return { value: 'mocked storage' }\n    }),\n  }\n})\n\nmockNuxtImport('useStorage', () => {\n  return useStorageMock\n})\n\n// Then, inside a test\nuseStorageMock.mockImplementation(() => {\n  return { value: 'something else' }\n})\n",[2045,4384,4385,4404,4422,4426,4456,4462,4484,4503,4512,4516,4522,4526,4546,4553,4559,4563,4568,4586,4605],{"__ignoreMap":2123},[2127,4386,4387,4389,4391,4394,4396,4398,4400,4402],{"class":2129,"line":2130},[2127,4388,2359],{"class":2282},[2127,4390,2362],{"class":2297},[2127,4392,4393],{"class":2293}," vi",[2127,4395,2368],{"class":2297},[2127,4397,2371],{"class":2282},[2127,4399,2374],{"class":2297},[2127,4401,2090],{"class":2136},[2127,4403,2380],{"class":2297},[2127,4405,4406,4408,4410,4412,4414,4416,4418,4420],{"class":2129,"line":2301},[2127,4407,2359],{"class":2282},[2127,4409,2362],{"class":2297},[2127,4411,4254],{"class":2293},[2127,4413,2368],{"class":2297},[2127,4415,2371],{"class":2282},[2127,4417,2374],{"class":2297},[2127,4419,3584],{"class":2136},[2127,4421,2380],{"class":2297},[2127,4423,4424],{"class":2129,"line":2314},[2127,4425,2405],{"emptyLinePlaceholder":1196},[2127,4427,4428,4431,4433,4436,4438,4440,4442,4444,4447,4449,4452,4454],{"class":2129,"line":2328},[2127,4429,4430],{"class":2986},"const",[2127,4432,2362],{"class":2297},[2127,4434,4435],{"class":2293}," useStorageMock ",[2127,4437,2339],{"class":2297},[2127,4439,3646],{"class":2297},[2127,4441,4393],{"class":2293},[2127,4443,2040],{"class":2297},[2127,4445,4446],{"class":2289},"hoisted",[2127,4448,2294],{"class":2293},[2127,4450,4451],{"class":2297},"()",[2127,4453,2987],{"class":2986},[2127,4455,2427],{"class":2297},[2127,4457,4458,4460],{"class":2129,"line":2336},[2127,4459,4293],{"class":2282},[2127,4461,2427],{"class":2297},[2127,4463,4464,4467,4469,4471,4473,4476,4478,4480,4482],{"class":2129,"line":2430},[2127,4465,4466],{"class":2304},"    useStorageMock",[2127,4468,2308],{"class":2297},[2127,4470,4393],{"class":2293},[2127,4472,2040],{"class":2297},[2127,4474,4475],{"class":2289},"fn",[2127,4477,2294],{"class":2304},[2127,4479,4451],{"class":2297},[2127,4481,2987],{"class":2986},[2127,4483,2427],{"class":2297},[2127,4485,4486,4489,4491,4493,4495,4497,4499,4501],{"class":2129,"line":2440},[2127,4487,4488],{"class":2282},"      return",[2127,4490,2362],{"class":2297},[2127,4492,4309],{"class":2304},[2127,4494,2308],{"class":2297},[2127,4496,2374],{"class":2297},[2127,4498,4316],{"class":2136},[2127,4500,2322],{"class":2297},[2127,4502,4321],{"class":2297},[2127,4504,4505,4508,4510],{"class":2129,"line":2446},[2127,4506,4507],{"class":2297},"    }",[2127,4509,2683],{"class":2304},[2127,4511,2325],{"class":2297},[2127,4513,4514],{"class":2129,"line":2456},[2127,4515,4326],{"class":2297},[2127,4517,4518,4520],{"class":2129,"line":2473},[2127,4519,2339],{"class":2297},[2127,4521,2342],{"class":2293},[2127,4523,4524],{"class":2129,"line":2496},[2127,4525,2405],{"emptyLinePlaceholder":1196},[2127,4527,4528,4530,4532,4534,4536,4538,4540,4542,4544],{"class":2129,"line":2513},[2127,4529,4231],{"class":2289},[2127,4531,2294],{"class":2293},[2127,4533,2322],{"class":2297},[2127,4535,4239],{"class":2136},[2127,4537,2322],{"class":2297},[2127,4539,2980],{"class":2297},[2127,4541,2983],{"class":2297},[2127,4543,2987],{"class":2986},[2127,4545,2427],{"class":2297},[2127,4547,4548,4550],{"class":2129,"line":2519},[2127,4549,4293],{"class":2282},[2127,4551,4552],{"class":2293}," useStorageMock\n",[2127,4554,4555,4557],{"class":2129,"line":2525},[2127,4556,2339],{"class":2297},[2127,4558,2342],{"class":2293},[2127,4560,4561],{"class":2129,"line":2530},[2127,4562,2405],{"emptyLinePlaceholder":1196},[2127,4564,4565],{"class":2129,"line":2539},[2127,4566,4567],{"class":2851},"// Then, inside a test\n",[2127,4569,4570,4573,4575,4578,4580,4582,4584],{"class":2129,"line":2555},[2127,4571,4572],{"class":2293},"useStorageMock",[2127,4574,2040],{"class":2297},[2127,4576,4577],{"class":2289},"mockImplementation",[2127,4579,2294],{"class":2293},[2127,4581,4451],{"class":2297},[2127,4583,2987],{"class":2986},[2127,4585,2427],{"class":2297},[2127,4587,4588,4590,4592,4594,4596,4598,4601,4603],{"class":2129,"line":2575},[2127,4589,4293],{"class":2282},[2127,4591,2362],{"class":2297},[2127,4593,4309],{"class":2304},[2127,4595,2308],{"class":2297},[2127,4597,2374],{"class":2297},[2127,4599,4600],{"class":2136},"something else",[2127,4602,2322],{"class":2297},[2127,4604,4321],{"class":2297},[2127,4606,4607,4609],{"class":2129,"line":2590},[2127,4608,2339],{"class":2297},[2127,4610,2342],{"class":2293},[2777,4612,4614],{"id":4613},"mockcomponent",[2045,4615,4616],{},"mockComponent",[2033,4618,4619,4621],{},[2045,4620,4616],{}," allows you to mock Nuxt's component.\nThe first argument can be the component name in PascalCase, or the relative path of the component.\nThe second argument is a factory function that returns the mocked component.",[2033,4623,4624,4625,4628],{},"For example, to mock ",[2045,4626,4627],{},"MyComponent",", you can:",[2117,4630,4632],{"className":2272,"code":4631,"language":2274,"meta":2275,"style":2123},"import { mockComponent } from '@nuxt/test-utils/runtime'\n\nmockComponent('MyComponent', {\n  props: {\n    value: String,\n  },\n  setup (props) {\n    // ...\n  },\n})\n\n// relative path or alias also works\nmockComponent('~/components/my-component.vue', () => {\n  // or a factory function\n  return defineComponent({\n    setup (props) {\n      // ...\n    },\n  })\n})\n\n// or you can use SFC for redirecting to a mock component\nmockComponent('MyComponent', () => import('./MockComponent.vue'))\n\n// your tests here\n",[2045,4633,4634,4653,4657,4673,4682,4694,4698,4714,4719,4723,4729,4733,4738,4759,4764,4775,4788,4793,4797,4804,4810,4814,4819,4852,4856],{"__ignoreMap":2123},[2127,4635,4636,4638,4640,4643,4645,4647,4649,4651],{"class":2129,"line":2130},[2127,4637,2359],{"class":2282},[2127,4639,2362],{"class":2297},[2127,4641,4642],{"class":2293}," mockComponent",[2127,4644,2368],{"class":2297},[2127,4646,2371],{"class":2282},[2127,4648,2374],{"class":2297},[2127,4650,3584],{"class":2136},[2127,4652,2380],{"class":2297},[2127,4654,4655],{"class":2129,"line":2301},[2127,4656,2405],{"emptyLinePlaceholder":1196},[2127,4658,4659,4661,4663,4665,4667,4669,4671],{"class":2129,"line":2314},[2127,4660,4616],{"class":2289},[2127,4662,2294],{"class":2293},[2127,4664,2322],{"class":2297},[2127,4666,4627],{"class":2136},[2127,4668,2322],{"class":2297},[2127,4670,2980],{"class":2297},[2127,4672,2427],{"class":2297},[2127,4674,4675,4678,4680],{"class":2129,"line":2328},[2127,4676,4677],{"class":2304},"  props",[2127,4679,2308],{"class":2297},[2127,4681,2427],{"class":2297},[2127,4683,4684,4687,4689,4692],{"class":2129,"line":2336},[2127,4685,4686],{"class":2304},"    value",[2127,4688,2308],{"class":2297},[2127,4690,4691],{"class":2293}," String",[2127,4693,2325],{"class":2297},[2127,4695,4696],{"class":2129,"line":2430},[2127,4697,2699],{"class":2297},[2127,4699,4700,4703,4706,4710,4712],{"class":2129,"line":2440},[2127,4701,4702],{"class":2304},"  setup",[2127,4704,4705],{"class":2297}," (",[2127,4707,4709],{"class":4708},"s1nJG","props",[2127,4711,2683],{"class":2297},[2127,4713,2427],{"class":2297},[2127,4715,4716],{"class":2129,"line":2446},[2127,4717,4718],{"class":2851},"    // ...\n",[2127,4720,4721],{"class":2129,"line":2456},[2127,4722,2699],{"class":2297},[2127,4724,4725,4727],{"class":2129,"line":2473},[2127,4726,2339],{"class":2297},[2127,4728,2342],{"class":2293},[2127,4730,4731],{"class":2129,"line":2496},[2127,4732,2405],{"emptyLinePlaceholder":1196},[2127,4734,4735],{"class":2129,"line":2513},[2127,4736,4737],{"class":2851},"// relative path or alias also works\n",[2127,4739,4740,4742,4744,4746,4749,4751,4753,4755,4757],{"class":2129,"line":2519},[2127,4741,4616],{"class":2289},[2127,4743,2294],{"class":2293},[2127,4745,2322],{"class":2297},[2127,4747,4748],{"class":2136},"~/components/my-component.vue",[2127,4750,2322],{"class":2297},[2127,4752,2980],{"class":2297},[2127,4754,2983],{"class":2297},[2127,4756,2987],{"class":2986},[2127,4758,2427],{"class":2297},[2127,4760,4761],{"class":2129,"line":2525},[2127,4762,4763],{"class":2851},"  // or a factory function\n",[2127,4765,4766,4768,4771,4773],{"class":2129,"line":2530},[2127,4767,4293],{"class":2282},[2127,4769,4770],{"class":2289}," defineComponent",[2127,4772,2294],{"class":2304},[2127,4774,2298],{"class":2297},[2127,4776,4777,4780,4782,4784,4786],{"class":2129,"line":2539},[2127,4778,4779],{"class":2304},"    setup ",[2127,4781,2294],{"class":2297},[2127,4783,4709],{"class":4708},[2127,4785,2683],{"class":2297},[2127,4787,2427],{"class":2297},[2127,4789,4790],{"class":2129,"line":2555},[2127,4791,4792],{"class":2851},"      // ...\n",[2127,4794,4795],{"class":2129,"line":2575},[2127,4796,3209],{"class":2297},[2127,4798,4799,4802],{"class":2129,"line":2590},[2127,4800,4801],{"class":2297},"  }",[2127,4803,2342],{"class":2304},[2127,4805,4806,4808],{"class":2129,"line":2595},[2127,4807,2339],{"class":2297},[2127,4809,2342],{"class":2293},[2127,4811,4812],{"class":2129,"line":2600},[2127,4813,2405],{"emptyLinePlaceholder":1196},[2127,4815,4816],{"class":2129,"line":2612},[2127,4817,4818],{"class":2851},"// or you can use SFC for redirecting to a mock component\n",[2127,4820,4821,4823,4825,4827,4829,4831,4833,4835,4837,4840,4842,4844,4847,4849],{"class":2129,"line":2621},[2127,4822,4616],{"class":2289},[2127,4824,2294],{"class":2293},[2127,4826,2322],{"class":2297},[2127,4828,4627],{"class":2136},[2127,4830,2322],{"class":2297},[2127,4832,2980],{"class":2297},[2127,4834,2983],{"class":2297},[2127,4836,2987],{"class":2986},[2127,4838,4839],{"class":2297}," import",[2127,4841,2294],{"class":2293},[2127,4843,2322],{"class":2297},[2127,4845,4846],{"class":2136},"./MockComponent.vue",[2127,4848,2322],{"class":2297},[2127,4850,4851],{"class":2293},"))\n",[2127,4853,4854],{"class":2129,"line":2637},[2127,4855,2405],{"emptyLinePlaceholder":1196},[2127,4857,4858],{"class":2129,"line":2657},[2127,4859,4341],{"class":2851},[2723,4861,4862],{},[2033,4863,4864,4867],{},[2758,4865,4866],{},"Note",": You can't reference local variables in the factory function since they are hoisted. If you need to access Vue APIs or other variables, you need to import them in your factory function.",[2117,4869,4871],{"className":2272,"code":4870,"language":2274,"meta":2275,"style":2123},"import { mockComponent } from '@nuxt/test-utils/runtime'\n\nmockComponent('MyComponent', async () => {\n  const { ref, h } = await import('vue')\n\n  return defineComponent({\n    setup (props) {\n      const counter = ref(0)\n      return () => h('div', null, counter.value)\n    },\n  })\n})\n",[2045,4872,4873,4891,4895,4917,4950,4954,4964,4976,4996,5029,5033,5039],{"__ignoreMap":2123},[2127,4874,4875,4877,4879,4881,4883,4885,4887,4889],{"class":2129,"line":2130},[2127,4876,2359],{"class":2282},[2127,4878,2362],{"class":2297},[2127,4880,4642],{"class":2293},[2127,4882,2368],{"class":2297},[2127,4884,2371],{"class":2282},[2127,4886,2374],{"class":2297},[2127,4888,3584],{"class":2136},[2127,4890,2380],{"class":2297},[2127,4892,4893],{"class":2129,"line":2301},[2127,4894,2405],{"emptyLinePlaceholder":1196},[2127,4896,4897,4899,4901,4903,4905,4907,4909,4911,4913,4915],{"class":2129,"line":2314},[2127,4898,4616],{"class":2289},[2127,4900,2294],{"class":2293},[2127,4902,2322],{"class":2297},[2127,4904,4627],{"class":2136},[2127,4906,2322],{"class":2297},[2127,4908,2980],{"class":2297},[2127,4910,3629],{"class":2986},[2127,4912,2983],{"class":2297},[2127,4914,2987],{"class":2986},[2127,4916,2427],{"class":2297},[2127,4918,4919,4921,4923,4926,4928,4931,4933,4935,4937,4939,4941,4943,4946,4948],{"class":2129,"line":2328},[2127,4920,3640],{"class":2986},[2127,4922,2362],{"class":2297},[2127,4924,4925],{"class":2293}," ref",[2127,4927,2980],{"class":2297},[2127,4929,4930],{"class":2293}," h",[2127,4932,2368],{"class":2297},[2127,4934,3646],{"class":2297},[2127,4936,3649],{"class":2282},[2127,4938,4839],{"class":2297},[2127,4940,2294],{"class":2304},[2127,4942,2322],{"class":2297},[2127,4944,4945],{"class":2136},"vue",[2127,4947,2322],{"class":2297},[2127,4949,2342],{"class":2304},[2127,4951,4952],{"class":2129,"line":2336},[2127,4953,2405],{"emptyLinePlaceholder":1196},[2127,4955,4956,4958,4960,4962],{"class":2129,"line":2430},[2127,4957,4293],{"class":2282},[2127,4959,4770],{"class":2289},[2127,4961,2294],{"class":2304},[2127,4963,2298],{"class":2297},[2127,4965,4966,4968,4970,4972,4974],{"class":2129,"line":2440},[2127,4967,4779],{"class":2304},[2127,4969,2294],{"class":2297},[2127,4971,4709],{"class":4708},[2127,4973,2683],{"class":2297},[2127,4975,2427],{"class":2297},[2127,4977,4978,4981,4984,4986,4988,4990,4994],{"class":2129,"line":2446},[2127,4979,4980],{"class":2986},"      const",[2127,4982,4983],{"class":2293}," counter",[2127,4985,3646],{"class":2297},[2127,4987,4925],{"class":2289},[2127,4989,2294],{"class":2304},[2127,4991,4993],{"class":4992},"sYRBq","0",[2127,4995,2342],{"class":2304},[2127,4997,4998,5000,5002,5004,5006,5008,5010,5013,5015,5017,5020,5022,5024,5027],{"class":2129,"line":2456},[2127,4999,4488],{"class":2282},[2127,5001,2983],{"class":2297},[2127,5003,2987],{"class":2986},[2127,5005,4930],{"class":2289},[2127,5007,2294],{"class":2304},[2127,5009,2322],{"class":2297},[2127,5011,5012],{"class":2136},"div",[2127,5014,2322],{"class":2297},[2127,5016,2980],{"class":2297},[2127,5018,5019],{"class":2297}," null,",[2127,5021,4983],{"class":2293},[2127,5023,2040],{"class":2297},[2127,5025,5026],{"class":2293},"value",[2127,5028,2342],{"class":2304},[2127,5030,5031],{"class":2129,"line":2473},[2127,5032,3209],{"class":2297},[2127,5034,5035,5037],{"class":2129,"line":2496},[2127,5036,4801],{"class":2297},[2127,5038,2342],{"class":2304},[2127,5040,5041,5043],{"class":2129,"line":2513},[2127,5042,2339],{"class":2297},[2127,5044,2342],{"class":2293},[2777,5046,5048],{"id":5047},"registerendpoint",[2045,5049,5050],{},"registerEndpoint",[2033,5052,5053,5055],{},[2045,5054,5050],{}," allows you create Nitro endpoint that returns mocked data. It can come in handy if you want to test a component that makes requests to API to display some data.",[2033,5057,5058,5059,5062],{},"The first argument is the endpoint name (e.g. ",[2045,5060,5061],{},"/test/",").\nThe second argument is a factory function that returns the mocked data.",[2033,5064,4624,5065,5067],{},[2045,5066,5061],{}," endpoint, you can do:",[2117,5069,5071],{"className":2272,"code":5070,"language":2274,"meta":2275,"style":2123},"import { registerEndpoint } from '@nuxt/test-utils/runtime'\n\nregisterEndpoint('/test/', () => ({\n  test: 'test-field',\n}))\n",[2045,5072,5073,5092,5096,5118,5133],{"__ignoreMap":2123},[2127,5074,5075,5077,5079,5082,5084,5086,5088,5090],{"class":2129,"line":2130},[2127,5076,2359],{"class":2282},[2127,5078,2362],{"class":2297},[2127,5080,5081],{"class":2293}," registerEndpoint",[2127,5083,2368],{"class":2297},[2127,5085,2371],{"class":2282},[2127,5087,2374],{"class":2297},[2127,5089,3584],{"class":2136},[2127,5091,2380],{"class":2297},[2127,5093,5094],{"class":2129,"line":2301},[2127,5095,2405],{"emptyLinePlaceholder":1196},[2127,5097,5098,5100,5102,5104,5106,5108,5110,5112,5114,5116],{"class":2129,"line":2314},[2127,5099,5050],{"class":2289},[2127,5101,2294],{"class":2293},[2127,5103,2322],{"class":2297},[2127,5105,5061],{"class":2136},[2127,5107,2322],{"class":2297},[2127,5109,2980],{"class":2297},[2127,5111,2983],{"class":2297},[2127,5113,2987],{"class":2986},[2127,5115,4705],{"class":2293},[2127,5117,2298],{"class":2297},[2127,5119,5120,5122,5124,5126,5129,5131],{"class":2129,"line":2328},[2127,5121,2422],{"class":2304},[2127,5123,2308],{"class":2297},[2127,5125,2374],{"class":2297},[2127,5127,5128],{"class":2136},"test-field",[2127,5130,2322],{"class":2297},[2127,5132,2325],{"class":2297},[2127,5134,5135,5137],{"class":2129,"line":2336},[2127,5136,2339],{"class":2297},[2127,5138,4851],{"class":2293},[2033,5140,5141,5142,5145],{},"By default, your request will be made using the ",[2045,5143,5144],{},"GET"," method. You may use another method by setting an object as the second argument instead of a function.",[2117,5147,5149],{"className":2272,"code":5148,"language":2274,"meta":2275,"style":2123},"import { registerEndpoint } from '@nuxt/test-utils/runtime'\n\nregisterEndpoint('/test/', {\n  method: 'POST',\n  handler: () => ({ test: 'test-field' }),\n})\n",[2045,5150,5151,5169,5173,5189,5205,5237],{"__ignoreMap":2123},[2127,5152,5153,5155,5157,5159,5161,5163,5165,5167],{"class":2129,"line":2130},[2127,5154,2359],{"class":2282},[2127,5156,2362],{"class":2297},[2127,5158,5081],{"class":2293},[2127,5160,2368],{"class":2297},[2127,5162,2371],{"class":2282},[2127,5164,2374],{"class":2297},[2127,5166,3584],{"class":2136},[2127,5168,2380],{"class":2297},[2127,5170,5171],{"class":2129,"line":2301},[2127,5172,2405],{"emptyLinePlaceholder":1196},[2127,5174,5175,5177,5179,5181,5183,5185,5187],{"class":2129,"line":2314},[2127,5176,5050],{"class":2289},[2127,5178,2294],{"class":2293},[2127,5180,2322],{"class":2297},[2127,5182,5061],{"class":2136},[2127,5184,2322],{"class":2297},[2127,5186,2980],{"class":2297},[2127,5188,2427],{"class":2297},[2127,5190,5191,5194,5196,5198,5201,5203],{"class":2129,"line":2328},[2127,5192,5193],{"class":2304},"  method",[2127,5195,2308],{"class":2297},[2127,5197,2374],{"class":2297},[2127,5199,5200],{"class":2136},"POST",[2127,5202,2322],{"class":2297},[2127,5204,2325],{"class":2297},[2127,5206,5207,5210,5212,5214,5216,5218,5221,5223,5225,5227,5229,5231,5233,5235],{"class":2129,"line":2336},[2127,5208,5209],{"class":2289},"  handler",[2127,5211,2308],{"class":2297},[2127,5213,2983],{"class":2297},[2127,5215,2987],{"class":2986},[2127,5217,4705],{"class":2293},[2127,5219,5220],{"class":2297},"{",[2127,5222,2949],{"class":2304},[2127,5224,2308],{"class":2297},[2127,5226,2374],{"class":2297},[2127,5228,5128],{"class":2136},[2127,5230,2322],{"class":2297},[2127,5232,2368],{"class":2297},[2127,5234,2683],{"class":2293},[2127,5236,2325],{"class":2297},[2127,5238,5239,5241],{"class":2129,"line":2430},[2127,5240,2339],{"class":2297},[2127,5242,2342],{"class":2293},[2723,5244,5245],{},[2033,5246,5247,5249,5250,5253,5254,4705,5258,5261],{},[2758,5248,4866],{},": If your requests in a component go to an external API, you can use ",[2045,5251,5252],{},"baseURL"," and then make it empty using ",[2037,5255,5257],{"href":5256},"/docs/4.x/getting-started/configuration#environment-overrides","Nuxt Environment Override Config",[2045,5259,5260],{},"$test",") so all your requests will go to Nitro server.",[2777,5263,5265],{"id":5264},"conflict-with-end-to-end-testing","Conflict with End-To-End Testing",[2033,5267,5268,2081,5270,5273],{},[2045,5269,3584],{},[2045,5271,5272],{},"@nuxt/test-utils/e2e"," need to run in different testing environments and so can't be used in the same file.",[2033,5275,5276,5277,5279,5280,5283,5284,5287],{},"If you would like to use both the end-to-end and unit testing functionality of ",[2045,5278,2047],{},", you can split your tests into separate files. You then either specify a test environment per-file with the special ",[2045,5281,5282],{},"// @vitest-environment nuxt"," comment, or name your runtime unit test files with the ",[2045,5285,5286],{},".nuxt.spec.ts"," extension.",[2033,5289,5290],{},[2045,5291,5292],{},"app.nuxt.spec.ts",[2117,5294,5296],{"className":2272,"code":5295,"language":2274,"meta":2275,"style":2123},"import { mockNuxtImport } from '@nuxt/test-utils/runtime'\n\nmockNuxtImport('useStorage', () => {\n  return () => {\n    return { value: 'mocked storage' }\n  }\n})\n",[2045,5297,5298,5316,5320,5340,5350,5368,5372],{"__ignoreMap":2123},[2127,5299,5300,5302,5304,5306,5308,5310,5312,5314],{"class":2129,"line":2130},[2127,5301,2359],{"class":2282},[2127,5303,2362],{"class":2297},[2127,5305,4254],{"class":2293},[2127,5307,2368],{"class":2297},[2127,5309,2371],{"class":2282},[2127,5311,2374],{"class":2297},[2127,5313,3584],{"class":2136},[2127,5315,2380],{"class":2297},[2127,5317,5318],{"class":2129,"line":2301},[2127,5319,2405],{"emptyLinePlaceholder":1196},[2127,5321,5322,5324,5326,5328,5330,5332,5334,5336,5338],{"class":2129,"line":2314},[2127,5323,4231],{"class":2289},[2127,5325,2294],{"class":2293},[2127,5327,2322],{"class":2297},[2127,5329,4239],{"class":2136},[2127,5331,2322],{"class":2297},[2127,5333,2980],{"class":2297},[2127,5335,2983],{"class":2297},[2127,5337,2987],{"class":2986},[2127,5339,2427],{"class":2297},[2127,5341,5342,5344,5346,5348],{"class":2129,"line":2328},[2127,5343,4293],{"class":2282},[2127,5345,2983],{"class":2297},[2127,5347,2987],{"class":2986},[2127,5349,2427],{"class":2297},[2127,5351,5352,5354,5356,5358,5360,5362,5364,5366],{"class":2129,"line":2336},[2127,5353,4304],{"class":2282},[2127,5355,2362],{"class":2297},[2127,5357,4309],{"class":2304},[2127,5359,2308],{"class":2297},[2127,5361,2374],{"class":2297},[2127,5363,4316],{"class":2136},[2127,5365,2322],{"class":2297},[2127,5367,4321],{"class":2297},[2127,5369,5370],{"class":2129,"line":2430},[2127,5371,4326],{"class":2297},[2127,5373,5374,5376],{"class":2129,"line":2440},[2127,5375,2339],{"class":2297},[2127,5377,2342],{"class":2293},[2033,5379,5380],{},[2045,5381,5382],{},"app.e2e.spec.ts",[2117,5384,5386],{"className":2272,"code":5385,"language":2274,"meta":2275,"style":2123},"import { $fetch, setup } from '@nuxt/test-utils/e2e'\n\nawait setup({\n  setupTimeout: 10000,\n})\n\n// ...\n",[2045,5387,5388,5412,5416,5427,5439,5445,5449],{"__ignoreMap":2123},[2127,5389,5390,5392,5394,5397,5399,5402,5404,5406,5408,5410],{"class":2129,"line":2130},[2127,5391,2359],{"class":2282},[2127,5393,2362],{"class":2297},[2127,5395,5396],{"class":2293}," $fetch",[2127,5398,2980],{"class":2297},[2127,5400,5401],{"class":2293}," setup",[2127,5403,2368],{"class":2297},[2127,5405,2371],{"class":2282},[2127,5407,2374],{"class":2297},[2127,5409,5272],{"class":2136},[2127,5411,2380],{"class":2297},[2127,5413,5414],{"class":2129,"line":2301},[2127,5415,2405],{"emptyLinePlaceholder":1196},[2127,5417,5418,5421,5423,5425],{"class":2129,"line":2314},[2127,5419,5420],{"class":2282},"await",[2127,5422,5401],{"class":2289},[2127,5424,2294],{"class":2293},[2127,5426,2298],{"class":2297},[2127,5428,5429,5432,5434,5437],{"class":2129,"line":2328},[2127,5430,5431],{"class":2304},"  setupTimeout",[2127,5433,2308],{"class":2297},[2127,5435,5436],{"class":4992}," 10000",[2127,5438,2325],{"class":2297},[2127,5440,5441,5443],{"class":2129,"line":2336},[2127,5442,2339],{"class":2297},[2127,5444,2342],{"class":2293},[2127,5446,5447],{"class":2129,"line":2430},[2127,5448,2405],{"emptyLinePlaceholder":1196},[2127,5450,5451],{"class":2129,"line":2440},[2127,5452,5453],{"class":2851},"// ...\n",[2252,5455,2746,5457],{"id":5456},"using-vuetest-utils",[2045,5458,3546],{},[2033,5460,5461,5462,5464],{},"If you prefer to use ",[2045,5463,3546],{}," on its own for unit testing in Nuxt, and you are only testing components which do not rely on Nuxt composables, auto-imports or context, you can follow these steps to set it up.",[2257,5466,5467,5557,5664,5759,5814,6002],{},[2075,5468,5469,5470],{},"Install the needed dependencies",[2113,5471,5472,5494,5515,5536],{"sync":2115},[2117,5473,5475],{"className":2119,"code":5474,"filename":2121,"language":2122,"meta":2123,"style":2123},"npm i --save-dev vitest @vue/test-utils happy-dom @vitejs/plugin-vue\n",[2045,5476,5477],{"__ignoreMap":2123},[2127,5478,5479,5481,5483,5485,5487,5489,5491],{"class":2129,"line":2130},[2127,5480,2121],{"class":2133},[2127,5482,2137],{"class":2136},[2127,5484,2140],{"class":2136},[2127,5486,2146],{"class":2136},[2127,5488,2149],{"class":2136},[2127,5490,2152],{"class":2136},[2127,5492,5493],{"class":2136}," @vitejs/plugin-vue\n",[2117,5495,5497],{"className":2119,"code":5496,"filename":2159,"language":2122,"meta":2123,"style":2123},"yarn add --dev vitest @vue/test-utils happy-dom @vitejs/plugin-vue\n",[2045,5498,5499],{"__ignoreMap":2123},[2127,5500,5501,5503,5505,5507,5509,5511,5513],{"class":2129,"line":2130},[2127,5502,2159],{"class":2133},[2127,5504,2168],{"class":2136},[2127,5506,2171],{"class":2136},[2127,5508,2146],{"class":2136},[2127,5510,2149],{"class":2136},[2127,5512,2152],{"class":2136},[2127,5514,5493],{"class":2136},[2117,5516,5518],{"className":2119,"code":5517,"filename":2185,"language":2122,"meta":2123,"style":2123},"pnpm add -D vitest @vue/test-utils happy-dom @vitejs/plugin-vue\n",[2045,5519,5520],{"__ignoreMap":2123},[2127,5521,5522,5524,5526,5528,5530,5532,5534],{"class":2129,"line":2130},[2127,5523,2185],{"class":2133},[2127,5525,2168],{"class":2136},[2127,5527,2196],{"class":2136},[2127,5529,2146],{"class":2136},[2127,5531,2149],{"class":2136},[2127,5533,2152],{"class":2136},[2127,5535,5493],{"class":2136},[2117,5537,5539],{"className":2119,"code":5538,"filename":2210,"language":2122,"meta":2123,"style":2123},"bun add --dev vitest @vue/test-utils happy-dom @vitejs/plugin-vue\n",[2045,5540,5541],{"__ignoreMap":2123},[2127,5542,5543,5545,5547,5549,5551,5553,5555],{"class":2129,"line":2130},[2127,5544,2210],{"class":2133},[2127,5546,2168],{"class":2136},[2127,5548,2171],{"class":2136},[2127,5550,2146],{"class":2136},[2127,5552,2149],{"class":2136},[2127,5554,2152],{"class":2136},[2127,5556,5493],{"class":2136},[2075,5558,2345,5559,2349,5561],{},[2045,5560,2348],{},[2117,5562,5564],{"className":2272,"code":5563,"language":2274,"meta":2123,"style":2123},"import { defineConfig } from 'vitest/config'\nimport vue from '@vitejs/plugin-vue'\n\nexport default defineConfig({\n  plugins: [vue()],\n  test: {\n    environment: 'happy-dom',\n  },\n})\n",[2045,5565,5566,5584,5600,5604,5616,5632,5640,5654,5658],{"__ignoreMap":2123},[2127,5567,5568,5570,5572,5574,5576,5578,5580,5582],{"class":2129,"line":2130},[2127,5569,2359],{"class":2282},[2127,5571,2362],{"class":2297},[2127,5573,2365],{"class":2293},[2127,5575,2368],{"class":2297},[2127,5577,2371],{"class":2282},[2127,5579,2374],{"class":2297},[2127,5581,2377],{"class":2136},[2127,5583,2380],{"class":2297},[2127,5585,5586,5588,5591,5593,5595,5598],{"class":2129,"line":2301},[2127,5587,2359],{"class":2282},[2127,5589,5590],{"class":2293}," vue ",[2127,5592,3743],{"class":2282},[2127,5594,2374],{"class":2297},[2127,5596,5597],{"class":2136},"@vitejs/plugin-vue",[2127,5599,2380],{"class":2297},[2127,5601,5602],{"class":2129,"line":2314},[2127,5603,2405],{"emptyLinePlaceholder":1196},[2127,5605,5606,5608,5610,5612,5614],{"class":2129,"line":2328},[2127,5607,2283],{"class":2282},[2127,5609,2286],{"class":2282},[2127,5611,2365],{"class":2289},[2127,5613,2294],{"class":2293},[2127,5615,2298],{"class":2297},[2127,5617,5618,5621,5623,5625,5627,5630],{"class":2129,"line":2336},[2127,5619,5620],{"class":2304},"  plugins",[2127,5622,2308],{"class":2297},[2127,5624,2481],{"class":2293},[2127,5626,4945],{"class":2289},[2127,5628,5629],{"class":2293},"()]",[2127,5631,2325],{"class":2297},[2127,5633,5634,5636,5638],{"class":2129,"line":2430},[2127,5635,2422],{"class":2304},[2127,5637,2308],{"class":2297},[2127,5639,2427],{"class":2297},[2127,5641,5642,5644,5646,5648,5650,5652],{"class":2129,"line":2440},[2127,5643,2836],{"class":2304},[2127,5645,2308],{"class":2297},[2127,5647,2374],{"class":2297},[2127,5649,2080],{"class":2136},[2127,5651,2322],{"class":2297},[2127,5653,2325],{"class":2297},[2127,5655,5656],{"class":2129,"line":2446},[2127,5657,2699],{"class":2297},[2127,5659,5660,5662],{"class":2129,"line":2456},[2127,5661,2339],{"class":2297},[2127,5663,2342],{"class":2293},[2075,5665,5666,5667,5669],{},"Add a new command for test in your ",[2045,5668,237],{},[2117,5670,5674],{"className":5671,"code":5672,"language":5673,"meta":2123,"style":2123},"language-json shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","\"scripts\": {\n  \"build\": \"nuxt build\",\n  \"dev\": \"nuxt dev\",\n  ...\n  \"test\": \"vitest\"\n},\n","json",[2045,5675,5676,5691,5712,5731,5736,5753],{"__ignoreMap":2123},[2127,5677,5678,5681,5684,5686,5689],{"class":2129,"line":2130},[2127,5679,5680],{"class":2297},"\"",[2127,5682,5683],{"class":2136},"scripts",[2127,5685,5680],{"class":2297},[2127,5687,5688],{"class":2293},": ",[2127,5690,2298],{"class":2297},[2127,5692,5693,5696,5699,5701,5703,5706,5708,5710],{"class":2129,"line":2301},[2127,5694,5695],{"class":2297},"  \"",[2127,5697,5698],{"class":2986},"build",[2127,5700,5680],{"class":2297},[2127,5702,2308],{"class":2297},[2127,5704,5705],{"class":2297}," \"",[2127,5707,761],{"class":2136},[2127,5709,5680],{"class":2297},[2127,5711,2325],{"class":2297},[2127,5713,5714,5716,5719,5721,5723,5725,5727,5729],{"class":2129,"line":2314},[2127,5715,5695],{"class":2297},[2127,5717,5718],{"class":2986},"dev",[2127,5720,5680],{"class":2297},[2127,5722,2308],{"class":2297},[2127,5724,5705],{"class":2297},[2127,5726,773],{"class":2136},[2127,5728,5680],{"class":2297},[2127,5730,2325],{"class":2297},[2127,5732,5733],{"class":2129,"line":2328},[2127,5734,5735],{"class":2293},"  ...\n",[2127,5737,5738,5740,5742,5744,5746,5748,5750],{"class":2129,"line":2336},[2127,5739,5695],{"class":2297},[2127,5741,2968],{"class":2986},[2127,5743,5680],{"class":2297},[2127,5745,2308],{"class":2297},[2127,5747,5705],{"class":2297},[2127,5749,2090],{"class":2136},[2127,5751,5752],{"class":2297},"\"\n",[2127,5754,5755,5757],{"class":2129,"line":2430},[2127,5756,2339],{"class":2297},[2127,5758,2325],{"class":2293},[2075,5760,5761,5762,5765,5766,2349,5769],{},"Create a simple ",[2045,5763,5764],{},"\u003CHelloWorld>"," component ",[2045,5767,5768],{},"app/components/HelloWorld.vue",[2117,5770,5773],{"className":5771,"code":5772,"language":4945,"meta":2123,"style":2123},"language-vue shiki shiki-themes material-theme-lighter material-theme-lighter material-theme-palenight","\u003Ctemplate>\n  \u003Cp>Hello world\u003C/p>\n\u003C/template>\n",[2045,5774,5775,5786,5806],{"__ignoreMap":2123},[2127,5776,5777,5780,5783],{"class":2129,"line":2130},[2127,5778,5779],{"class":2297},"\u003C",[2127,5781,5782],{"class":2304},"template",[2127,5784,5785],{"class":2297},">\n",[2127,5787,5788,5791,5793,5796,5799,5802,5804],{"class":2129,"line":2301},[2127,5789,5790],{"class":2297},"  \u003C",[2127,5792,2033],{"class":2304},[2127,5794,5795],{"class":2297},">",[2127,5797,5798],{"class":2293},"Hello world",[2127,5800,5801],{"class":2297},"\u003C/",[2127,5803,2033],{"class":2304},[2127,5805,5785],{"class":2297},[2127,5807,5808,5810,5812],{"class":2129,"line":2314},[2127,5809,5801],{"class":2297},[2127,5811,5782],{"class":2304},[2127,5813,5785],{"class":2297},[2075,5815,5816,5817,5820],{},"Create a simple unit test for this newly created component ",[2045,5818,5819],{},"~/components/HelloWorld.spec.ts",[2117,5821,5823],{"className":2272,"code":5822,"language":2274,"meta":2275,"style":2123},"import { describe, expect, it } from 'vitest'\nimport { mount } from '@vue/test-utils'\n\nimport HelloWorld from './HelloWorld.vue'\n\ndescribe('HelloWorld', () => {\n  it('component renders Hello world properly', () => {\n    const wrapper = mount(HelloWorld)\n    expect(wrapper.text()).toContain('Hello world')\n  })\n})\n",[2045,5824,5825,5854,5873,5877,5893,5897,5919,5941,5959,5990,5996],{"__ignoreMap":2123},[2127,5826,5827,5829,5831,5834,5836,5839,5841,5844,5846,5848,5850,5852],{"class":2129,"line":2130},[2127,5828,2359],{"class":2282},[2127,5830,2362],{"class":2297},[2127,5832,5833],{"class":2293}," describe",[2127,5835,2980],{"class":2297},[2127,5837,5838],{"class":2293}," expect",[2127,5840,2980],{"class":2297},[2127,5842,5843],{"class":2293}," it",[2127,5845,2368],{"class":2297},[2127,5847,2371],{"class":2282},[2127,5849,2374],{"class":2297},[2127,5851,2090],{"class":2136},[2127,5853,2380],{"class":2297},[2127,5855,5856,5858,5860,5863,5865,5867,5869,5871],{"class":2129,"line":2301},[2127,5857,2359],{"class":2282},[2127,5859,2362],{"class":2297},[2127,5861,5862],{"class":2293}," mount",[2127,5864,2368],{"class":2297},[2127,5866,2371],{"class":2282},[2127,5868,2374],{"class":2297},[2127,5870,3546],{"class":2136},[2127,5872,2380],{"class":2297},[2127,5874,5875],{"class":2129,"line":2314},[2127,5876,2405],{"emptyLinePlaceholder":1196},[2127,5878,5879,5881,5884,5886,5888,5891],{"class":2129,"line":2328},[2127,5880,2359],{"class":2282},[2127,5882,5883],{"class":2293}," HelloWorld ",[2127,5885,3743],{"class":2282},[2127,5887,2374],{"class":2297},[2127,5889,5890],{"class":2136},"./HelloWorld.vue",[2127,5892,2380],{"class":2297},[2127,5894,5895],{"class":2129,"line":2336},[2127,5896,2405],{"emptyLinePlaceholder":1196},[2127,5898,5899,5902,5904,5906,5909,5911,5913,5915,5917],{"class":2129,"line":2430},[2127,5900,5901],{"class":2289},"describe",[2127,5903,2294],{"class":2293},[2127,5905,2322],{"class":2297},[2127,5907,5908],{"class":2136},"HelloWorld",[2127,5910,2322],{"class":2297},[2127,5912,2980],{"class":2297},[2127,5914,2983],{"class":2297},[2127,5916,2987],{"class":2986},[2127,5918,2427],{"class":2297},[2127,5920,5921,5924,5926,5928,5931,5933,5935,5937,5939],{"class":2129,"line":2440},[2127,5922,5923],{"class":2289},"  it",[2127,5925,2294],{"class":2304},[2127,5927,2322],{"class":2297},[2127,5929,5930],{"class":2136},"component renders Hello world properly",[2127,5932,2322],{"class":2297},[2127,5934,2980],{"class":2297},[2127,5936,2983],{"class":2297},[2127,5938,2987],{"class":2986},[2127,5940,2427],{"class":2297},[2127,5942,5943,5946,5949,5951,5953,5955,5957],{"class":2129,"line":2446},[2127,5944,5945],{"class":2986},"    const",[2127,5947,5948],{"class":2293}," wrapper",[2127,5950,3646],{"class":2297},[2127,5952,5862],{"class":2289},[2127,5954,2294],{"class":2304},[2127,5956,5908],{"class":2293},[2127,5958,2342],{"class":2304},[2127,5960,5961,5964,5966,5969,5971,5973,5975,5977,5980,5982,5984,5986,5988],{"class":2129,"line":2456},[2127,5962,5963],{"class":2289},"    expect",[2127,5965,2294],{"class":2304},[2127,5967,5968],{"class":2293},"wrapper",[2127,5970,2040],{"class":2297},[2127,5972,3673],{"class":2289},[2127,5974,3676],{"class":2304},[2127,5976,2040],{"class":2297},[2127,5978,5979],{"class":2289},"toContain",[2127,5981,2294],{"class":2304},[2127,5983,2322],{"class":2297},[2127,5985,5798],{"class":2136},[2127,5987,2322],{"class":2297},[2127,5989,2342],{"class":2304},[2127,5991,5992,5994],{"class":2129,"line":2473},[2127,5993,4801],{"class":2297},[2127,5995,2342],{"class":2304},[2127,5997,5998,6000],{"class":2129,"line":2496},[2127,5999,2339],{"class":2297},[2127,6001,2342],{"class":2293},[2075,6003,6004,6005],{},"Run vitest command",[2113,6006,6007,6022,6033,6046],{"sync":2115},[2117,6008,6010],{"className":2119,"code":6009,"filename":2121,"language":2122,"meta":2123,"style":2123},"npm run test\n",[2045,6011,6012],{"__ignoreMap":2123},[2127,6013,6014,6016,6019],{"class":2129,"line":2130},[2127,6015,2121],{"class":2133},[2127,6017,6018],{"class":2136}," run",[2127,6020,6021],{"class":2136}," test\n",[2117,6023,6025],{"className":2119,"code":6024,"filename":2159,"language":2122,"meta":2123,"style":2123},"yarn test\n",[2045,6026,6027],{"__ignoreMap":2123},[2127,6028,6029,6031],{"class":2129,"line":2130},[2127,6030,2159],{"class":2133},[2127,6032,6021],{"class":2136},[2117,6034,6036],{"className":2119,"code":6035,"filename":2185,"language":2122,"meta":2123,"style":2123},"pnpm run test\n",[2045,6037,6038],{"__ignoreMap":2123},[2127,6039,6040,6042,6044],{"class":2129,"line":2130},[2127,6041,2185],{"class":2133},[2127,6043,6018],{"class":2136},[2127,6045,6021],{"class":2136},[2117,6047,6049],{"className":2119,"code":6048,"filename":2210,"language":2122,"meta":2123,"style":2123},"bun run test\n",[2045,6050,6051],{"__ignoreMap":2123},[2127,6052,6053,6055,6057],{"class":2129,"line":2130},[2127,6054,2210],{"class":2133},[2127,6056,6018],{"class":2136},[2127,6058,6021],{"class":2136},[2033,6060,6061,6062,6064],{},"Congratulations, you're all set to start unit testing with ",[2045,6063,3546],{}," in Nuxt! Happy testing!",[2062,6066,6068],{"id":6067},"end-to-end-testing","End-To-End Testing",[2033,6070,6071,6072,2091,6077,2091,6082,2081,6087,6092],{},"For end-to-end testing, we support ",[2037,6073,6076],{"href":6074,"rel":6075},"https://github.com/vitest-dev/vitest",[2053],"Vitest",[2037,6078,6081],{"href":6079,"rel":6080},"https://jestjs.io",[2053],"Jest",[2037,6083,6086],{"href":6084,"rel":6085},"https://cucumber.io/",[2053],"Cucumber",[2037,6088,6091],{"href":6089,"rel":6090},"https://playwright.dev/",[2053],"Playwright"," as test runners.",[2252,6094,2255],{"id":6095},"setup-1",[2033,6097,6098,6099,6101,6102,6104],{},"In each ",[2045,6100,5901],{}," block where you are taking advantage of the ",[2045,6103,5272],{}," helper methods, you will need to set up the test context before beginning.",[2117,6106,6109],{"className":2272,"code":6107,"filename":6108,"language":2274,"meta":2275,"style":2123},"import { describe, test } from 'vitest'\nimport { $fetch, setup } from '@nuxt/test-utils/e2e'\n\ndescribe('My test', async () => {\n  await setup({\n    // test context options\n  })\n\n  test('my test', () => {\n    // ...\n  })\n})\n","test/my-test.spec.ts",[2045,6110,6111,6133,6155,6159,6182,6192,6197,6203,6207,6227,6231,6237],{"__ignoreMap":2123},[2127,6112,6113,6115,6117,6119,6121,6123,6125,6127,6129,6131],{"class":2129,"line":2130},[2127,6114,2359],{"class":2282},[2127,6116,2362],{"class":2297},[2127,6118,5833],{"class":2293},[2127,6120,2980],{"class":2297},[2127,6122,2949],{"class":2293},[2127,6124,2368],{"class":2297},[2127,6126,2371],{"class":2282},[2127,6128,2374],{"class":2297},[2127,6130,2090],{"class":2136},[2127,6132,2380],{"class":2297},[2127,6134,6135,6137,6139,6141,6143,6145,6147,6149,6151,6153],{"class":2129,"line":2301},[2127,6136,2359],{"class":2282},[2127,6138,2362],{"class":2297},[2127,6140,5396],{"class":2293},[2127,6142,2980],{"class":2297},[2127,6144,5401],{"class":2293},[2127,6146,2368],{"class":2297},[2127,6148,2371],{"class":2282},[2127,6150,2374],{"class":2297},[2127,6152,5272],{"class":2136},[2127,6154,2380],{"class":2297},[2127,6156,6157],{"class":2129,"line":2314},[2127,6158,2405],{"emptyLinePlaceholder":1196},[2127,6160,6161,6163,6165,6167,6170,6172,6174,6176,6178,6180],{"class":2129,"line":2328},[2127,6162,5901],{"class":2289},[2127,6164,2294],{"class":2293},[2127,6166,2322],{"class":2297},[2127,6168,6169],{"class":2136},"My test",[2127,6171,2322],{"class":2297},[2127,6173,2980],{"class":2297},[2127,6175,3629],{"class":2986},[2127,6177,2983],{"class":2297},[2127,6179,2987],{"class":2986},[2127,6181,2427],{"class":2297},[2127,6183,6184,6186,6188,6190],{"class":2129,"line":2336},[2127,6185,4020],{"class":2282},[2127,6187,5401],{"class":2289},[2127,6189,2294],{"class":2304},[2127,6191,2298],{"class":2297},[2127,6193,6194],{"class":2129,"line":2430},[2127,6195,6196],{"class":2851},"    // test context options\n",[2127,6198,6199,6201],{"class":2129,"line":2440},[2127,6200,4801],{"class":2297},[2127,6202,2342],{"class":2304},[2127,6204,6205],{"class":2129,"line":2446},[2127,6206,2405],{"emptyLinePlaceholder":1196},[2127,6208,6209,6211,6213,6215,6217,6219,6221,6223,6225],{"class":2129,"line":2456},[2127,6210,2422],{"class":2289},[2127,6212,2294],{"class":2304},[2127,6214,2322],{"class":2297},[2127,6216,2975],{"class":2136},[2127,6218,2322],{"class":2297},[2127,6220,2980],{"class":2297},[2127,6222,2983],{"class":2297},[2127,6224,2987],{"class":2986},[2127,6226,2427],{"class":2297},[2127,6228,6229],{"class":2129,"line":2473},[2127,6230,4718],{"class":2851},[2127,6232,6233,6235],{"class":2129,"line":2496},[2127,6234,4801],{"class":2297},[2127,6236,2342],{"class":2304},[2127,6238,6239,6241],{"class":2129,"line":2513},[2127,6240,2339],{"class":2297},[2127,6242,2342],{"class":2293},[2033,6244,6245,6246,6248,6249,2091,6252,2091,6255,2081,6258,6261],{},"Behind the scenes, ",[2045,6247,2254],{}," performs a number of tasks in ",[2045,6250,6251],{},"beforeAll",[2045,6253,6254],{},"beforeEach",[2045,6256,6257],{},"afterEach",[2045,6259,6260],{},"afterAll"," to set up the Nuxt test environment correctly.",[2033,6263,6264,6265,6267],{},"Please use the options below for the ",[2045,6266,2254],{}," method.",[2777,6269,6271],{"id":6270},"nuxt-config","Nuxt Config",[2072,6273,6274,6294],{},[2075,6275,6276,6279,6280],{},[2045,6277,6278],{},"rootDir",": Path to a directory with a Nuxt app to be put under test.\n",[2072,6281,6282,6288],{},[2075,6283,6284,6285],{},"Type: ",[2045,6286,6287],{},"string",[2075,6289,6290,6291],{},"Default: ",[2045,6292,6293],{},"'.'",[2075,6295,6296,6299,6300],{},[2045,6297,6298],{},"configFile",": Name of the configuration file.\n",[2072,6301,6302,6306],{},[2075,6303,6284,6304],{},[2045,6305,6287],{},[2075,6307,6290,6308],{},[2045,6309,6310],{},"'nuxt.config'",[2777,6312,6314],{"id":6313},"timings","Timings",[2072,6316,6317,6343],{},[2075,6318,6319,6322,6323,6326,6327],{},[2045,6320,6321],{},"setupTimeout",": The amount of time (in milliseconds) to allow for ",[2045,6324,6325],{},"setupTest"," to complete its work (which could include building or generating files for a Nuxt application, depending on the options that are passed).",[2072,6328,6329,6334],{},[2075,6330,6284,6331],{},[2045,6332,6333],{},"number",[2075,6335,6290,6336,3325,6339,6342],{},[2045,6337,6338],{},"120000",[2045,6340,6341],{},"240000"," on windows",[2075,6344,6345,6348,6349],{},[2045,6346,6347],{},"teardownTimeout",": The amount of time (in milliseconds) to allow tearing down the test environment, such as closing the browser.",[2072,6350,6351,6355],{},[2075,6352,6284,6353],{},[2045,6354,6333],{},[2075,6356,6290,6357],{},[2045,6358,6359],{},"30000",[2777,6361,395],{"id":6362},"features",[2072,6364,6365,6394,6414,6432,6451,6473,6516],{},[2075,6366,6367,6369,6370],{},[2045,6368,5698],{},": Whether to run a separate build step.",[2072,6371,6372,6377],{},[2075,6373,6284,6374],{},[2045,6375,6376],{},"boolean",[2075,6378,6290,6379,4705,6381,6383,6384,3325,6387,6389,6390,6393],{},[2045,6380,3359],{},[2045,6382,3371],{}," if ",[2045,6385,6386],{},"browser",[2045,6388,185],{}," is disabled, or if a ",[2045,6391,6392],{},"host"," is provided)",[2075,6395,6396,6398,6399],{},[2045,6397,185],{},": Whether to launch a server to respond to requests in the test suite.",[2072,6400,6401,6405],{},[2075,6402,6284,6403],{},[2045,6404,6376],{},[2075,6406,6290,6407,4705,6409,6411,6412,6393],{},[2045,6408,3359],{},[2045,6410,3371],{}," if a ",[2045,6413,6392],{},[2075,6415,6416,6419,6420],{},[2045,6417,6418],{},"port",": If provided, set the launched test server port to the value.",[2072,6421,6422,6427],{},[2075,6423,6284,6424],{},[2045,6425,6426],{},"number | undefined",[2075,6428,6290,6429],{},[2045,6430,6431],{},"undefined",[2075,6433,6434,6436,6437,2040,6441],{},[2045,6435,6392],{},": If provided, a URL to use as the test target instead of building and running a new server. Useful for running \"real\" end-to-end tests against a deployed version of your application, or against an already running local server (which may provide a significant reduction in test execution timings). See the ",[2037,6438,6440],{"href":6439},"/docs/4.x/getting-started/testing#target-host-end-to-end-example","target host end-to-end example below",[2072,6442,6443,6447],{},[2075,6444,6284,6445],{},[2045,6446,6287],{},[2075,6448,6290,6449],{},[2045,6450,6431],{},[2075,6452,6453,6455,6456,6462,6463],{},[2045,6454,6386],{},": Under the hood, Nuxt test utils uses ",[2037,6457,6460],{"href":6458,"rel":6459},"https://playwright.dev",[2053],[2045,6461,2100],{}," to carry out browser testing. If this option is set, a browser will be launched and can be controlled in the subsequent test suite.",[2072,6464,6465,6469],{},[2075,6466,6284,6467],{},[2045,6468,6376],{},[2075,6470,6290,6471],{},[2045,6472,3371],{},[2075,6474,6475,6478],{},[2045,6476,6477],{},"browserOptions",[2072,6479,6480],{},[2075,6481,6284,6482,6485,6486],{},[2045,6483,6484],{},"object"," with the following properties\n",[2072,6487,6488,6503],{},[2075,6489,6490,6493,6494,2091,6497,3325,6500],{},[2045,6491,6492],{},"type",": The type of browser to launch - either ",[2045,6495,6496],{},"chromium",[2045,6498,6499],{},"firefox",[2045,6501,6502],{},"webkit",[2075,6504,6505,5688,6508,6510,6511,2040],{},[2045,6506,6507],{},"launch",[2045,6509,6484],{}," of options that will be passed to playwright when launching the browser. See ",[2037,6512,6515],{"href":6513,"rel":6514},"https://playwright.dev/docs/api/class-browsertype#browser-type-launch",[2053],"full API reference",[2075,6517,6518,6521,6522,6526,6527],{},[2045,6519,6520],{},"runner",": Specify the runner for the test suite. Currently, ",[2037,6523,6076],{"href":6524,"rel":6525},"https://vitest.dev",[2053]," is recommended.",[2072,6528,6529,6534],{},[2075,6530,6284,6531],{},[2045,6532,6533],{},"'vitest' | 'jest' | 'cucumber'",[2075,6535,6290,6536],{},[2045,6537,6538],{},"'vitest'",[3130,6540,6542,6543,6545],{"id":6541},"target-host-end-to-end-example","Target ",[2045,6544,6392],{}," end-to-end example",[2033,6547,6548],{},"A common use-case for end-to-end testing is running the tests against a deployed application running in the same environment typically used for Production.",[2033,6550,6551],{},"For local development or automated deploy pipelines, testing against a separate local server can be more efficient and is typically faster than allowing the test framework to rebuild between tests.",[2033,6553,6554,6555,6557,6558,6560],{},"To utilize a separate target host for end-to-end tests, simply provide the ",[2045,6556,6392],{}," property of the ",[2045,6559,2254],{}," function with the desired URL.",[2117,6562,6564],{"className":2272,"code":6563,"language":2274,"meta":2123,"style":2123},"import { createPage, setup } from '@nuxt/test-utils/e2e'\nimport { describe, expect, it } from 'vitest'\n\ndescribe('login page', async () => {\n  await setup({\n    host: 'http://localhost:8787',\n  })\n\n  it('displays the email and password fields', async () => {\n    const page = await createPage('/login')\n    expect(await page.getByTestId('email').isVisible()).toBe(true)\n    expect(await page.getByTestId('password').isVisible()).toBe(true)\n  })\n})\n",[2045,6565,6566,6589,6615,6619,6642,6652,6668,6674,6678,6701,6725,6769,6810,6816],{"__ignoreMap":2123},[2127,6567,6568,6570,6572,6575,6577,6579,6581,6583,6585,6587],{"class":2129,"line":2130},[2127,6569,2359],{"class":2282},[2127,6571,2362],{"class":2297},[2127,6573,6574],{"class":2293}," createPage",[2127,6576,2980],{"class":2297},[2127,6578,5401],{"class":2293},[2127,6580,2368],{"class":2297},[2127,6582,2371],{"class":2282},[2127,6584,2374],{"class":2297},[2127,6586,5272],{"class":2136},[2127,6588,2380],{"class":2297},[2127,6590,6591,6593,6595,6597,6599,6601,6603,6605,6607,6609,6611,6613],{"class":2129,"line":2301},[2127,6592,2359],{"class":2282},[2127,6594,2362],{"class":2297},[2127,6596,5833],{"class":2293},[2127,6598,2980],{"class":2297},[2127,6600,5838],{"class":2293},[2127,6602,2980],{"class":2297},[2127,6604,5843],{"class":2293},[2127,6606,2368],{"class":2297},[2127,6608,2371],{"class":2282},[2127,6610,2374],{"class":2297},[2127,6612,2090],{"class":2136},[2127,6614,2380],{"class":2297},[2127,6616,6617],{"class":2129,"line":2314},[2127,6618,2405],{"emptyLinePlaceholder":1196},[2127,6620,6621,6623,6625,6627,6630,6632,6634,6636,6638,6640],{"class":2129,"line":2328},[2127,6622,5901],{"class":2289},[2127,6624,2294],{"class":2293},[2127,6626,2322],{"class":2297},[2127,6628,6629],{"class":2136},"login page",[2127,6631,2322],{"class":2297},[2127,6633,2980],{"class":2297},[2127,6635,3629],{"class":2986},[2127,6637,2983],{"class":2297},[2127,6639,2987],{"class":2986},[2127,6641,2427],{"class":2297},[2127,6643,6644,6646,6648,6650],{"class":2129,"line":2336},[2127,6645,4020],{"class":2282},[2127,6647,5401],{"class":2289},[2127,6649,2294],{"class":2304},[2127,6651,2298],{"class":2297},[2127,6653,6654,6657,6659,6661,6664,6666],{"class":2129,"line":2430},[2127,6655,6656],{"class":2304},"    host",[2127,6658,2308],{"class":2297},[2127,6660,2374],{"class":2297},[2127,6662,6663],{"class":2136},"http://localhost:8787",[2127,6665,2322],{"class":2297},[2127,6667,2325],{"class":2297},[2127,6669,6670,6672],{"class":2129,"line":2440},[2127,6671,4801],{"class":2297},[2127,6673,2342],{"class":2304},[2127,6675,6676],{"class":2129,"line":2446},[2127,6677,2405],{"emptyLinePlaceholder":1196},[2127,6679,6680,6682,6684,6686,6689,6691,6693,6695,6697,6699],{"class":2129,"line":2456},[2127,6681,5923],{"class":2289},[2127,6683,2294],{"class":2304},[2127,6685,2322],{"class":2297},[2127,6687,6688],{"class":2136},"displays the email and password fields",[2127,6690,2322],{"class":2297},[2127,6692,2980],{"class":2297},[2127,6694,3629],{"class":2986},[2127,6696,2983],{"class":2297},[2127,6698,2987],{"class":2986},[2127,6700,2427],{"class":2297},[2127,6702,6703,6705,6708,6710,6712,6714,6716,6718,6721,6723],{"class":2129,"line":2473},[2127,6704,5945],{"class":2986},[2127,6706,6707],{"class":2293}," page",[2127,6709,3646],{"class":2297},[2127,6711,3649],{"class":2282},[2127,6713,6574],{"class":2289},[2127,6715,2294],{"class":2304},[2127,6717,2322],{"class":2297},[2127,6719,6720],{"class":2136},"/login",[2127,6722,2322],{"class":2297},[2127,6724,2342],{"class":2304},[2127,6726,6727,6729,6731,6733,6735,6737,6740,6742,6744,6747,6749,6751,6753,6756,6758,6760,6763,6765,6767],{"class":2129,"line":2496},[2127,6728,5963],{"class":2289},[2127,6730,2294],{"class":2304},[2127,6732,5420],{"class":2282},[2127,6734,6707],{"class":2293},[2127,6736,2040],{"class":2297},[2127,6738,6739],{"class":2289},"getByTestId",[2127,6741,2294],{"class":2304},[2127,6743,2322],{"class":2297},[2127,6745,6746],{"class":2136},"email",[2127,6748,2322],{"class":2297},[2127,6750,2683],{"class":2304},[2127,6752,2040],{"class":2297},[2127,6754,6755],{"class":2289},"isVisible",[2127,6757,3676],{"class":2304},[2127,6759,2040],{"class":2297},[2127,6761,6762],{"class":2289},"toBe",[2127,6764,2294],{"class":2304},[2127,6766,3359],{"class":3474},[2127,6768,2342],{"class":2304},[2127,6770,6771,6773,6775,6777,6779,6781,6783,6785,6787,6790,6792,6794,6796,6798,6800,6802,6804,6806,6808],{"class":2129,"line":2513},[2127,6772,5963],{"class":2289},[2127,6774,2294],{"class":2304},[2127,6776,5420],{"class":2282},[2127,6778,6707],{"class":2293},[2127,6780,2040],{"class":2297},[2127,6782,6739],{"class":2289},[2127,6784,2294],{"class":2304},[2127,6786,2322],{"class":2297},[2127,6788,6789],{"class":2136},"password",[2127,6791,2322],{"class":2297},[2127,6793,2683],{"class":2304},[2127,6795,2040],{"class":2297},[2127,6797,6755],{"class":2289},[2127,6799,3676],{"class":2304},[2127,6801,2040],{"class":2297},[2127,6803,6762],{"class":2289},[2127,6805,2294],{"class":2304},[2127,6807,3359],{"class":3474},[2127,6809,2342],{"class":2304},[2127,6811,6812,6814],{"class":2129,"line":2519},[2127,6813,4801],{"class":2297},[2127,6815,2342],{"class":2304},[2127,6817,6818,6820],{"class":2129,"line":2525},[2127,6819,2339],{"class":2297},[2127,6821,2342],{"class":2293},[2252,6823,6825],{"id":6824},"apis","APIs",[2777,6827,6829],{"id":6828},"fetchurl",[2045,6830,6831],{},"$fetch(url)",[2033,6833,6834],{},"Get the HTML of a server-rendered page.",[2117,6836,6838],{"className":2272,"code":6837,"language":2274,"meta":2275,"style":2123},"import { $fetch } from '@nuxt/test-utils/e2e'\n\nconst html = await $fetch('/')\n",[2045,6839,6840,6858,6862],{"__ignoreMap":2123},[2127,6841,6842,6844,6846,6848,6850,6852,6854,6856],{"class":2129,"line":2130},[2127,6843,2359],{"class":2282},[2127,6845,2362],{"class":2297},[2127,6847,5396],{"class":2293},[2127,6849,2368],{"class":2297},[2127,6851,2371],{"class":2282},[2127,6853,2374],{"class":2297},[2127,6855,5272],{"class":2136},[2127,6857,2380],{"class":2297},[2127,6859,6860],{"class":2129,"line":2301},[2127,6861,2405],{"emptyLinePlaceholder":1196},[2127,6863,6864,6866,6869,6872,6874,6876,6878,6880,6883,6885],{"class":2129,"line":2314},[2127,6865,4430],{"class":2986},[2127,6867,6868],{"class":2293}," html ",[2127,6870,6871],{"class":2297},"=",[2127,6873,3649],{"class":2282},[2127,6875,5396],{"class":2289},[2127,6877,2294],{"class":2293},[2127,6879,2322],{"class":2297},[2127,6881,6882],{"class":2136},"/",[2127,6884,2322],{"class":2297},[2127,6886,2342],{"class":2293},[2777,6888,6890],{"id":6889},"fetchurl-1",[2045,6891,6892],{},"fetch(url)",[2033,6894,6895],{},"Get the response of a server-rendered page.",[2117,6897,6899],{"className":2272,"code":6898,"language":2274,"meta":2275,"style":2123},"import { fetch } from '@nuxt/test-utils/e2e'\n\nconst res = await fetch('/')\nconst { body, headers } = res\n",[2045,6900,6901,6920,6924,6947],{"__ignoreMap":2123},[2127,6902,6903,6905,6907,6910,6912,6914,6916,6918],{"class":2129,"line":2130},[2127,6904,2359],{"class":2282},[2127,6906,2362],{"class":2297},[2127,6908,6909],{"class":2293}," fetch",[2127,6911,2368],{"class":2297},[2127,6913,2371],{"class":2282},[2127,6915,2374],{"class":2297},[2127,6917,5272],{"class":2136},[2127,6919,2380],{"class":2297},[2127,6921,6922],{"class":2129,"line":2301},[2127,6923,2405],{"emptyLinePlaceholder":1196},[2127,6925,6926,6928,6931,6933,6935,6937,6939,6941,6943,6945],{"class":2129,"line":2314},[2127,6927,4430],{"class":2986},[2127,6929,6930],{"class":2293}," res ",[2127,6932,6871],{"class":2297},[2127,6934,3649],{"class":2282},[2127,6936,6909],{"class":2289},[2127,6938,2294],{"class":2293},[2127,6940,2322],{"class":2297},[2127,6942,6882],{"class":2136},[2127,6944,2322],{"class":2297},[2127,6946,2342],{"class":2293},[2127,6948,6949,6951,6953,6956,6958,6961,6963,6965],{"class":2129,"line":2328},[2127,6950,4430],{"class":2986},[2127,6952,2362],{"class":2297},[2127,6954,6955],{"class":2293}," body",[2127,6957,2980],{"class":2297},[2127,6959,6960],{"class":2293}," headers ",[2127,6962,2339],{"class":2297},[2127,6964,3646],{"class":2297},[2127,6966,6967],{"class":2293}," res\n",[2777,6969,6971],{"id":6970},"urlpath",[2045,6972,6973],{},"url(path)",[2033,6975,6976],{},"Get the full URL for a given page (including the port the test server is running on.)",[2117,6978,6980],{"className":2272,"code":6979,"language":2274,"meta":2275,"style":2123},"import { url } from '@nuxt/test-utils/e2e'\n\nconst pageUrl = url('/page')\n// 'http://localhost:6840/page'\n",[2045,6981,6982,7001,7005,7027],{"__ignoreMap":2123},[2127,6983,6984,6986,6988,6991,6993,6995,6997,6999],{"class":2129,"line":2130},[2127,6985,2359],{"class":2282},[2127,6987,2362],{"class":2297},[2127,6989,6990],{"class":2293}," url",[2127,6992,2368],{"class":2297},[2127,6994,2371],{"class":2282},[2127,6996,2374],{"class":2297},[2127,6998,5272],{"class":2136},[2127,7000,2380],{"class":2297},[2127,7002,7003],{"class":2129,"line":2301},[2127,7004,2405],{"emptyLinePlaceholder":1196},[2127,7006,7007,7009,7012,7014,7016,7018,7020,7023,7025],{"class":2129,"line":2314},[2127,7008,4430],{"class":2986},[2127,7010,7011],{"class":2293}," pageUrl ",[2127,7013,6871],{"class":2297},[2127,7015,6990],{"class":2289},[2127,7017,2294],{"class":2293},[2127,7019,2322],{"class":2297},[2127,7021,7022],{"class":2136},"/page",[2127,7024,2322],{"class":2297},[2127,7026,2342],{"class":2293},[2127,7028,7029],{"class":2129,"line":2328},[2127,7030,7031],{"class":2851},"// 'http://localhost:6840/page'\n",[2252,7033,7035],{"id":7034},"testing-in-a-browser","Testing in a Browser",[2033,7037,7038,7039,7041],{},"We provide built-in support using Playwright within ",[2045,7040,2047],{},", either programmatically or via the Playwright test runner.",[2777,7043,7045],{"id":7044},"createpageurl",[2045,7046,7047],{},"createPage(url)",[2033,7049,7050,7051,2091,7053,3325,7055,7057,7058,7061,7062,2040],{},"Within ",[2045,7052,2090],{},[2045,7054,2097],{},[2045,7056,2094],{},", you can create a configured Playwright browser instance with ",[2045,7059,7060],{},"createPage",", and (optionally) point it at a path from the running server. You can find out more about the API methods available from ",[2037,7063,7066],{"href":7064,"rel":7065},"https://playwright.dev/docs/api/class-page",[2053],"in the Playwright documentation",[2117,7068,7070],{"className":2272,"code":7069,"language":2274,"meta":2275,"style":2123},"import { createPage } from '@nuxt/test-utils/e2e'\n\nconst page = await createPage('/page')\n// you can access all the Playwright APIs from the `page` variable\n",[2045,7071,7072,7090,7094,7117],{"__ignoreMap":2123},[2127,7073,7074,7076,7078,7080,7082,7084,7086,7088],{"class":2129,"line":2130},[2127,7075,2359],{"class":2282},[2127,7077,2362],{"class":2297},[2127,7079,6574],{"class":2293},[2127,7081,2368],{"class":2297},[2127,7083,2371],{"class":2282},[2127,7085,2374],{"class":2297},[2127,7087,5272],{"class":2136},[2127,7089,2380],{"class":2297},[2127,7091,7092],{"class":2129,"line":2301},[2127,7093,2405],{"emptyLinePlaceholder":1196},[2127,7095,7096,7098,7101,7103,7105,7107,7109,7111,7113,7115],{"class":2129,"line":2314},[2127,7097,4430],{"class":2986},[2127,7099,7100],{"class":2293}," page ",[2127,7102,6871],{"class":2297},[2127,7104,3649],{"class":2282},[2127,7106,6574],{"class":2289},[2127,7108,2294],{"class":2293},[2127,7110,2322],{"class":2297},[2127,7112,7022],{"class":2136},[2127,7114,2322],{"class":2297},[2127,7116,2342],{"class":2293},[2127,7118,7119],{"class":2129,"line":2328},[2127,7120,7121],{"class":2851},"// you can access all the Playwright APIs from the `page` variable\n",[2777,7123,7125],{"id":7124},"testing-with-playwright-test-runner","Testing with Playwright Test Runner",[2033,7127,7128,7129,2040],{},"We also provide first-class support for testing Nuxt within ",[2037,7130,7133],{"href":7131,"rel":7132},"https://playwright.dev/docs/intro",[2053],"the Playwright test runner",[2113,7135,7136,7155,7172,7189,7206],{"sync":2115},[2117,7137,7139],{"className":2119,"code":7138,"filename":2121,"language":2122,"meta":2123,"style":2123},"npm i --save-dev @playwright/test @nuxt/test-utils\n",[2045,7140,7141],{"__ignoreMap":2123},[2127,7142,7143,7145,7147,7149,7152],{"class":2129,"line":2130},[2127,7144,2121],{"class":2133},[2127,7146,2137],{"class":2136},[2127,7148,2140],{"class":2136},[2127,7150,7151],{"class":2136}," @playwright/test",[2127,7153,7154],{"class":2136}," @nuxt/test-utils\n",[2117,7156,7158],{"className":2119,"code":7157,"filename":2159,"language":2122,"meta":2123,"style":2123},"yarn add --dev @playwright/test @nuxt/test-utils\n",[2045,7159,7160],{"__ignoreMap":2123},[2127,7161,7162,7164,7166,7168,7170],{"class":2129,"line":2130},[2127,7163,2159],{"class":2133},[2127,7165,2168],{"class":2136},[2127,7167,2171],{"class":2136},[2127,7169,7151],{"class":2136},[2127,7171,7154],{"class":2136},[2117,7173,7175],{"className":2119,"code":7174,"filename":2185,"language":2122,"meta":2123,"style":2123},"pnpm add -D @playwright/test @nuxt/test-utils\n",[2045,7176,7177],{"__ignoreMap":2123},[2127,7178,7179,7181,7183,7185,7187],{"class":2129,"line":2130},[2127,7180,2185],{"class":2133},[2127,7182,2168],{"class":2136},[2127,7184,2196],{"class":2136},[2127,7186,7151],{"class":2136},[2127,7188,7154],{"class":2136},[2117,7190,7192],{"className":2119,"code":7191,"filename":2210,"language":2122,"meta":2123,"style":2123},"bun add --dev @playwright/test @nuxt/test-utils\n",[2045,7193,7194],{"__ignoreMap":2123},[2127,7195,7196,7198,7200,7202,7204],{"class":2129,"line":2130},[2127,7197,2210],{"class":2133},[2127,7199,2168],{"class":2136},[2127,7201,2171],{"class":2136},[2127,7203,7151],{"class":2136},[2127,7205,7154],{"class":2136},[2117,7207,7210],{"className":2119,"code":7208,"filename":7209,"language":2122,"meta":2123,"style":2123},"deno add --dev npm:@playwright/test npm:@nuxt/test-utils\n","deno",[2045,7211,7212],{"__ignoreMap":2123},[2127,7213,7214,7216,7218,7220,7223],{"class":2129,"line":2130},[2127,7215,7209],{"class":2133},[2127,7217,2168],{"class":2136},[2127,7219,2171],{"class":2136},[2127,7221,7222],{"class":2136}," npm:@playwright/test",[2127,7224,7225],{"class":2136}," npm:@nuxt/test-utils\n",[2033,7227,7228,7229,7232],{},"You can provide global Nuxt configuration, with the same configuration details as the ",[2045,7230,7231],{},"setup()"," function mentioned earlier in this section.",[2117,7234,7237],{"className":2272,"code":7235,"filename":7236,"language":2274,"meta":2123,"style":2123},"import { fileURLToPath } from 'node:url'\nimport { defineConfig, devices } from '@playwright/test'\nimport type { ConfigOptions } from '@nuxt/test-utils/playwright'\n\nexport default defineConfig\u003CConfigOptions>({\n  use: {\n    nuxt: {\n      rootDir: fileURLToPath(new URL('.', import.meta.url)),\n    },\n  },\n  // ...\n})\n","playwright.config.ts",[2045,7238,7239,7259,7282,7305,7309,7328,7337,7346,7387,7391,7395,7400],{"__ignoreMap":2123},[2127,7240,7241,7243,7245,7248,7250,7252,7254,7257],{"class":2129,"line":2130},[2127,7242,2359],{"class":2282},[2127,7244,2362],{"class":2297},[2127,7246,7247],{"class":2293}," fileURLToPath",[2127,7249,2368],{"class":2297},[2127,7251,2371],{"class":2282},[2127,7253,2374],{"class":2297},[2127,7255,7256],{"class":2136},"node:url",[2127,7258,2380],{"class":2297},[2127,7260,7261,7263,7265,7267,7269,7272,7274,7276,7278,7280],{"class":2129,"line":2301},[2127,7262,2359],{"class":2282},[2127,7264,2362],{"class":2297},[2127,7266,2365],{"class":2293},[2127,7268,2980],{"class":2297},[2127,7270,7271],{"class":2293}," devices",[2127,7273,2368],{"class":2297},[2127,7275,2371],{"class":2282},[2127,7277,2374],{"class":2297},[2127,7279,2110],{"class":2136},[2127,7281,2380],{"class":2297},[2127,7283,7284,7286,7289,7291,7294,7296,7298,7300,7303],{"class":2129,"line":2314},[2127,7285,2359],{"class":2282},[2127,7287,7288],{"class":2282}," type",[2127,7290,2362],{"class":2297},[2127,7292,7293],{"class":2293}," ConfigOptions",[2127,7295,2368],{"class":2297},[2127,7297,2371],{"class":2282},[2127,7299,2374],{"class":2297},[2127,7301,7302],{"class":2136},"@nuxt/test-utils/playwright",[2127,7304,2380],{"class":2297},[2127,7306,7307],{"class":2129,"line":2328},[2127,7308,2405],{"emptyLinePlaceholder":1196},[2127,7310,7311,7313,7315,7317,7319,7322,7324,7326],{"class":2129,"line":2336},[2127,7312,2283],{"class":2282},[2127,7314,2286],{"class":2282},[2127,7316,2365],{"class":2289},[2127,7318,5779],{"class":2297},[2127,7320,7321],{"class":2133},"ConfigOptions",[2127,7323,5795],{"class":2297},[2127,7325,2294],{"class":2293},[2127,7327,2298],{"class":2297},[2127,7329,7330,7333,7335],{"class":2129,"line":2430},[2127,7331,7332],{"class":2304},"  use",[2127,7334,2308],{"class":2297},[2127,7336,2427],{"class":2297},[2127,7338,7339,7342,7344],{"class":2129,"line":2440},[2127,7340,7341],{"class":2304},"    nuxt",[2127,7343,2308],{"class":2297},[2127,7345,2427],{"class":2297},[2127,7347,7348,7351,7353,7355,7357,7360,7363,7365,7367,7369,7371,7373,7375,7377,7380,7382,7385],{"class":2129,"line":2446},[2127,7349,7350],{"class":2304},"      rootDir",[2127,7352,2308],{"class":2297},[2127,7354,7247],{"class":2289},[2127,7356,2294],{"class":2293},[2127,7358,7359],{"class":2297},"new",[2127,7361,7362],{"class":2289}," URL",[2127,7364,2294],{"class":2293},[2127,7366,2322],{"class":2297},[2127,7368,2040],{"class":2136},[2127,7370,2322],{"class":2297},[2127,7372,2980],{"class":2297},[2127,7374,4839],{"class":2282},[2127,7376,2040],{"class":2297},[2127,7378,7379],{"class":2293},"meta",[2127,7381,2040],{"class":2297},[2127,7383,7384],{"class":2293},"url))",[2127,7386,2325],{"class":2297},[2127,7388,7389],{"class":2129,"line":2456},[2127,7390,3209],{"class":2297},[2127,7392,7393],{"class":2129,"line":2473},[2127,7394,2699],{"class":2297},[2127,7396,7397],{"class":2129,"line":2496},[2127,7398,7399],{"class":2851},"  // ...\n",[2127,7401,7402,7404],{"class":2129,"line":2513},[2127,7403,2339],{"class":2297},[2127,7405,2342],{"class":2293},[7407,7408],"read-more",{"target":7409,"title":7410,"to":7411},"_blank","See full example config","https://github.com/nuxt/test-utils/blob/main/examples/app-playwright/playwright.config.ts",[2033,7413,7414,7415,2081,7418,7420,7421,2308],{},"Your test file should then use ",[2045,7416,7417],{},"expect",[2045,7419,2968],{}," directly from ",[2045,7422,7302],{},[2117,7424,7427],{"className":2272,"code":7425,"filename":7426,"language":2274,"meta":2123,"style":2123},"import { expect, test } from '@nuxt/test-utils/playwright'\n\ntest('test', async ({ page, goto }) => {\n  await goto('/', { waitUntil: 'hydration' })\n  await expect(page.getByRole('heading')).toHaveText('Welcome to Playwright!')\n})\n","tests/example.test.ts",[2045,7428,7429,7451,7455,7488,7522,7565],{"__ignoreMap":2123},[2127,7430,7431,7433,7435,7437,7439,7441,7443,7445,7447,7449],{"class":2129,"line":2130},[2127,7432,2359],{"class":2282},[2127,7434,2362],{"class":2297},[2127,7436,5838],{"class":2293},[2127,7438,2980],{"class":2297},[2127,7440,2949],{"class":2293},[2127,7442,2368],{"class":2297},[2127,7444,2371],{"class":2282},[2127,7446,2374],{"class":2297},[2127,7448,7302],{"class":2136},[2127,7450,2380],{"class":2297},[2127,7452,7453],{"class":2129,"line":2301},[2127,7454,2405],{"emptyLinePlaceholder":1196},[2127,7456,7457,7459,7461,7463,7465,7467,7469,7471,7474,7476,7478,7481,7484,7486],{"class":2129,"line":2314},[2127,7458,2968],{"class":2289},[2127,7460,2294],{"class":2293},[2127,7462,2322],{"class":2297},[2127,7464,2968],{"class":2136},[2127,7466,2322],{"class":2297},[2127,7468,2980],{"class":2297},[2127,7470,3629],{"class":2986},[2127,7472,7473],{"class":2297}," ({",[2127,7475,6707],{"class":4708},[2127,7477,2980],{"class":2297},[2127,7479,7480],{"class":4708}," goto",[2127,7482,7483],{"class":2297}," })",[2127,7485,2987],{"class":2986},[2127,7487,2427],{"class":2297},[2127,7489,7490,7492,7494,7496,7498,7500,7502,7504,7506,7509,7511,7513,7516,7518,7520],{"class":2129,"line":2328},[2127,7491,4020],{"class":2282},[2127,7493,7480],{"class":2282},[2127,7495,2294],{"class":2304},[2127,7497,2322],{"class":2297},[2127,7499,6882],{"class":2136},[2127,7501,2322],{"class":2297},[2127,7503,2980],{"class":2297},[2127,7505,2362],{"class":2297},[2127,7507,7508],{"class":2304}," waitUntil",[2127,7510,2308],{"class":2297},[2127,7512,2374],{"class":2297},[2127,7514,7515],{"class":2136},"hydration",[2127,7517,2322],{"class":2297},[2127,7519,2368],{"class":2297},[2127,7521,2342],{"class":2304},[2127,7523,7524,7526,7528,7530,7533,7535,7538,7540,7542,7545,7547,7549,7551,7554,7556,7558,7561,7563],{"class":2129,"line":2336},[2127,7525,4020],{"class":2282},[2127,7527,5838],{"class":2289},[2127,7529,2294],{"class":2304},[2127,7531,7532],{"class":2293},"page",[2127,7534,2040],{"class":2297},[2127,7536,7537],{"class":2289},"getByRole",[2127,7539,2294],{"class":2304},[2127,7541,2322],{"class":2297},[2127,7543,7544],{"class":2136},"heading",[2127,7546,2322],{"class":2297},[2127,7548,4053],{"class":2304},[2127,7550,2040],{"class":2297},[2127,7552,7553],{"class":2289},"toHaveText",[2127,7555,2294],{"class":2304},[2127,7557,2322],{"class":2297},[2127,7559,7560],{"class":2136},"Welcome to Playwright!",[2127,7562,2322],{"class":2297},[2127,7564,2342],{"class":2304},[2127,7566,7567,7569],{"class":2129,"line":2430},[2127,7568,2339],{"class":2297},[2127,7570,2342],{"class":2293},[2033,7572,7573],{},"You can alternatively configure your Nuxt server directly within your test file:",[2117,7575,7577],{"className":2272,"code":7576,"filename":7426,"language":2274,"meta":2123,"style":2123},"import { expect, test } from '@nuxt/test-utils/playwright'\n\ntest.use({\n  nuxt: {\n    rootDir: fileURLToPath(new URL('..', import.meta.url)),\n  },\n})\n\ntest('test', async ({ page, goto }) => {\n  await goto('/', { waitUntil: 'hydration' })\n  await expect(page.getByRole('heading')).toHaveText('Welcome to Playwright!')\n})\n",[2045,7578,7579,7601,7605,7618,7627,7665,7669,7675,7679,7709,7741,7779],{"__ignoreMap":2123},[2127,7580,7581,7583,7585,7587,7589,7591,7593,7595,7597,7599],{"class":2129,"line":2130},[2127,7582,2359],{"class":2282},[2127,7584,2362],{"class":2297},[2127,7586,5838],{"class":2293},[2127,7588,2980],{"class":2297},[2127,7590,2949],{"class":2293},[2127,7592,2368],{"class":2297},[2127,7594,2371],{"class":2282},[2127,7596,2374],{"class":2297},[2127,7598,7302],{"class":2136},[2127,7600,2380],{"class":2297},[2127,7602,7603],{"class":2129,"line":2301},[2127,7604,2405],{"emptyLinePlaceholder":1196},[2127,7606,7607,7609,7611,7614,7616],{"class":2129,"line":2314},[2127,7608,2968],{"class":2293},[2127,7610,2040],{"class":2297},[2127,7612,7613],{"class":2289},"use",[2127,7615,2294],{"class":2293},[2127,7617,2298],{"class":2297},[2127,7619,7620,7623,7625],{"class":2129,"line":2328},[2127,7621,7622],{"class":2304},"  nuxt",[2127,7624,2308],{"class":2297},[2127,7626,2427],{"class":2297},[2127,7628,7629,7632,7634,7636,7638,7640,7642,7644,7646,7649,7651,7653,7655,7657,7659,7661,7663],{"class":2129,"line":2336},[2127,7630,7631],{"class":2304},"    rootDir",[2127,7633,2308],{"class":2297},[2127,7635,7247],{"class":2289},[2127,7637,2294],{"class":2293},[2127,7639,7359],{"class":2297},[2127,7641,7362],{"class":2289},[2127,7643,2294],{"class":2293},[2127,7645,2322],{"class":2297},[2127,7647,7648],{"class":2136},"..",[2127,7650,2322],{"class":2297},[2127,7652,2980],{"class":2297},[2127,7654,4839],{"class":2282},[2127,7656,2040],{"class":2297},[2127,7658,7379],{"class":2293},[2127,7660,2040],{"class":2297},[2127,7662,7384],{"class":2293},[2127,7664,2325],{"class":2297},[2127,7666,7667],{"class":2129,"line":2430},[2127,7668,2699],{"class":2297},[2127,7670,7671,7673],{"class":2129,"line":2440},[2127,7672,2339],{"class":2297},[2127,7674,2342],{"class":2293},[2127,7676,7677],{"class":2129,"line":2446},[2127,7678,2405],{"emptyLinePlaceholder":1196},[2127,7680,7681,7683,7685,7687,7689,7691,7693,7695,7697,7699,7701,7703,7705,7707],{"class":2129,"line":2456},[2127,7682,2968],{"class":2289},[2127,7684,2294],{"class":2293},[2127,7686,2322],{"class":2297},[2127,7688,2968],{"class":2136},[2127,7690,2322],{"class":2297},[2127,7692,2980],{"class":2297},[2127,7694,3629],{"class":2986},[2127,7696,7473],{"class":2297},[2127,7698,6707],{"class":4708},[2127,7700,2980],{"class":2297},[2127,7702,7480],{"class":4708},[2127,7704,7483],{"class":2297},[2127,7706,2987],{"class":2986},[2127,7708,2427],{"class":2297},[2127,7710,7711,7713,7715,7717,7719,7721,7723,7725,7727,7729,7731,7733,7735,7737,7739],{"class":2129,"line":2473},[2127,7712,4020],{"class":2282},[2127,7714,7480],{"class":2282},[2127,7716,2294],{"class":2304},[2127,7718,2322],{"class":2297},[2127,7720,6882],{"class":2136},[2127,7722,2322],{"class":2297},[2127,7724,2980],{"class":2297},[2127,7726,2362],{"class":2297},[2127,7728,7508],{"class":2304},[2127,7730,2308],{"class":2297},[2127,7732,2374],{"class":2297},[2127,7734,7515],{"class":2136},[2127,7736,2322],{"class":2297},[2127,7738,2368],{"class":2297},[2127,7740,2342],{"class":2304},[2127,7742,7743,7745,7747,7749,7751,7753,7755,7757,7759,7761,7763,7765,7767,7769,7771,7773,7775,7777],{"class":2129,"line":2496},[2127,7744,4020],{"class":2282},[2127,7746,5838],{"class":2289},[2127,7748,2294],{"class":2304},[2127,7750,7532],{"class":2293},[2127,7752,2040],{"class":2297},[2127,7754,7537],{"class":2289},[2127,7756,2294],{"class":2304},[2127,7758,2322],{"class":2297},[2127,7760,7544],{"class":2136},[2127,7762,2322],{"class":2297},[2127,7764,4053],{"class":2304},[2127,7766,2040],{"class":2297},[2127,7768,7553],{"class":2289},[2127,7770,2294],{"class":2304},[2127,7772,2322],{"class":2297},[2127,7774,7560],{"class":2136},[2127,7776,2322],{"class":2297},[2127,7778,2342],{"class":2304},[2127,7780,7781,7783],{"class":2129,"line":2513},[2127,7782,2339],{"class":2297},[2127,7784,2342],{"class":2293},[7786,7787,7788],"style",{},"html pre.shiki code .s52Pk, html code.shiki .s52Pk{--shiki-light:#E2931D;--shiki-default:#E2931D;--shiki-dark:#FFCB6B}html pre.shiki code .sGFVr, html code.shiki .sGFVr{--shiki-light:#91B859;--shiki-default:#91B859;--shiki-dark:#C3E88D}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s8R28, html code.shiki .s8R28{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#39ADB5;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .s3cPz, html code.shiki .s3cPz{--shiki-light:#6182B8;--shiki-default:#6182B8;--shiki-dark:#82AAFF}html pre.shiki code .sZSNi, html code.shiki .sZSNi{--shiki-light:#90A4AE;--shiki-default:#90A4AE;--shiki-dark:#BABED8}html pre.shiki code .sDfIl, html code.shiki .sDfIl{--shiki-light:#39ADB5;--shiki-default:#39ADB5;--shiki-dark:#89DDFF}html pre.shiki code .sRlkE, html code.shiki .sRlkE{--shiki-light:#E53935;--shiki-default:#E53935;--shiki-dark:#F07178}html pre.shiki code .sWuyu, html code.shiki .sWuyu{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#90A4AE;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .smZ93, html code.shiki .smZ93{--shiki-light:#9C3EDA;--shiki-default:#9C3EDA;--shiki-dark:#C792EA}html pre.shiki code .sbKd-, html code.shiki .sbKd-{--shiki-light:#FF5370;--shiki-default:#FF5370;--shiki-dark:#FF9CAC}html pre.shiki code .s1nJG, html code.shiki .s1nJG{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#90A4AE;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .sYRBq, html code.shiki .sYRBq{--shiki-light:#F76D47;--shiki-default:#F76D47;--shiki-dark:#F78C6C}",{"title":2123,"searchDepth":2301,"depth":2301,"links":7790},[7791,7792,7801],{"id":2064,"depth":2301,"text":24},{"id":2233,"depth":2301,"text":2234,"children":7793},[7794,7795,7796,7797,7798,7799],{"id":2254,"depth":2314,"text":2255},{"id":2742,"depth":2314,"text":2743},{"id":3013,"depth":2314,"text":3014},{"id":3341,"depth":2314,"text":3342},{"id":3513,"depth":2314,"text":3514},{"id":5456,"depth":2314,"text":7800},"Using @vue/test-utils",{"id":6067,"depth":2301,"text":6068,"children":7802},[7803,7804,7805],{"id":6095,"depth":2314,"text":2255},{"id":6824,"depth":2314,"text":6825},{"id":7034,"depth":2314,"text":7035},"How to test your Nuxt application.","md",{},{"icon":102},{"title":99,"description":7806},"04m1fMZ_77gDN3u2If1s3qyldDRsrd4Pp8EoLw0_8Vc",[7813,7815],{"title":94,"path":1174,"stem":1175,"description":7814,"icon":97,"children":-1},"Learn how to deploy your Nuxt application to any hosting provider.",{"title":104,"path":1180,"stem":1181,"description":7816,"icon":107,"children":-1},"Learn how to upgrade to the latest Nuxt version.",1770834940766]