Published February 26, 2019 | Version v1
Preprint Open

Automated Reporting of Anti-Patterns and Decay in Continuous Integration

  • 1. University of Zurich
  • 2. University of Sannio

Description

Continuous Integration (CI) is a widely-used software engineering practice. The software is continuously built so that changes can be easily integrated and issues such as unmet quality goals or style inconsistencies get detected early. Unfortunately, it is not only hard to introduce CI into an existing project, but it is also challenging to live up to the CI principles when facing tough deadlines or business decisions. Previous work has identified common anti-patterns that reduce the promised benefits of CI. Typically, these anti-patterns slowly creep into a project over time before they are identified. We argue that automated detection can help with early identification and prevent such a process decay. In this work, we further analyze this assumption and survey 124 developers about CI anti-patterns. From the results, we build CI-Odor, a reporting tool for CI processes that detects the existence of four relevant anti-patterns by analyzing regular build logs and repository information. In a study on the 18,474 build logs of 36 popular Java projects, we reveal the presence of 3,823 high-severity warnings spread across projects. We validate our reports in a survey among 13 original developers of these projects and through general feedback from 42 developers that confirm the relevance of our reports.

Notes

To appear in the proceedings of the 41st IEEE/ACM International Conference on Software Engineering (ICSE) technical track, Montréal, Canada, 2019.

Files

VassalloICSE2019.pdf

Files (652.7 kB)

Name Size Download all
md5:458e883c0ad0c17763a9e9b9face927a
652.7 kB Preview Download