I will most definitely agree on that point.
I am still relatively new to testing, so I don't think I have gotten to the point that I am bothered by the tediousness of updating the test suite each time I make an internal refactor change to the code.
/me now ponders whether the extra test cases on private methods are beneficial enough that they will be worth the extra effort in the long run, hmmm... | [reply] |
If your classes do substantial calculations, it's useful to test the private methods that do the sub-calculations.
Otherwise, you'll probably end up doing more work to manage all the code coverage cases. That is, you'll need to do the same code coverage, but you'll have to reason out how to get to each submethod, and ensure you pass it the right parameters to ensure all of it's children get called.
I'd just as soon call all the children directly, with valid, invalid, likely, and not so likely datasets, and ensure that all cases are handled correctly. If I know the sub-methods do their jobs, then testing the API becomes more of an excercise in confirming the behaviour of the API against the final set of business requirements, versus a frantic search for coding errors.
If you only test the API, you also run the risk of your subroutines containing hidden flaws that cancel each other out. If you try to re-use or refactor such flawed code, you'll be in for nasty surprises later on...
But then again, testing is a lot of work in general, and if you refactor the internal methods, updating the test suite each time is a real pain.
--
AC | [reply] |
Otherwise, you'll probably end up doing more work to manage all the code coverage cases. That is, you'll need to do the same code coverage, but you'll have to reason out how to get to each submethod, and ensure you pass it the right parameters to ensure all of it's children get called.
I find that this is rarely a problem in real world usage. This is probably a side effect of doing TDD. If I factor out a private method from a public method then the coverage of my test suite isn't going to change, and if I change my private method I'll always write a test first.
To put it another way, if you aren't exercising all of the code in your private methods why did you need to write them in the first place?
| [reply] |
adrianh, have you found some good material on TDD in Perl? I'm finding TDD, so far, only slightly less painful than debugging :-) . (Though I just received Kent Beck's book today, so maybe I'll pick up some wisdom there.)
| [reply] |