The 3 Rules of TDD (Plus bonus rule)
“Uncle” Bob Martin authored the Three Rules of TDD, which is enough to get started with TDD:
- You are not allowed to write any production code unless it is to make a failing unit test pass.
- You are not allowed to write any more of a unit test than is sufficient to fail; and compilation failures are failures.
- You are not allowed to write any more production code than is sufficient to pass the one failing unit test.
With these rules in mind, it’s pretty clear that writing all of your tests up front is not TDD.
It’s also worth noting that there’s no rule that you must use TDD for non-production code (although of course you’re free to do so, if you feel it’s a benefit!)
The fourth rule, which Kent Beck includes in his book Test Driven Development: By Example, and I think it’s worth including, too:
- Refactor.
That is, once you’ve written a test, and code sufficient to make the test pass, look for any reasonable refactoring to do on your code and your tests. Remove duplication. Make it more readable. Improve performance.