The test team shouldn’t have the onus to improve the software quality, rather the quality should already be built into the software. A few subtle indicators can reveal if the quality isn’t being built into the software.
Prior to a production release, it’s not uncommon for management to have the test team “sign off” on the release, signifying the software meets requirements and quality expectations. This sign off comes at the end of the project, putting the burden on the testers to catch all the problems introduced into the software on its journey leading up to test deployment. Instead, signoffs should happen in a regular series throughout the software development lifecycle.
Usually, problems are introduced into the software due to inadequate, broken, or non-existent processes. Not even with the use of modern-day software development processes can you be assured you are building a quality product.
Using Test-Driven Development (TDD), where you write and execute tests before you write code, the ability to write good unit tests is essential, a point often overlooked.
With DevOps, people are one of the main reasons why it fails. Collaboration is an essential trait. People are unable to bridge the gap between teams. Collaboration and communication across the teams can result in human, non-technical obstacles. Other issues include the struggle in hiring talented people along with challenges of tool selection, test coverage decisions, and integration.
Utilizing Continuous Integration and Continuous Delivery (CI/CD), where developers and testers work together validating new code, faulty tests and automating the wrong processes are often the cause of problems. This can redefine CI/CD to mean Continuous Inaccuracies/Countless Defects
Poor quality is most obvious by the number of defects written after the software is deployed into test. Regardless of the severity though, defects that cannot be deferred just emphasize the problem. As a guideline, studies suggest that one defect per 1000 lines of code is generally considered as a sign of a product with good quality.
Subtle signs of poor software quality can include:
Several best practices are available to build quality into your product, including:
No matter which software development process you use, it’s imperative to integrate quality verification steps to ensure quality is built-in into each deliverable. Move from TDD to QTDD; DevOps to QDevOps, and CI/CD to QCI/QCD.
Preventive action is always better than corrective action. As with sweeping stairs, you always start from the top and work your way down. The same goes for software quality, institute quality from the start.
Just as no one can whistle a symphony alone, quality is everyone’s responsibility.