Test-Driven Development (TDD) is a software practice emphasizing writing tests before code. Many find drawbacks in committing to an API prematurely and hindering exploration during early development.
Test-Driven Development (TDD) is a software development process that relies on the repetition of a very short development cycle: first the developer writes a failing automated test case that defines a desired improvement or new function, then produces code to pass that test, and finally refactors the new code to acceptable standards.
TDD requires you to commit to an API before you fully understand what you want from it. This can be a significant drawback, especially in the early stages of development when you’re still exploring different possibilities.
When you’re just starting out with a new feature or module, you’re often in an exploratory phase. You’re trying out different approaches, iterating on your ideas, and generally figuring out what works best. In this phase, committing to an API can feel premature.