Vitest

> Blazing fast unit testing powered by Vite — Jest-compatible API, native ESM, TypeScript.

39 stars

Best use case

Vitest is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

> Blazing fast unit testing powered by Vite — Jest-compatible API, native ESM, TypeScript.

Teams using Vitest should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/vitest/SKILL.md --create-dirs "https://raw.githubusercontent.com/InugamiDev/ultrathink-oss/main/.claude/skills/vitest/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/vitest/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How Vitest Compares

Feature / AgentVitestStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

> Blazing fast unit testing powered by Vite — Jest-compatible API, native ESM, TypeScript.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

Related Guides

SKILL.md Source

# Vitest

> Blazing fast unit testing powered by Vite — Jest-compatible API, native ESM, TypeScript.

## When to Use
- Unit and integration testing for Vite/React/Vue/Svelte projects
- Replacing Jest with faster, ESM-native alternative
- Component testing with happy-dom or jsdom
- In-source testing (tests alongside implementation)

## Core Patterns

### Configuration
```typescript
// vitest.config.ts
import { defineConfig } from "vitest/config";
import react from "@vitejs/plugin-react";

export default defineConfig({
  plugins: [react()],
  test: {
    globals: true,           // No need for import { test, expect }
    environment: "happy-dom", // or "jsdom" for browser APIs
    setupFiles: ["./test/setup.ts"],
    coverage: {
      provider: "v8",
      reporter: ["text", "html"],
    },
    include: ["src/**/*.{test,spec}.{ts,tsx}"],
  },
});
```

### Testing
```typescript
import { describe, it, expect, vi, beforeEach } from "vitest";

describe("UserService", () => {
  beforeEach(() => { vi.clearAllMocks(); });

  it("creates user", async () => {
    const mockDb = vi.fn().mockResolvedValue({ id: "1", name: "Inu" });
    const user = await createUser(mockDb, { name: "Inu" });
    expect(user).toMatchObject({ id: "1", name: "Inu" });
    expect(mockDb).toHaveBeenCalledOnce();
  });

  it("throws on invalid input", () => {
    expect(() => validateName("")).toThrow("Name required");
  });
});
```

### Key Features
- **vi.fn()**: Mock functions (same API as jest.fn())
- **vi.mock()**: Module mocking with auto-mock support
- **vi.spyOn()**: Spy on object methods
- **Snapshots**: `expect(result).toMatchSnapshot()`
- **In-source**: `if (import.meta.vitest)` blocks stripped from production
- **Watch mode**: `vitest` (default), `vitest run` for CI
- **Workspace**: `vitest.workspace.ts` for monorepo testing
- **Type testing**: `expectTypeOf<string>().toMatchTypeOf<string>()`
- **Browser mode**: `vitest --browser` for real browser testing

Related Skills

ultrathink

39
from InugamiDev/ultrathink-oss

UltraThink Workflow OS — 4-layer skill mesh with persistent memory and privacy hooks for complex engineering tasks. Routes prompts through intent detection to activate the right domain skills automatically.

ultrathink_review

39
from InugamiDev/ultrathink-oss

Multi-pass code review powered by UltraThink's quality gate — checks correctness, security (OWASP), performance, readability, and project conventions in a single structured pass.

ultrathink_memory

39
from InugamiDev/ultrathink-oss

Persistent memory system for UltraThink — search, save, and recall project context, decisions, and patterns across sessions using Postgres-backed fuzzy search with synonym expansion.

ui-design

39
from InugamiDev/ultrathink-oss

Comprehensive UI design system: 230+ font pairings, 48 themes, 65 design systems, 23 design languages, 30 UX laws, 14 color systems, Swiss grid, Gestalt principles, Pencil.dev workflow. Inherits ui-ux-pro-max (99 UX rules) + impeccable-frontend-design (anti-AI-slop). Triggers on any design, UI, layout, typography, color, theme, or styling task.

Zod

39
from InugamiDev/ultrathink-oss

> TypeScript-first schema validation with static type inference.

webinar-registration-page

39
from InugamiDev/ultrathink-oss

Build a webinar or live event registration page as a self-contained HTML file with countdown timer, speaker bio, agenda, and registration form. Triggers on: "build a webinar registration page", "create a webinar sign-up page", "event registration landing page", "live training registration page", "workshop sign-up page", "create a webinar page", "build an event page", "free webinar landing page", "live demo registration page", "online event page", "create a registration page for my webinar", "build a training event page".

webhooks

39
from InugamiDev/ultrathink-oss

Webhook design patterns — delivery, retry with exponential backoff, HMAC signature verification, payload validation, idempotency keys

web-workers

39
from InugamiDev/ultrathink-oss

Offload heavy computation from the main thread using Web Workers, SharedWorkers, and Comlink — structured messaging, transferable objects, and off-main-thread architecture patterns

web-vitals

39
from InugamiDev/ultrathink-oss

Core Web Vitals monitoring (LCP, FID, CLS, INP, TTFB), measurement with web-vitals library, reporting to analytics, and optimization strategies for Next.js

web-components

39
from InugamiDev/ultrathink-oss

Native Web Components, custom elements API, Shadow DOM, HTML templates, slots, lifecycle callbacks, and framework-agnostic design patterns

wasm

39
from InugamiDev/ultrathink-oss

WebAssembly integration — Rust to WASM with wasm-pack/wasm-bindgen, WASI, browser usage, server-side WASM, and performance considerations

vue

39
from InugamiDev/ultrathink-oss

Vue 3 Composition API, Nuxt patterns, reactivity system, component architecture, and production development practices