Agile methodologies are rather prevalent these days, but I cannot seem to find much documentation on what metrics are most useful and why. I have found many more things saying that some traditional metrics like LOC and code coverage of tests are not appropriate, leaving two main questions:
- Why are those two (and other) metrics inappropriate?
- What metrics are best for Agile and why?
Even with an Agile process, wouldn’t you want to know how much code coverage you have with your unit tests? Or is it simply that this metric (and others) just are not as useful as other metrics like cyclomatic complexity and velocity?
Agile is a business oriented thing, Agile is about maximizing the customer value while minimizing waste to provide the most optimal ROI. This is what should get measured. And to do so, I use the system that Mary Poppendieck recommends. This system is based on three holistic measurements that must be taken as a package:
Sure, at the team level you can track things like test coverage, cyclomatic complexity, conformance to coding standards, etc, but high quality is not an end in itself, it’s just a mean. Don’t misinterpret me, I’m not saying high quality doesn’t matters, high quality is mandatory to achieve sustainable pace (and we include “no increase of the technical debt” in our Definition of Done) but still, the goal is to deliver value to the customer in a fast and profitable way.