← ClaudeAtlas

running-tdd-cycleslisted

Drive strict red-green-refactor TDD discipline on any code change, any language.
swell-agents/coding-skills · ★ 2 · Code & Development · score 71
Install: claude install-skill swell-agents/coding-skills
## Loop For each new piece of behaviour: ``` 1. Extract <requirement> — the smallest piece of logic that adds value. 2. RED → write ONE failing test that pins down <requirement>. 3. GREEN → write the minimal code that makes it pass. 4. REFACTOR → improve structure with the test as a safety net. 5. COMMIT → one logical change per commit (defer to committing-changes). 6. Repeat 2–5 until the task is done. 7. REVIEW → defer to reviewing-changes for the final pass. ``` Always one requirement per cycle. If the cycle feels big, the requirement was too big — split it. ## RED — write a failing test - **One test, one requirement.** Don't write a test suite up front; one test, fail, pass, refactor, next. - **Test names are claims, not labels.** Verify the fixture shape, input source, and assertion target match the name *before* the test goes green. A test named `test_decodesV4Quote` that loads a V5 fixture is silently broken: it passes but pins the wrong invariant, and the regression lands in the wrong place. Common causes: renamed a test and forgot to update the fixture; copy-pasted a fuzzy assertion from a sibling test without re-targeting it. - **Arrange-Act-Assert.** Three blocks, one assertion focus. Use `should_X_when_Y` naming where the framework allows it. - **Fail for the right reason.** Run the test before writing implementation. The failure message must point at *missing behaviour*, not at a typo, missing import, or fixture mistake. If it doesn't, the test i