An Ingredients List for Testing - Part Six
Friday, November 05, 2010
By James Whittaker
The sixth ingredient is variation. Tests often get stale (i.e., they stop finding bugs) as they are run over and over on build after build as a product is being constructed. On the one hand, it is important to continue running tests to ensure the product still operates as specified. Indeed, I hesitate to throw any test away. However, becoming reliant on stale tests is too risky. Adding variation to existing tests can range from straightforward reordering of the sequence in which tests are run to more involved solutions of either modifying tests or adding new ones. Hopefully new tests will increase overall coverage and add to our confidence that we’ve tested the software in all the ways it needs to be tested.
The sixth ingredient is variation. Tests often get stale (i.e., they stop finding bugs) as they are run over and over on build after build as a product is being constructed. On the one hand, it is important to continue running tests to ensure the product still operates as specified. Indeed, I hesitate to throw any test away. However, becoming reliant on stale tests is too risky. Adding variation to existing tests can range from straightforward reordering of the sequence in which tests are run to more involved solutions of either modifying tests or adding new ones. Hopefully new tests will increase overall coverage and add to our confidence that we’ve tested the software in all the ways it needs to be tested.
Since Jan 1, 2010:
ReplyDelete75% of the tests for my project have failed 0 times.
20 % have failed between 1 and 100 times.
5% have failed more than 100 times.
My diagnosis:
The 20% are live tests, doing important work.
The 5% are mostly flaky.
The 75% probably can be broken into 2 sets, the 'keeping us honest' tests. They cover very basic, core components of our systems that change very, very rarely. BUT, if something were to change, we'd want to know immediately. The other set is probably dead code, we're testing because we like tests, not to protect our code base.
What does this mean? I'm not sure, but certainly we've got a lot of stale tests wasting CPU cycles and cluttering our test suites. For sure, this makes it difficult to understand our real tests.
Perhaps looking at some of these older, stale tests and modifying them could be a nice way to prevent test/code rot .
Where is Part Five? =)
ReplyDeleteI agree with this if you are adding tests or getting rid of useless tests. But randomly changing test is probably not good. Hopefully you have a testing architecture that allows you to run a lot of tests and keep them organized.
ReplyDeleteI really appreciate your post and it was superb .Thanks for sharing.I would like to hear more about this in future.
ReplyDeleteRegards:
http://www.blackitsoft.com/inventory-pos-software.aspx