What if a bug has a different origin? making sense of bugs without an explicit bug introducing change

Gema Rodriguez Perez, Andy Zaidman, A. Serebrenik, Gregorio Robles, Jesús M. González-Barahona

Research output: Chapter in Book/Report/Conference proceedingConference contributionAcademicpeer-review

18 Citations (Scopus)

Abstract

Background: Many studies in the software research literature on bug fixing are built upon the assumption that "a given bug was introduced by the lines of code that were modified to fix it", or variations of it. Although this assumption seems very reasonable at first glance, there is little empirical evidence supporting it. A careful examination surfaces that there are other possible sources for the introduction of bugs such as modifications to those lines that happened before the last change an changes external to the piece of code being fixed. Goal: We aim at understanding the complex phenomenon of bug introduction and bug fix. Method: We design a preliminary approach distinguishing between bug introducing commits (BIC) and first failing moments (FFM). We apply this approach to Nova and ElasticSearch, two large and well-known open source software projects. Results: In our initial results we obtain that at least 24% bug fixes in Nova and 10% in ElasticSearch have not been caused by a BIC but by co-evolution, compatibility issues or bugs in external API. Merely 26--29% of BICs can be found using the algorithm based on the assumption that "a given bug was introduced by the lines of code that were modified to fix it". Conclusions: The approach allows also for a better framing of the comparison of automatic methods to find bug inducting changes. Our results indicate that more attention should be paid to whether a bug has been introduced and, when it was introduced.
Original languageEnglish
Title of host publicationESEM '18 Proceedings of the 12th ACM/IEEE International Symposium on Empirical Software Engineering and Measurement
Place of PublicationNew York
PublisherAssociation for Computing Machinery, Inc
Number of pages4
ISBN (Electronic)9781450358231
ISBN (Print)978-1-4503-5823-1
DOIs
Publication statusPublished - 11 Oct 2018
Event12th ACM/IEEE International Conference on Empirical Software Engineering and Measurement - Oulu, Finland
Duration: 11 Oct 201812 Oct 2018
Conference number: 12
http://eseiw2018.wixsite.com/esem2018

Conference

Conference12th ACM/IEEE International Conference on Empirical Software Engineering and Measurement
Abbreviated titleESEM'18
Country/TerritoryFinland
CityOulu
Period11/10/1812/10/18
Internet address

Keywords

  • Bug-introducing change
  • Empirical study
  • SZZ algorithm

Fingerprint

Dive into the research topics of 'What if a bug has a different origin? making sense of bugs without an explicit bug introducing change'. Together they form a unique fingerprint.

Cite this