• 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