Agent skill

test-driven-development

Enforce RED-GREEN-REFACTOR cycle. Use when implementing features, fixing bugs, or writing any production code.

Stars 232
Forks 15

Install this agent skill to your Project

npx add-skill https://github.com/aiskillstore/marketplace/tree/main/skills/dmjgilbert/test-driven-development

SKILL.md

Test-Driven Development

Write the test first. Watch it fail. Write minimal code to pass.

The Iron Law

NO PRODUCTION CODE WITHOUT A FAILING TEST FIRST

Any code written before its corresponding test must be deleted entirely - no exceptions for "reference" or "adapting" existing work.

Red-Green-Refactor Cycle

RED: Write Failing Test

  1. Write ONE minimal failing test demonstrating desired behavior
  2. Use clear naming that describes the behavior
  3. Test real code, not mocks (mock only external dependencies)
  4. Focus on ONE behavior per test

Verify RED (CRITICAL)

Run tests and confirm:

  • Test fails (not errors)
  • Failure indicates missing feature
  • Error message matches expectations

If test passes immediately → DELETE IT (it proves nothing)

GREEN: Make It Pass

  1. Implement the simplest code that passes the test
  2. Avoid over-engineering
  3. Don't add features not requested
  4. Keep scope narrow

Verify GREEN

  • All tests pass
  • No other tests broke

REFACTOR: Clean Up

  1. Clean up while ALL tests remain green
  2. Remove duplication (DRY)
  3. Improve naming
  4. Extract helpers if needed

Why Tests-First Matters

Tests written after code pass immediately, proving nothing about their validity. Tests-first:

  • Force discovery of edge cases before implementation
  • Provide systematic verification impossible with manual testing
  • Document expected behavior

Common Rationalizations (ALL REJECTED)

Excuse Why It's Wrong
"Too simple to test" Simple code still needs verification
"I'll test after" Tests-after pass immediately, proving nothing
"Already manually tested" Manual testing isn't repeatable or documented
"Deleting hours of work is wasteful" Sunk cost fallacy - untested code is liability

When to Use TDD

Always: New features, bug fixes, refactoring, behavior changes

Exceptions only: Throwaway prototypes, generated code, config files (with permission)

Red Flags Requiring Restart

  • Code written before test
  • Test passes immediately
  • Can't explain why test should fail
  • Rationalizing "just this once"

→ DELETE the code and recommence with failing test

When 3+ Test Fixes Fail

STOP. This signals an architectural problem:

  1. Return to investigation phase
  2. Question whether the underlying pattern is sound
  3. Discuss with user before attempting more fixes

Expand your agent's capabilities with these related and highly-rated skills.

aiskillstore/marketplace

perigon-backend

Perigon ASP.NET Core + EF Core + Aspire conventions

232 15
Explore
aiskillstore/marketplace

perigon-agent

Pointers for Copilot/agents to apply Perigon conventions

232 15
Explore
aiskillstore/marketplace

perigon-angular

Angular 21+ standalone/Material/signal conventions for Perigon WebApp

232 15
Explore
aiskillstore/marketplace

fastapi-mastery

Comprehensive FastAPI development skill covering REST API creation, routing, request/response handling, validation, authentication, database integration, middleware, and deployment. Use when working with FastAPI projects, building APIs, implementing CRUD operations, setting up authentication/authorization, integrating databases (SQL/NoSQL), adding middleware, handling WebSockets, or deploying FastAPI applications. Triggered by requests involving .py files with FastAPI code, API endpoint creation, Pydantic models, or FastAPI-specific features.

232 15
Explore
aiskillstore/marketplace

context7-efficient

Token-efficient library documentation fetcher using Context7 MCP with 86.8% token savings through intelligent shell pipeline filtering. Fetches code examples, API references, and best practices for JavaScript, Python, Go, Rust, and other libraries. Use when users ask about library documentation, need code examples, want API usage patterns, are learning a new framework, need syntax reference, or troubleshooting with library-specific information. Triggers include questions like "Show me React hooks", "How do I use Prisma", "What's the Next.js routing syntax", or any request for library/framework documentation.

232 15
Explore
aiskillstore/marketplace

browser-use

Browser automation using Playwright MCP. Navigate websites, fill forms, click elements, take screenshots, and extract data. Use when tasks require web browsing, form submission, web scraping, UI testing, or any browser interaction.

232 15
Explore

Didn't find tool you were looking for?

Be as detailed as possible for better results