Strategies to manage quality requirements in agile software development: a multiple case study

Agile methods can deliver software that fulfills customer needs rapidly and continuously. Quality requirements (QRs) are important in this regard; however, detailed studies on how companies applying agile methods to manage QRs are limited, as are studies on the rationale for choosing specific QR management practices and related challenges. The aim of this study was to address why practitioners manage QRs as they do and what challenges they face. We also analyzed how existing practices mitigate some of the found challenges. Lastly, we connect the contextual elements of the companies with their practices and challenges. We conducted 36 interviews with practitioners from four companies of varying sizes. Since each company operates in different domains, comparing QR management strategies and related challenges in different contexts was possible. We found that the companies apply proactive, reactive, and interactive strategies to manage QRs. Additionally, our study revealed 40 challenges in six categories that companies applying agile methods may face in QR management. We also identified nine contextual elements that affect QR management practice choices and which, importantly, can explain many related challenges. Based on these findings, we constructed a theoretical model about the connection between context, QR management practices, and challenges. Practitioners in similar contexts can learn from the practices identified in this study. Our preliminary theoretical model can help other practitioners identify what challenges they can expect to face in QR management in different developmental contexts as well as which practices to apply to mitigate these challenges.

[1]  John Mylopoulos,et al.  Representing and Using Nonfunctional Requirements: A Process-Oriented Approach , 1992, IEEE Trans. Software Eng..

[2]  Robert L. Glass Defining Quality Intuitively , 1998, IEEE Softw..

[3]  Per Runeson,et al.  Guidelines for conducting and reporting case study research in software engineering , 2009, Empirical Software Engineering.

[4]  B. Ramesh,et al.  Agile Requirements Engineering Practices: An Empirical Study , 2008, IEEE Software.

[5]  Richard Baskerville,et al.  Agile requirements engineering practices and challenges: an empirical study , 2007, Inf. Syst. J..

[6]  Weam M. Farid,et al.  The NORMAP Methodology: Lightweight Engineering of Non-functional Requirements for Agile Processes , 2012, 2012 19th Asia-Pacific Software Engineering Conference.

[7]  Stefan Wagner,et al.  Software Product Quality Control , 2013, Springer Berlin Heidelberg.

[8]  Lianping Chen,et al.  Continuous Delivery: Huge Benefits, but Challenges Too , 2015, IEEE Software.

[9]  Sabrina Marczak,et al.  A systematic literature review on agile requirements engineering practices and challenges , 2015, Comput. Hum. Behav..

[10]  Jörg Thomaschewski,et al.  Agile Requirements Engineering: A systematic literature review , 2017, Comput. Stand. Interfaces.

[11]  Bruno Rossi,et al.  Scaling agile in large organizations: Practices, challenges, and success factors , 2018, J. Softw. Evol. Process..

[12]  Andreia Malucelli,et al.  Requirements engineering: A systematic mapping study in agile software development , 2018, J. Syst. Softw..

[13]  Roel Wieringa,et al.  Quality requirements challenges in the context of large-scale distributed agile: An empirical study , 2019, Inf. Softw. Technol..

[14]  Miguel Goulão,et al.  Requirements specification for developers in agile projects: Evaluation by two industrial case studies , 2020, Inf. Softw. Technol..