Software Quality Management (SQM) 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.[1][2][3] 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.[1][2][3]

Quality management activities

Software quality management activities are generally split up into three core components: quality assurance, quality planning, and quality control.[1][2] Some like software engineer and author Ian Sommerville don't use the term "quality control" (as quality control is often viewed as more a manufacturing term than a software development term), rather, linking its associated concepts with the concept of quality assurance.[3] However, the three core components otherwise remain the same.

Quality assurance

Main article: Software 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.[1][2][3] Additionally, "process standardization can sometimes stifle creativity, which leads to poorer rather than better quality software."[3]

This stage can include:

Quality planning

Quality planning works at a more granular, project-based level, defining the quality attributes to be associated with the output of the project and how those attributes should be assessed. Additionally, any existing organizational standards may also be assigned to the project at this phase. Attributes such as "robustness," "accessibility," and "modularity" may be assigned to the software development project.[1][2] While this may be a more formalized, integral process, those using a more agile method of quality management may place less emphasis on strict planning structures.[3] The quality plan may also address intended market, critical release dates, quality goals, expected risks, and risk management policy.[2][3]

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.[1][2] (Some like Sommerville link these responsibilities to quality assurance rather than call it quality control.[3]) These checks are optimally separate from the development team so as to lend more of an objective view of the product to be tested.[2][3] 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."[3] 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.[3]

Activities include:

Software quality and the software lifecycle

The measurement of software quality is different from manufacturing; tolerances aren't applicable (at least in the same way), and objective conclusions concerning if software meets specifications are difficult if not impossible to achieve.[3] However, software's quality and fit-for-purpose status can still be realized in various ways depending on the organization and type of realized project.[4] This done through the support of the entire software development lifecycle, meaning:

Links to IT methods

Software quality management is a topic strongly linked with various project management, development, and IT operation methods, including:

Software Quality Management implementation sample for project using RUP and V-Model
  • 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.
  • 3.4.12 Plan Quality,
  • 3.5.2. Perform Quality Assurance,
  • 3.6.7. Perform Quality Control

Associations and organizations

See also

References

  1. ^ a b c d e f Zsolt, U. (February 2014). "Software quality management" (PDF). Software Development Processes and Software Quality Assurance. University of Pannonia. pp. 117–121. Retrieved 7 December 2017.
  2. ^ a b c d e f g h Maxim, B.R. (2014). "Software Quality Management" (PPT). University of Michigan - Dearborn. Retrieved 7 December 2017.
  3. ^ a b c d e f g h i j k l Sommerville, I. (2011). "Chapter 24: Quality Management". Software Engineering (9th ed.). Addison-Wesley. pp. 651–680. ISBN 9780137035151.
  4. ^ Kelemen, Z. D. (2013). Process Based Unification for Multi-Model Software Process Improvement Eindhoven: Technische Universiteit Eindhoven. ISBN 978-90-386-3313-8
  5. ^ OGC (Office of Government Commerce) (2009). Managing Successful Projects with PRINCE2 (2009 ed.). TSO (The Stationery Office). ISBN 978-0-11-331059-3
  6. ^ A Guide to the Project Management Body of Knowledge, Fourth Edition, PMI, USA, 2008
  7. ^ Microsoft Solution Framework - Chapter 18 Stabilization phase, Published: April 27, 2005 [1]
  8. ^ "Certifying Software Testers Worldwide". International Software Testing Qualifications Board. Retrieved 7 December 2017.