Should we test all our methods?
Posted
by
Zenzen
on Programmers
See other posts from Programmers
or by Zenzen
Published on 2012-01-19T20:40:06Z
Indexed on
2012/10/20
23:19 UTC
Read the original article
Hit count: 268
So today I had a talk with my teammate about unit testing. The whole thing started when he asked me "hey, where are the tests for that class, I see only one?". The whole class was a manager (or a service if you prefer to call it like that) and almost all the methods were simply delegating stuff to a DAO so it was similar to:
SomeClass getSomething(parameters) {
return myDao.findSomethingBySomething(parameters);
}
A kind of boilerplate with no logic (or at least I do not consider such simple delegation as logic) but a useful boilerplate in most cases (layer separation etc.). And we had a rather lengthy discussion whether or not I should unit test it (I think that it is worth mentioning that I did fully unit test the DAO). His main arguments being that it was not TDD (obviously) and that someone might want to see the test to check what this method does (I do not know how it could be more obvious) or that in the future someone might want to change the implementation and add new (or more like "any") logic to it (in which case I guess someone should simply test that logic).
This made me think, though. Should we strive for the highest test coverage %? Or is it simply an art for art's sake then? I simply do not see any reason behind testing things like:
- getters and setters (unless they actually have some logic in them)
- "boilerplate" code
Obviously a test for such a method (with mocks) would take me less than a minute but I guess that is still time wasted and a millisecond longer for every CI.
Are there any rational/not "flammable" reasons to why one should test every single (or as many as he can) line of code?
© Programmers or respective owner