DocumentCode
176114
Title
Why Do Automated Builds Break? An Empirical Study
Author
Kerzazi, Noureddine ; Khomh, Foutse ; Adams, Bram
Author_Institution
R&D Dept., Payza.com, Montreal, QC, Canada
fYear
2014
fDate
Sept. 29 2014-Oct. 3 2014
Firstpage
41
Lastpage
50
Abstract
To detect integration errors as quickly as possible, organizations use automated build systems. Such systems ensure that (1) the developers are able to integrate their parts into an executable whole, (2) the testers are able to test the built system, (3) and the release engineers are able to leverage the generated build to produce the upcoming release. The flipside of automated builds is that any incorrect change can break the build, and hence testing and releasing, and (even worse) block other developers from continuing their work, delaying the project even further. To measure the impact of such build breakage, this empirical study analyzes 3,214 builds produced in a large software company over a period of 6 months. We found a high ratio of build breakage (17.9%), and also quantified the cost of such build breakage as more than 336.18 man-hours. Interviews with 28 software engineers from the company helped to understand the circumstances under which builds are broken and the effects of build breakages on the collaboration and coordination of teams. We quantitatively investigated the main factors impacting build breakage and found that build failures correlate with the number of simultaneous contributors on branches, the type of work items performed on a branch, and the roles played by the stakeholders of the builds (for example developers vs. Integrators).
Keywords
error detection; program testing; software quality; automated build systems; build breakage; build failures; integration error detection; software company; software quality; Collaboration; Companies; Context; Interviews; Software; Statistical analysis; Automated Builds; Data Mining; Empirical Software Engineering; Software Quality;
fLanguage
English
Publisher
ieee
Conference_Titel
Software Maintenance and Evolution (ICSME), 2014 IEEE International Conference on
Conference_Location
Victoria, BC
ISSN
1063-6773
Type
conf
DOI
10.1109/ICSME.2014.26
Filename
6976070
Link To Document