A family of experiments on test-driven developmentShow others and affiliations
2021 (English)In: Empirical Software Engineering, ISSN 1382-3256, E-ISSN 1573-7616, Vol. 26, no 3, article id 42Article in journal (Refereed) Published
Abstract [en]
Context:: Test-driven development (TDD) is an agile software development approach that has been widely claimed to improve software quality. However, the extent to which TDD improves quality appears to be largely dependent upon the characteristics of the study in which it is evaluated (e.g., the research method, participant type, programming environment, etc.). The particularities of each study make the aggregation of results untenable. Objectives:: The goal of this paper is to: increase the accuracy and generalizability of the results achieved in isolated experiments on TDD, provide joint conclusions on the performance of TDD across different industrial and academic settings, and assess the extent to which the characteristics of the experiments affect the quality-related performance of TDD. Method:: We conduct a family of 12 experiments on TDD in academia and industry. We aggregate their results by means of meta-analysis. We perform exploratory analyses to identify variables impacting the quality-related performance of TDD. Results:: TDD novices achieve a slightly higher code quality with iterative test-last development (i.e., ITL, the reverse approach of TDD) than with TDD. The task being developed largely determines quality. The programming environment, the order in which TDD and ITL are applied, or the learning effects from one development approach to another do not appear to affect quality. The quality-related performance of professionals using TDD drops more than for students. We hypothesize that this may be due to their being more resistant to change and potentially less motivated than students. Conclusion:: Previous studies seem to provide conflicting results on TDD performance (i.e., positive vs. negative, respectively). We hypothesize that these conflicting results may be due to different study durations, experiment participants being unfamiliar with the TDD process, or case studies comparing the performance achieved by TDD vs. the control approach (e.g., the waterfall model), each applied to develop a different system. Further experiments with TDD experts are needed to validate these hypotheses. © 2021, The Author(s), under exclusive licence to Springer Science+Business Media, LLC part of Springer Nature.
Place, publisher, year, edition, pages
Springer , 2021. Vol. 26, no 3, article id 42
Keywords [en]
Academia, Family of experiments, Industry, Quality, Test-driven development, Computer software selection and evaluation, Iterative methods, Quality control, Software design, Software quality, Software testing, Agile software development, Control approach, Development approach, Exploratory analysis, Learning effects, Programming environment, research methods, Test driven development, Computer programming
National Category
Software Engineering
Identifiers
URN: urn:nbn:se:bth-21321DOI: 10.1007/s10664-020-09895-8ISI: 000632058500001Scopus ID: 2-s2.0-85103232361OAI: oai:DiVA.org:bth-21321DiVA, id: diva2:1543183
Funder
European Regional Development Fund (ERDF)2021-04-092021-04-092022-09-15Bibliographically approved