tdd-obra

Test-Driven Development (TDD) Skill

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "tdd-obra" with this command: npx skills add vamseeachanta/workspace-hub/vamseeachanta-workspace-hub-tdd-obra

Test-Driven Development (TDD) Skill

Overview

This skill enforces strict test-first development methodology. The core principle: "Write the test first. Watch it fail. Write minimal code to pass." If you didn't watch the test fail, you don't know if it tests the right thing.

Quick Start

  • Write one failing test - Minimal test demonstrating desired behavior

  • Verify RED - Run test, confirm it fails (not errors)

  • Write minimal code - Just enough to pass

  • Verify GREEN - All tests pass

  • Refactor - Clean up while maintaining green

When to Use

  • Starting new features or modules

  • Fixing bugs (write failing test reproducing bug first)

  • Refactoring existing code

  • Any production code development

  • Code review verification

Iron Law

Produce no production code without a failing test first.

Any code written before tests must be deleted entirely - no exceptions for keeping it as reference material.

Red-Green-Refactor Cycle

RED Phase

Write one minimal test demonstrating desired behavior:

  • Use clear, descriptive test names

  • Test real behavior, not mocks

  • One assertion focus per test

Verify RED (Mandatory)

Run tests and confirm:

  • Test fails (not errors)

  • Failure message matches expectations

  • Failure occurs because feature is missing, not due to typos

GREEN Phase

Write simplest code passing the test:

  • No over-engineering or feature additions

  • No refactoring other code

  • Implement only what satisfies the test

Verify GREEN (Mandatory)

Confirm:

  • Target test passes

  • All existing tests remain passing

  • No errors or warnings appear

REFACTOR Phase

After green only, clean up implementation:

  • Remove duplication

  • Improve naming

  • Extract helpers

  • Maintain all passing tests

Why Tests-After Fails

Approach Validates

Tests-first "What should this do?"

Tests-after "What did I build?"

Tests written after code:

  • Pass immediately, proving nothing

  • May test the wrong thing

  • Verify implementation rather than behavior

  • Miss edge cases forgotten during coding

  • Never demonstrate the test catching real bugs

Common Rationalizations (All Invalid)

These are "Red Flags" requiring complete restart with proper TDD:

  • "Too simple to test"

  • "I'll test after"

  • "Already manually tested"

  • "Tests slow me down"

  • "I know this works"

Bug Fix Pattern

  1. Write failing test reproducing the bug
  2. Verify test fails for expected reason
  3. Implement minimal fix
  4. Verify all tests pass
  5. Refactor if needed
  6. Commit with test and fix together

Verification Checklist

Before completing work:

  • Every function has a test

  • Each test was watched failing first

  • Tests failed for expected reasons

  • Minimal code passes each test

  • All tests pass without warnings

  • Tests employ real code with minimal mocking

  • Edge cases and errors are covered

Best Practices

Do

  • Write test name as behavior specification

  • Use AAA pattern: Arrange, Act, Assert

  • Test edge cases explicitly

  • Keep tests independent

  • Run full suite frequently

  • Commit test and implementation together

Don't

  • Write tests after implementation

  • Test implementation details

  • Use excessive mocking

  • Skip verification steps

  • Batch multiple behaviors in one test

  • Ignore flaky tests

Error Handling

Error Cause Solution

Test passes immediately Wrote code first Delete code, start over with test

Test errors instead of fails Syntax or setup issue Fix test setup, not production code

Tests pass but feature broken Testing wrong thing Review test assertions

Flaky tests Async or state issues Fix test isolation

Metrics

Metric Target Description

Test-First Rate 100% Tests written before code

RED Verification 100% All tests watched failing

Coverage

80% Line coverage baseline

Critical Path Coverage 100% Auth, payments, security

Test Independence 100% No test order dependencies

Related Skills

  • systematic-debugging - Debug with methodology

  • writing-plans - Plan implementations

  • subagent-driven - Structured development

Version History

  • 1.0.0 (2026-01-19): Initial release adapted from obra/superpowers

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

cli-productivity

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

python-docx

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

python-scientific-computing

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

python-pptx

No summary provided by upstream source.

Repository SourceNeeds Review