Software quality management
Software Quality Management is a management process that aims to develop and manage the quality of software in such a way so as to best ensure that the product meets the quality standards expected by the customer while also meeting any necessary regulatory and developer requirements, if any. Software quality managers require software to be tested before it is released to the market, and they do this using a cyclical process-based quality assessment in order to reveal and fix bugs before release. Their job is not only to ensure their software is in good shape for the consumer but also to encourage a culture of quality throughout the enterprise.
Quality management activities
Software quality management activities are generally split up into three core components: quality assurance, quality planning, and quality control. Some like software engineer and author Ian Sommerville don't use the term "quality control", rather, linking its associated concepts with the concept of quality assurance. However, the three core components otherwise remain the same.Quality assurance
Software quality assurance sets up an organized and logical set of organizational processes and deciding on that software development standards — based on industry best practices — that should be paired with those organizational processes, software developers stand a better chance of producing higher quality software. However, linking quality attributes such as "maintainability" and "reliability" to processes is more difficult in software development due to its creative design elements versus the mechanical processes of manufacturing. Additionally, "process standardization can sometimes stifle creativity, which leads to poorer rather than better quality software."This stage can include:
- encouraging documentation process standards, such as the creation of well-defined engineering documents using standard templates
- mentoring how to conduct standard processes, such as quality reviews
- performing in-process test data recording procedures
- identifying standards, if any, that should be used in software development processes
Quality planning
Quality control
The quality control team tests and reviews software at its various stages to ensure quality assurance processes and standards at both the organizational and project level are being followed. These checks are optimally separate from the development team so as to lend more of an objective view of the product to be tested. However, project managers on the development side must also assist, helping to promote as part of this phase a "culture that provides support without blame when errors are discovered." In software development firms implementing a more agile quality approach, these activities may be less formal; however, a switch to agile methods from a more formal quality management structure may create problems if management procedures aren't appropriately adapted.Activities include:
- release testing of software, including proper documentation of the testing process
- examination of software and associated documentation for non-conformance with standards
- follow-up review of software to ensure any required changes detailed in previous testing are addressed
- application of software measurement and metrics for assessment
Software quality and the software lifecycle
- collecting requirements and defining the scope of an IT project, focused on verification if defined requirements will be testable;
- designing the solution, focused on planning a test process, e.g., what type of tests will be performed and how they will be performed in the context of test environments and test data?;
- implementing a solution supported by test cases and scenarios, executing them, and registering defects, including the coordination of resolving the defects;
- implementing change management, supported by verification of how planned changes can influence the quality of a created solution and eventual change of a test plan; and
- closing the project, supported by the realization of tests focused on complex verification of the overall quality of the created solution.
Links to IT methods
- Project management method PRINCE2 defines:
- Project management method PMBOK 4th edition defines knowledge area Project Quality Management and following processes:
- Development method RUP defines discipline testing, which is engaged in all phases starting from Inception, finishing at Transition.
- Development method MSF defines tester role and stabilization phase, which focuses mainly on testing a solution.
- Agile methods do not precisely define the tester's role or mechanisms related to software quality management. The methods define only such techniques as continuous integration and test-driven development. Nevertheless, there appears lastly the publication about agile testing.
- Operational method CMMI defines among others process area PPQA "Process and Product Quality Assurance", which is required already at CMMI level 2.
- Operational method COBIT defines among others process P08 Manage Quality.
- Operational method ITIL is defined among others by publication Continual service improvement.
- V-Model – model, which defines the software development lifecycle and test process.
- ISO 9000 – family of standards is related to quality management systems and designed to help organizations ensure that they meet the needs of customers and other stakeholders while meeting statutory and regulatory requirements related to the product.
Associations and organizations
- The American Society for Quality is a professional organization that provides its members with certification, training, publications, conferences, and other services related to quality management, continual improvement, and product safety.
- The International Software Testing Qualifications Board (ISTQBP is a non-profit, international association registered in Belgium. It manages the certification process for software testers and boasts more than 535,000 certificates issues in over 120 countries.