Test Driven Development (TDD) – Code Coverage

Home » General Topics » Test Driven Development (TDD) – Code Coverage
TDD (Test Driven Development) Letters

Should you aim for 100% code coverage on Test Driven Development (TDD) projects?

My view is that for TDD projects, only the business logic layer should be under TDD, not every line of code in every layer. This way it gives you maximum benefit developing the core unique thing you are developing, and lets the common and garden plumbing in other layers be produced without 5 lines of test code for each line of application code produced.

Controversial? Many projects blindly use tools like NCrunch and aim for every line of code to be covered by a test somewhere.

I personally don’t think this is necessary and adds a lot of overhead to a project where if you are following SOLID or similar rules your MVC views will only contain formatting and your data access layer will contain lots of small very simple functions. So what if you miss a where clause off a select? It will be really obvious really quickly especially if the repository method is used in more than one place, and fixing it once will fix it everywhere. I think a balanced approach is much more productive, although like a lot of my views, these are strong views, weakly held – that is, the client can easily convince me that if they want to do it differently they can, because they are the client after all.

About Phil

I have been working as a software developer since 1983. This blog could have been called "From Fortran 77, C and Cobol to C# in 20 (not so) easy years", but it doesn't sound quite right somehow. Besides I'm talking about what's happened since 2003, not before!

Leave a Reply

Your email address will not be published.


You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">




Top Posts & Pages

Categories

Recent Posts

Recent Comments

Archives

Blogroll

  • Mike Cohn's Blog
  • Scott Hanselman's Blog
- mike@mountaingoatsoftware.com

Being a great product owner is hard. Here are the things your team wants from you to help them do th [...]

- mike@mountaingoatsoftware.com

Want to learn about Kanban? Here’s a complete guide to introducing Kanban into your organization. [...]

- mike@mountaingoatsoftware.com

Lack of communication is a common problem that causes delays, rework, or adds risk. See how Kanban “ [...]

- mike@mountaingoatsoftware.com

It’s easy to say you limit how much work you’ll have in process. It’s harder to live up to it, espec [...]

- mike@mountaingoatsoftware.com

You told me you have questions about Kanban. Here are some answers from Kanban expert, Brendan Wovch [...]

- Scott Hanselman

I love my Nintendo Switch. It's a brilliant console that fits into my lifestyle. I use it on pl [...]

- Scott Hanselman

I was fortunate to be a guest on Steve Carroll's talk show "Careers Behind the Code," [...]

- Scott Hanselman

I've been talking about it for months, but in case you haven't heard, there's a new W [...]

- Scott Hanselman

I posted recently about What's the difference between a console, a terminal, and a shell? The w [...]

- Scott Hanselman

Earlier this week I announced over 80 new free videos in our .NET Core 3.0 launch video series - Ann [...]

Meta