tdd

star 81

Guides through the complete TDD workflow with Red-Green-Refactor cycle

jellydn By jellydn schedule Updated 5/10/2026

name: tdd description: Guides through the complete TDD workflow with Red-Green-Refactor cycle license: MIT compatibility: claude, opencode, amp, codex, gemini, cursor, pi hint: Use when doing test-driven development with Red-Green-Refactor cycle user-invocable: true metadata: audience: all workflow: testing

Test-Driven Development (TDD)

Guides you through the complete TDD workflow with Red-Green-Refactor cycle.

Usage

/tdd <ACTION> [ARGUMENTS]

Actions

  • start - Initialize TDD session for a feature
  • red - Create failing test (Red phase)
  • green - Run tests and implement code (Green phase)
  • refactor - Guide refactoring process (Refactor phase)
  • cycle - Run complete Red-Green-Refactor cycle
  • watch - Start test watcher for continuous feedback
  • status - Show current test status and next steps
  • help - Show this help

TDD Principles

The Red-Green-Refactor Cycle

  1. Red: Write a failing test that defines desired behavior
  2. Green: Write minimal code to make the test pass
  3. Refactor: Improve code quality while keeping tests green

Best Practices

  • Write tests first - Tests define the interface and behavior
  • Small steps - Make tiny, incremental changes
  • Fast feedback - Run tests frequently for immediate validation
  • Clean code - Refactor regularly to maintain quality
  • One concept per test - Keep tests focused and atomic
  • AAA Pattern - Structure tests as Arrange, Act, Assert
  • Black-box testing - Test only public methods and behavior, not implementation details

Process

For "start ":

  1. Initialize TDD session for the feature
  2. Create or identify target source file
  3. Create corresponding test file if it doesn't exist
  4. Explain the feature requirements and acceptance criteria

For "red ":

  1. Create a failing test that describes the desired behavior
  2. Ensure test fails for the right reason (not syntax errors)
  3. Run tests to confirm red state
  4. Explain what the test is validating

For "green":

  1. Implement minimal code to make failing tests pass
  2. Focus on making tests pass, not perfect code
  3. Run tests to confirm green state
  4. Avoid over-engineering at this stage

For "refactor":

  1. Improve code quality while maintaining green tests
  2. Remove duplication and improve design
  3. Run tests continuously during refactoring
  4. Make one refactoring change at a time

Test Template

A test template is available at $SKILL_PATH/templates/test-template.md:

import { describe, it, expect } from "vitest";
import { functionName } from "./module";

describe("functionName", () => {
    it("should return formatted output when given valid input", () => {
        // Arrange - Setup test scenario
        const input = "test input";
        const expectedOutput = "expected output";

        // Act - Execute the unit under test
        const result = functionName(input);

        // Assert - Verify expected outcome
        expect(result).toBe(expectedOutput);
    });
});

Common Commands

  • Run tests: npm test or pnpm test
  • Watch mode: npm test --watch
  • With coverage: npm test --coverage
Install via CLI
npx skills add https://github.com/jellydn/my-ai-tools --skill tdd
Repository Details
star Stars 81
call_split Forks 10
navigation Branch main
article Path SKILL.md
More from Creator