Security News
vlt Debuts New JavaScript Package Manager and Serverless Registry at NodeConf EU
vlt introduced its new package manager and a serverless registry this week, innovating in a space where npm has stagnated.
vitest-environment-nuxt
Advanced tools
An vitest environment with support for testing code that needs a Nuxt runtime environment.
A vitest environment for testing code that needs a Nuxt runtime environment
Warning This library is in active development and you should pin the patch version before using.
nuxt-vitest
:pnpm add -D nuxt-vitest vitest happy-dom
# or
yarn add --dev nuxt-vitest vitest happy-dom
npm i -D nuxt-vitest vitest happy-dom
nuxt-vitest
to your nuxt.config.js
:export default defineNuxtConfig({
// ...
modules: [
'nuxt-vitest'
]
})
vitest.config.mjs
with the following content:import { defineVitestConfig } from 'nuxt-vitest/config'
export default defineVitestConfig({
// any custom vitest config you require
})
By default, nuxt-vitest
will not change your default Vitest environment, so you can do fine-grain opt-in and run Nuxt tests together with other unit tests.
We provided a filename convention that test files contains .nuxt.
, like *.nuxt.test.{js,ts}
and *.nuxt.spec.{js,ts}
, will be run in Nuxt environment automatically.
Or you can add @vitest-environment nuxt
in your test file as a comment to opt-in per test file.
// @vitest-environment nuxt
import { test } from 'vitest'
test('my test', () => {
// ... test with Nuxt environment!
})
Finally, you can set environment: 'nuxt'
, to enable Nuxt environment for all tests.
// vitest.config.ts
import { fileURLToPath } from 'node:url'
import { defineVitestConfig } from 'nuxt-vitest/config'
export default defineVitestConfig({
test: {
environment: 'nuxt',
// you can optionally set nuxt-specific environment options
// environmentOptions: {
// nuxt: {
// rootDir: fileURLToPath(new URL('./playground', import.meta.url)),
// overrides: {
// // other nuxt config you want to pass
// }
// }
// }
}
})
If you have set environment: 'nuxt'
by default, you can then opt-out of the default environment per test file as needed.
// @vitest-environment node
import { test } from 'vitest'
test('my test', () => {
// ... test without Nuxt environment!
})
When you run your tests within the Nuxt environment, they will be running in a happy-dom
environment. Before your tests run, a global Nuxt app will be initialised (including, for example, running any plugins or code you've defined in your app.vue
).
This means you should be take particular care not to mutate the global state in your tests (or, if you have, to reset it afterwards).
nuxt-vitest
provides a number of helpers to make testing Nuxt apps easier.
mountSuspended
mountSuspended
allows you to mount any vue component within the Nuxt environment, allowing async setup and access to injections from your Nuxt plugins. For example:
// tests/components/SomeComponents.nuxt.spec.ts
it('can mount some component', async () => {
const component = await mountSuspended(SomeComponent)
expect(component.text()).toMatchInlineSnapshot(
'This is an auto-imported component'
)
})
// tests/App.nuxt.spec.ts
it('can also mount an app', async () => {
const component = await mountSuspended(App, { route: '/test' })
expect(component.html()).toMatchInlineSnapshot(`
"<div>This is an auto-imported component</div>
<div> I am a global component </div>
<div>/</div>
<a href=\\"/test\\"> Test link </a>"
`)
})
renderSuspended
renderSuspended
allows you to render any vue component within the Nuxt environment using @testing-library/vue
, allowing async setup and access to injections from your Nuxt plugins.
This should be used together with utilities from testing-library, e.g. screen
and fireEvent
. Install @testing-library/vue in your project to use these.
Additionally testing-library also relies on testing globals for cleanup. You should turn these on in your Vitest config.
The passed in component will be rendered inside a <div id="test-wrapper"></div>
.
Examples:
// tests/components/SomeComponents.nuxt.spec.ts
import { renderSuspended } from 'nuxt-vitest/utils'
import { screen } from '@testing-library/vue'
it('can render some component', async () => {
await renderSuspended(SomeComponent)
expect(screen.getByText('This is an auto-imported component')).toBeDefined()
})
// tests/App.nuxt.spec.ts
import { renderSuspended } from 'nuxt-vitest/utils'
it('can also render an app', async () => {
const html = await renderSuspended(App, { route: '/test' })
expect(html()).toMatchInlineSnapshot(`
"<div id=\\"test-wrapper\\">
<div>This is an auto-imported component</div>
<div> I am a global component </div>
<div>Index page</div><a href=\\"/test\\"> Test link </a>
</div>"
`)
})
mockNuxtImport
mockNuxtImport
allows you to mock Nuxt's auto import functionality. For example, to mock useStorage
, you can do so like this:
import { mockNuxtImport } from 'nuxt-vitest/utils'
mockNuxtImport('useStorage', () => {
return () => {
return { value: 'mocked storage' }
}
})
// your tests here
Note:
mockNuxtImport
can only be used once per mocked import per test file. It is actually a macro that gets transformed tovi.mock
andvi.mock
is hoisted, as described here.
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 vi.hoisted
, and then use those mocks in mockNuxtImport
. You then have access to the mocked imports, and can change the implementation between tests. Be careful to restore mocks before or after each test to undo mock state changes between runs.
import { vi } from 'vitest'
import { mockNuxtImport } from 'nuxt-vitest/utils'
const { useStorageMock } = vi.hoisted(() => {
return {
useStorageMock: vi.fn().mockImplementation(() => {
return { value: 'mocked storage'}
})
}
})
mockNuxtImport('useStorage', () => {
return useStorageMock
})
// Then, inside a test
useStorageMock.mockImplementation(() => {
return { value: 'something else' }
})
mockComponent
mockComponent
allows you to mock Nuxt's component.
The first argument can be the component name in PascalCase, or the relative path of the component.
The second argument is a factory function that returns the mocked component.
For example, to mock MyComponent
, you can:
import { mockComponent } from 'nuxt-vitest/utils'
mockComponent('MyComponent', {
props: {
value: String
},
setup(props) {
// ...
}
})
// relative path or alias also works
mockComponent('~/components/my-component.vue', async () => {
// or a factory function
return {
setup(props) {
// ...
}
}
})
// or you can use SFC for redirecting to a mock component
mockComponent('MyComponent', () => import('./MockComponent.vue'))
// your tests here
Note: You can't reference to 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.
mockComponent('MyComponent', async () => {
const { ref, h } = await import('vue')
return {
setup(props) {
const counter = ref(0)
return () => h('div', null, counter.value)
}
}
})
registerEndpoint
registerEndpoint
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.
The first argument is the endpoint name (e.g. /test/
).
The second argument is a factory function that returns the mocked data.
For example, to mock /test/
endpoint, you can do:
import { registerEndpoint } from 'nuxt-vitest/utils'
registerEndpoint("/test/", () => ({
test: "test-field"
}))
Note: If your requests in a component go to external API, you can use
baseURL
and then make it empty using Nuxt Enviroment Config ($test
) so all your requests will go to Nitro server.
nuxt-vitest
and @nuxt/test-utils
need to run in different testing environments and so can't be used in the same file.
If you would like to use @nuxt/test-utils
to conduct end-to-end tests on your Nuxt app, you can split your tests into separate files. You then either specify a test environment per-file with the special // @vitest-environment nuxt
comment, or name your nuxt-vitest
files with the .nuxt.spec.ts
extension.
app.nuxt.spec.js
import { mockNuxtImport } from "nuxt-vitest/utils";
mockNuxtImport('useStorage', () => {
return () => {
return { value: 'mocked storage' }
}
})
app.e2e.spec.js
import { setup, $fetch } from '@nuxt/test-utils';
await setup({
setupTimeout: 10000,
});
// ...
corepack enable
(use npm i -g corepack
for Node.js < 16.10)pnpm install
pnpm dev:prepare
pnpm test
Made with ❤️
Published under the MIT License.
FAQs
Unknown package
The npm package vitest-environment-nuxt receives a total of 114,690 weekly downloads. As such, vitest-environment-nuxt popularity was classified as popular.
We found that vitest-environment-nuxt demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
vlt introduced its new package manager and a serverless registry this week, innovating in a space where npm has stagnated.
Security News
Research
The Socket Research Team uncovered a malicious Python package typosquatting the popular 'fabric' SSH library, silently exfiltrating AWS credentials from unsuspecting developers.
Security News
At its inaugural meeting, the JSR Working Group outlined plans for an open governance model and a roadmap to enhance JavaScript package management.