Agent skill
vitest_runner
Modern JavaScript/TypeScript testing with Vitest including mocking and coverage.
Stars
163
Forks
31
Install this agent skill to your Project
npx add-skill https://github.com/majiayu000/claude-skill-registry/tree/main/skills/data/vitest-runner-vuralserhat86-antigravity-agentic
Metadata
Additional technical details for this skill
- skillport
-
{ "tags": [ "architecture", "assertions", "automation", "best practices", "clean code", "coding", "collaboration", "compliance", "debugging", "design patterns", "development", "documentation", "efficiency", "git", "jest compatible", "mocking", "optimization", "productivity", "programming", "project management", "quality assurance", "refactoring", "software engineering", "standards", "testing", "unit testing", "utilities", "version control", "vite", "vitest runner", "workflow" ], "category": "auto-healed" }
SKILL.md
Vitest
Description
Modern JavaScript/TypeScript testing with Vitest including mocking and coverage.
When to Use
- Testing JavaScript/TypeScript
- React component testing
- Unit and integration tests
Core Patterns
Basic Tests
typescript
import { describe, it, expect } from 'vitest';
describe('math', () => {
it('should add numbers', () => {
expect(1 + 1).toBe(2);
});
it('should throw on invalid input', () => {
expect(() => divide(1, 0)).toThrow('Division by zero');
});
});
Mocking
typescript
import { vi, describe, it, expect } from 'vitest';
// Mock module
vi.mock('./api', () => ({
fetchUser: vi.fn().mockResolvedValue({ id: 1 })
}));
// Mock function
const callback = vi.fn();
callback('arg');
expect(callback).toHaveBeenCalledWith('arg');
Async Tests
typescript
it('should fetch data', async () => {
const data = await fetchData();
expect(data).toEqual({ id: 1 });
});
it('should reject on error', async () => {
await expect(fetchData()).rejects.toThrow('Error');
});
React Testing
typescript
import { render, screen } from '@testing-library/react';
import { userEvent } from '@testing-library/user-event';
it('should handle click', async () => {
const onClick = vi.fn();
render(<Button onClick={onClick}>Click</Button>);
await userEvent.click(screen.getByRole('button'));
expect(onClick).toHaveBeenCalled();
});
🔄 Workflow
Kaynak: Vitest Official Documentation & Vite + Testing Best Practices
Aşama 1: Environment & Setup
- Vite Integration:
vitest.config.tsdosyasının Vite ayarlarıyla senkronize olduğunu doğrula. - Environment Choice: Web projeleri için
jsdomveyahappy-dom, backend içinnodeenvironment'ı seç. - Global Mocks: Sık kullanılan harici servisler (API, LocalStorage) için
setup.tsiçinde global mock'ları tanımla.
Aşama 2: Unit & Component Testing
- Isolation Layer: Bağımlılıkları
vi.mock()ile izole ederek sadece hedef üniteyi test et. - Assertion Strategy:
expectmetodlarını kullanarak beklenen sonuçları (be.truthy, toEqual, toBeCalled) doğrula. - Snapshot Testing: UI bileşenlerindeki (Component) beklenmedik arayüz değişikliklerini
toMatchSnapshot()ile yakala.
Aşama 3: Performance & Coverage
- Watch Mode: Geliştirme sürecinde testleri
watchmodunda tutarak anlık geri bildirim al. - Coverage Analysis:
v8veyaistanbulprovider kullanarak test kapsamını raporla. - Dependency Cleanup:
vi.clearAllMocks()ile testler arası veri kirliliğini (Pollution) önle.
Kontrol Noktaları
| Aşama | Doğrulama |
|---|---|
| 1 | Test dosyaları *.test.ts veya *.spec.ts formatında mı? |
| 2 | Asenkron kodlar (async/await) doğru handle ediliyor mu? |
| 3 | Karmaşık nesne karşılaştırmalarında toBe (referans) yerine toEqual (değer) mi kullanıldı? |
Vitest Runner v1.5 - With Workflow
Didn't find tool you were looking for?