active

TDD Workflow

Safe

Enforces strict Red-Green-Refactor TDD cycle. Tests first, minimal implementation, then refactor. Inspired by obra/superpowers and Aider architect mode.

@atapifire/tdd-workflow

tdd
testing
workflow
methodology

TDD Workflow

Purpose: Enforce a strict Red-Green-Refactor test-driven development cycle. The agent writes tests FIRST, then implements just enough code to make them pass, then refactors.


Invocation

code
/tdd <feature_description>

The Cycle

Phase 1: RED — Write Failing Tests

  1. Create a test file (or add to existing)
  2. Write test cases that describe the desired behavior
  3. Run the test suite — confirm tests FAIL
  4. Do NOT write any implementation yet
bash
$ npx vitest run src/utils/slug.test.ts
 FAIL  src/utils/slug.test.ts
  ✗ converts spaces to hyphens
  ✗ lowercases all characters
  ✗ removes special characters
  ✗ handles empty string

Phase 2: GREEN — Write Minimum Implementation

  1. Write the simplest code that makes ALL tests pass
  2. No extra features, no optimization, no "while I'm here" additions
  3. Run tests — confirm they PASS
bash
$ npx vitest run src/utils/slug.test.ts
 ✓ src/utils/slug.test.ts (4 tests)
  ✓ converts spaces to hyphens
  ✓ lowercases all characters
  ✓ removes special characters
  ✓ handles empty string

Phase 3: REFACTOR — Clean Up

  1. Improve code quality WITHOUT changing behavior
  2. Run tests after each refactor step — they must stay GREEN
  3. Look for: duplication, unclear naming, complex conditionals, missing types
  4. Commit when satisfied

Rules

  1. Never write implementation before tests — If you catch yourself coding logic before a test exists, stop and write the test first.
  2. One test at a time — Write one test, see it fail, make it pass. Then the next.
  3. Minimal implementation — Don't write code "you'll need later." Only satisfy current tests.
  4. Tests must fail first — If a new test passes immediately, either the test is wrong or the behavior already exists. Investigate.
  5. Refactor only when green — Never refactor while tests are failing.
  6. Small commits — Commit at the end of each RED-GREEN-REFACTOR cycle.

Commit Convention

code
test: add tests for slug utility (RED)
feat(utils): implement slug generation (GREEN)
refactor(utils): simplify slug regex (REFACTOR)

When to Break the Cycle

It's okay to skip TDD for:

  • Configuration files (no logic to test)
  • Type definitions (TypeScript compiler is the test)
  • One-line wrappers around well-tested libraries
  • UI layout (visual testing is better here)

But ALWAYS use TDD for:

  • Business logic
  • Data transformations
  • Validation rules
  • API endpoint handlers
  • State management logic

Playground

<!DOCTYPE html><html><head><meta charset='utf-8'><style>*{box-sizing:border-box;margin:0;padding:0}body{background:#0d1117;font-family:monospace;font-size:12px;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.title{color:#58a6ff;font-size:14px;font-weight:bold;margin-bottom:24px}.flow{display:flex;align-items:center;gap:0}.step{width:112px;height:84px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:11px;font-weight:bold;text-align:center;padding:8px}.arrow{color:#30363d;font-size:20px;padding:0 6px}.red{background:#3d1117;border:2px solid #f85149;color:#f85149}.green{background:#0d2d1a;border:2px solid #3fb950;color:#3fb950}.blue{background:#0d1f3d;border:2px solid #58a6ff;color:#58a6ff}.sub{font-size:9px;color:#8b949e;font-weight:normal;margin-top:4px;line-height:1.4}.rule{color:#8b949e;font-size:10px;margin-top:20px;text-align:center;max-width:380px;line-height:1.6}</style></head><body><div class='title'>TDD Workflow · Red→Green→Refactor</div><div class='flow'><div class='step red'>🔴 RED<div class='sub'>Write a failing test.<br>Run it. See it fail.</div></div><div class='arrow'>→</div><div class='step green'>🟢 GREEN<div class='sub'>Write minimum code<br>to pass the test.</div></div><div class='arrow'>→</div><div class='step blue'>🔵 REFACTOR<div class='sub'>Clean up. Keep tests<br>green. Repeat.</div></div></div><div class='rule'>Rule: never write production code without a failing test first.<br>Rule: commit after each green. CI must stay green at every commit.</div></body></html>
Dormant$0/mo

$20 more to next tier

Info

Created February 18, 2026
Version 1.0.0
Agent-invoked
Terminal output

Embed

Add this skill card to any webpage.

<iframe src="https://skillslap.com/skill/dbc33db0-610a-4b14-ad8c-79dc9ab6fc55/embed"
        width="400" height="200"
        style="border:none;border-radius:12px;"
        title="SkillSlap Skill: TDD Workflow">
</iframe>