common-tdd
$
npx mdskill add HoangNguyen0403/agent-skills-standard/common-tdd> **NO PRODUCTION CODE WITHOUT FAILING TEST FIRST.** > Code written before test MUST deleted. Start over.
SKILL.md
.github/skills/common-tddView on GitHub ↗
---
name: common-tdd
description: 'Implements a strict Red-Green-Refactor loop to ensure zero production code is written without a prior failing test. Use when: creating new features, fixing bugs, or expanding test coverage.'
metadata:
triggers:
files:
- '**/*.test.ts'
- '**/*.spec.ts'
- '**/*_test.go'
- '**/*Test.java'
- '**/*_test.dart'
- '**/*_spec.rb'
keywords:
- tdd
- unit test
- write test
- red green refactor
- failing test
- test coverage
---
# Test-Driven Development (TDD) Standard
## **Priority: P0 — Iron Law**
> **NO PRODUCTION CODE WITHOUT FAILING TEST FIRST.**
> Code written before test MUST deleted. Start over.
## **Step 1: RGR Loop (Red-Green-Refactor)**
1. **RED**: Write minimal failing test. **Verify failure** (Expected error, not typo).
2. **GREEN**: Write simplest code to pass. **Verify pass**.
3. **REFACTOR**: Clean up code while staying green.
## **AAA Structure (Mandatory)**
Every test must follow Arrange-Act-Assert:
- **Arrange**: Set up inputs, stubs, mocks, and expected values.
- **Act**: Call single unit under test.
- **Assert**: Verify output and side effects. One logical assertion per test.
**(See [AAA Example](references/aaa_example.md) for code structure)**.
## **Step 3: Verification & Thresholds**
- **Minimum Coverage**: 80% (Stat/Func/Line), 75% (Branch).
- **Mocks**:
- Always mock: HTTP, Time/Date, Filesystem.
- Never mock: Fast internal services (<200ms), pure domain logic.
- See [Test Runner Reference](references/test_runners.md) for environment-specific commands.
## **Step 4: Principles & Mocks**
- **Watch it Fail**: Prove test works before writing code.
- **Minimalism**: Don't add features/options beyond current test (YAGNI).
- **Isolation**: Mock external APIs (HTTP) and Time.
- **Realism**: Prefer real DBs (test containers) and fast internal services (<200ms).
## **Verification Checklist**
- [ ] Every new function/method failing test first?
- [ ] Failure message expected?
- [ ] Minimal code implemented passed?
- [ ] AAA structure followed?
- [ ] Coverage thresholds met?
## **Expert References**
- [AAA Example](references/aaa_example.md)
- [AAA Methodology](references/aaa_methodology.md)
- [Test Runners](references/test_runners.md)
- [TDD Patterns](references/tdd_patterns.md)
- [Testing Anti-Patterns](references/testing_anti_patterns.md)
## Anti-Patterns
- **No test-after**: Writing tests post-implementation defeats TDD. Delete and restart.
- **No assertion-free tests**: test without assert not test.
- **No testing implementation**: Test behavior and contracts, not internal calls.