Software quality management is a management process that aims to develop and manage the quality of software to make sure the product satisfies the user. The goals of SQM (software quality management ) is to make sure the product follows regulations and meets the quality standards expected by the customer. Software quality managers have to test the product before it is released to the market and they do this by a series of steps called the software cycle in order to reveal and fix bugs before release. Their job is not only to make sure that their software is in good shape for the consumer, but also to encourage the quality culture to everyone and avoid fraud by protecting their software through proper development.
The aim of Software Quality Management (SQM) is to manage the quality of software and of its development process.A quality product is one which meets its requirements and satisfies the userA quality culture is an organizational environment where quality is viewed as everyone's responsibility.The computer scientist Ian Sommerville uses SQM as an umbrella-term that includes the following quality layers:
Software Quality Assurance (SQA) layer
An Organizational quality guide of
Standards, regulations, and procedures to produce, verify, evaluate and confirm work products during the software development lifecycleIncorporated knowledge base of best practicesOff-the-shelf software tools selected to apply the aboveSoftware Quality Plan (SQP) layer
A project level quality plan written by each project for declaring project commitment to follow an applicable set of standards, regulations, procedures and tools during the development lifecycle. In addition, SQP should contain quality goals to be achieved, expected risks and risk management. SQP sources are derived from
SQA components that are adopted as is or customized to the project's needsNew procedures, standards and tools complementing missing or not-applicable SQA components that have been written in particular for the project, or imported from outside the organization.Any deviation of an SQP from SQA should be justified by the project manager and be confirmed by the company management.
Software Quality Control (SQC) layer
Ensures in-process that both SQA and SQP are being followed by the development teams.
SQC activities include
Mentoring how to produce artifacts, such as well-defined engineering documents using standard templatesMentoring how to conduct standard processes, such as quality reviewsPerform in-process quality reviews to verify, evaluate and confirm artifactsVerify and evaluate to improve the use of methods, procedures and adopted software toolsto ensure that the required level of quality is achieved in a software productto encourage a company-wide "Quality Culture" where quality is viewed as everyone's responsibilityto reduce the learning curve and help with continuity in case team members change positions within the organizationto enable in-process fault avoidance and fault prevention through proper developmentMany people use the terms SQM and SQA (Software quality assurance) interchangeably.
Software quality management and software lifecycle
Software quality management can be realized in various ways depending on organization and type of realized project, but it should support whole software development lifecycle, meaning:
Collecting requirements and defining scope of IT project, focused on verification if defined requirements will be testable. One of the products can be test strategy.Designing the solution, focused on planning test process e.g. what type of tests will be performed, how they will be performed in context of test environments and test data. One of the products can be test plan including test schedule.Solution implementation supported by creating test cases and scenarios, executing them and registering defects including coordination of fixing them. Products can be test cases and scenarios, reports from test iteration realization.Change management, supported by verification how planned changes can influence the quality of created solution and eventual change of test plan. One of the products can be changes in test plan, test cases and scenarios.Closing project, supported by realization number of tests focused on complex verification of overall quality of created solution. It can include System Integration Tests, User Acceptance Tests and Operational Acceptance Tests. One of the products can be recommendation about production start of the system.Software quality management is a topic strongly linked with various project management, development and IT operation methods like:
Project management method PRINCE2 defines:component "Quality in a project environment", which describes necessity of double-checked and objective control of created products. It proposes using 4 elements: quality management system, function of quality control, planning quality and quality controls."Quality Review Technique" which is focused on verification if created products fulfills defined quality criteria.Project management method PMBOK 4th edition defines knowledge area Project Quality Management and following processes:3.4.12 Plan Quality,3.5.2. Perform Quality Assurance,3.6.7. Perform Quality ControlDevelopment 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[1] while meeting statutory and regulatory requirements related to the product.Associations and organizations
ISTQB, International Software Testing Qualifications Board is non-profit association registered in Belgium and working world-wide. It manages certification process for software testers. There is already over 200.000 ISTQB® certificates (date: March 2012).ASQ, American Society for Quality is a knowledge-based global community of quality professionals, with nearly 80,000 members dedicated to the promotion and advancement of quality tools, principles, and practices in their workplaces and in their communities.