Back to overview

Automated reporting of anti-patterns and decay in continuous integration

Type of publication Peer-reviewed
Publikationsform Proceedings (peer-reviewed)
Author Vassallo Carmine, Proksch Sebastian, Gall Harald C., Penta Massimiliano Di,
Project SURF-MobileAppsData
Show all

Proceedings (peer-reviewed)

Editor , Whittle Jon; , Bultan Tevfik; , Atlee Joanne M.
Page(s) 105 - 115
Title of proceedings Proceedings of the 41st Int Conf on Software Engineering, ICSE 2019
DOI 10.1109/icse.2019.00028

Open Access

Type of Open Access Repository (Green Open Access)


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.