The forgotten case of the dependency bugs: on the example of the robot operating system
- Conference Paper
A dependency bug is a software fault that manifests itself when accessing an unavailable asset. Dependency bugs are pervasive and we all hate them. This paper presents a case study of dependency bugs in the Robot Operating System (ROS), applying mixed methods: a qualitative investigation of 78 dependency bug reports, a quantitative analysis of 1354 ROS bug reports against 19553 reports in the top 30 GitHub projects, and a design of three dependency linters evaluated on 406 ROS packages. The paper presents a definition and a taxonomy of dependency bugs extracted from data. It describes multiple facets of these bugs and estimates that as many as 15% (!) of all reported bugs are dependency bugs. We show that lightweight tools can find dependency bugs efficiently, although it is challenging to decide which tools to build and difficult to build general tools. We present the research problem to the community, and posit that it should be feasible to eradicate it from software development practice. Show more
Book titleICSE-SEIP '20: Proceedings of the ACM/IEEE 42nd International Conference on Software Engineering: Software Engineering in Practice
Pages / Article No.
Organisational unit09628 - Su, Zhendong / Su, Zhendong
NotesConference postponed due to Corona virus (COVID-19). Conference rescheduled from June 24, 2020 - July 16, 2020 to July 6-11, 2020. Due to the Coronavirus (COVID-19) the conference was conducted virtually.
MoreShow all metadata