home / skills / partme-ai / full-stack-skills / vitest
This skill helps you set up, configure, and write fast, reliable unit and component tests with Vitest in Vite projects.
npx playbooks add skill partme-ai/full-stack-skills --skill vitestReview the files below or copy the command above to add this skill to your agents.
---
name: vitest
description: Provides comprehensive guidance for Vitest testing framework including fast test execution, Vite integration, component testing, mocking, and configuration. Use when the user asks about Vitest, needs to write fast unit tests, test Vue/React components, or configure Vitest with Vite projects.
license: Complete terms in LICENSE.txt
---
## When to use this skill
Use this skill whenever the user wants to:
- Set up Vitest in a Vite project
- Write unit tests and component tests
- Configure Vitest for different environments
- Use Vitest API and utilities
- Test Vue, React, or Svelte components
- Use browser mode for testing
- Set up visual regression testing
- Mock functions and modules
- Use snapshots for testing
- Configure test coverage
- Use Vitest UI
- Optimize test performance
- Debug tests
- Understand Vitest best practices
- Troubleshoot Vitest issues
## How to use this skill
This skill is organized to match the Vitest official documentation structure (https://vitest.dev/guide/, https://vitest.dev/api/, https://vitest.dev/config/). When working with Vitest:
1. **Identify the topic** from the user's request:
- Getting started/快速开始 → `examples/getting-started.md`
- Features/功能特性 → `examples/features.md`
- Component testing/组件测试 → `examples/component-testing.md`
- Browser mode/浏览器模式 → `examples/browser-mode.md`
- API/API 文档 → `api/`
- Configuration/配置 → `examples/config/`
2. **Load the appropriate example file** from the `examples/` directory:
**Getting Started (快速开始)**:
- `examples/getting-started.md` - Installation and first test
**Features (功能特性)**:
- `examples/features.md` - Key features and capabilities
- `examples/ui.md` - Vitest UI
- `examples/component-testing.md` - Component testing
- `examples/browser-mode.md` - Browser mode testing
- `examples/visual-regression-testing.md` - Visual regression testing
- `examples/trace-view.md` - Trace view
**Testing (测试)**:
- `examples/test-api.md` - Test API (test, it, describe, etc.)
- `examples/mocking.md` - Mocking functions and modules
- `examples/snapshots.md` - Snapshot testing
- `examples/coverage.md` - Code coverage
**Configuration (配置)**:
- `examples/config/basic-config.md` - Basic configuration
- `examples/config/environment.md` - Environment configuration
- `examples/config/browser-config.md` - Browser mode configuration
3. **Follow the specific instructions** in that example file for syntax, structure, and best practices
**Important Notes**:
- Vitest is designed for Vite projects
- Supports TypeScript, JSX, ESM out of the box
- Fast watch mode with HMR-like experience
- Compatible with Jest API
- Examples include both JavaScript and TypeScript versions
- Each example file includes key concepts, code examples, and key points
4. **Reference API documentation** in the `api/` directory when needed:
- `api/test-api.md` - Test API reference
- `api/vi-utility.md` - vi utility functions
- `api/expect.md` - Expect assertions
- `api/mocking.md` - Mocking API
5. **Use templates** from the `templates/` directory:
- `templates/vitest-config.md` - Vitest configuration templates
- `templates/test-examples.md` - Test example templates
### Doc mapping (one-to-one with https://vitest.dev/guide/, https://vitest.dev/api/, https://vitest.dev/config/)
**Guide (指南)**:
- `examples/getting-started.md` → https://vitest.dev/guide/getting-started.html
- `examples/features.md` → https://vitest.dev/guide/features.html
- `examples/ui.md` → https://vitest.dev/guide/ui.html
- `examples/component-testing.md` → https://vitest.dev/guide/testing-components.html
- `examples/browser-mode.md` → https://vitest.dev/guide/browser.html
- `examples/visual-regression-testing.md` → https://vitest.dev/guide/visual-regression.html
- `examples/trace-view.md` → https://vitest.dev/guide/trace-view.html
- `examples/mocking.md` → https://vitest.dev/guide/mocking.html
- `examples/snapshots.md` → https://vitest.dev/guide/snapshot.html
- `examples/coverage.md` → https://vitest.dev/guide/coverage.html
**Configuration (配置)**:
- `examples/config/basic-config.md` → https://vitest.dev/config/
- `examples/config/environment.md` → https://vitest.dev/config/#environment
- `examples/config/browser-config.md` → https://vitest.dev/config/#browser
**API Reference**:
- `api/test-api.md` → https://vitest.dev/api/
- `api/vi-utility.md` → https://vitest.dev/api/vi.html
- `api/expect.md` → https://vitest.dev/api/expect.html
- `api/mocking.md` → https://vitest.dev/api/vi.html
## Examples and Templates
This skill includes detailed examples organized to match the official documentation structure. All examples are in the `examples/` directory (see mapping above).
**To use examples:**
- Identify the topic from the user's request
- Load the appropriate example file from the mapping above
- Follow the instructions, syntax, and best practices in that file
- Adapt the code examples to your specific use case
**To use templates:**
- Reference templates in `templates/` directory for common scaffolding
- Adapt templates to your specific needs and coding style
## Best Practices
1. **Use watch mode**: Leverage Vitest's smart watch mode for faster feedback
2. **Organize tests**: Group related tests with describe blocks
3. **Use TypeScript**: Take advantage of native TypeScript support
4. **Mock effectively**: Use vi.mock() for module mocking
5. **Test components**: Use component testing for Vue/React components
6. **Use UI mode**: Use `--ui` flag for better test debugging experience
7. **Optimize performance**: Use test.only() during development
## Resources
- **Official Documentation**: https://vitest.dev/
- **Getting Started**: https://vitest.dev/guide/
- **API Reference**: https://vitest.dev/api/
- **Configuration**: https://vitest.dev/config/
- **GitHub Repository**: https://github.com/vitest-dev/vitest
## Keywords
Vitest, vitest, test framework, unit testing, component testing, Vite, Jest compatible, watch mode, HMR, TypeScript, ESM, mocking, snapshots, coverage, browser mode, visual regression testing, 测试框架, 单元测试, 组件测试, 监视模式, 热模块替换, 模拟, 快照, 覆盖率, 浏览器模式, 视觉回归测试
This skill provides comprehensive, practical guidance for using Vitest, the fast Vite-native testing framework. It covers setup, configuration, API usage, component testing for Vue/React/Svelte, mocking, snapshots, coverage, browser mode, and performance tips. Use it to write fast, reliable unit and component tests and to integrate Vitest into Vite projects. The content maps to official Vitest topics and includes examples and templates for common scenarios.
The skill maps user requests to focused examples and API references that mirror Vitest documentation, delivering step-by-step instructions and code snippets for each topic. It directs you to configuration templates, test and mocking patterns, component-testing workflows, and the Vi utility API for advanced mocking and spies. Guidance is organized so you can quickly find getting-started instructions, configuration options, and component/browser-specific examples. Practical notes explain trade-offs, performance considerations, and debugging techniques.
Is Vitest compatible with Jest tests?
Many Jest APIs are supported; migrating usually requires small API adjustments and config updates since Vitest is Vite-native and ESM-first.
How do I test components that use Vite plugins or custom aliases?
Ensure your vitest.config exports the same Vite resolve.alias and plugin configuration so component tests use the same module resolution and transforms.