4.6 Article

An Empirical Study of Boosting Spectrum-Based Fault Localization via PageRank

期刊

IEEE TRANSACTIONS ON SOFTWARE ENGINEERING
卷 47, 期 6, 页码 1089-1113

出版社

IEEE COMPUTER SOC
DOI: 10.1109/TSE.2019.2911283

关键词

Software testing; automated debugging; spectrum-based fault localization; SBFL; PageRank analysis

资金

  1. Ministry of Science and Technology of China [2017YFC0804002]
  2. Shenzhen Peacock Plan [KQTD2016112514355531]
  3. Science and Technology Innovation Committee Foundation of Shenzhen [JCYJ20170817110848086, ZDSYS201703031748284]
  4. US National Science Foundation [CCF-1566589, CCF-1763906, CCF-1704790, CCF-1718903]
  5. Amazon
  6. Futurewei
  7. Samsung

向作者/读者索取更多资源

The article introduces a lightweight fault localization technique named PRFL, built upon existing SBFL techniques, which utilizes the PageRank algorithm to differentiate test cases for more effective fault localization. Experimental results demonstrate the superior performance of PRFL in real and artificial fault localization, surpassing various recent proposed fault localization techniques.
Manual debugging is notoriously tedious and time-consuming. Therefore, various automated fault localization techniques have been proposed to help with manual debugging. Among the existing fault localization techniques, spectrum-based fault localization (SBFL) is one of the most widely studied techniques due to being lightweight. The focus of the existing SBFL techniques is to consider how to differentiate programentities (i.e., one dimension in program spectra); indeed, this focus is aligned with the ultimate goal of finding the faulty lines of code. Our key insight is to enhance the existing SBFL techniques by additionally considering how to differentiate tests (i.e., the other dimension in programspectra), which, to the best of our knowledge, has not been studied in prior work. We present our basic approach, PRFL, a lightweight technique that boosts SBFL by differentiating tests using PageRank algorithm. Specifically, given the original program spectrum information, PRFL uses PageRank to recompute the spectrum by considering the contributions of different tests. Next, traditional SBFL techniques are applied on the recomputed spectrum to achieve more effective fault localization. On top of PRFL, we explore PRFL+ and PRFLMA, two variants which extend PRFL by optimizing its components and integrating Method-level Aggregation technique, respectively. Though being simple and lightweight, PRFL has been demonstrated to outperform state-of-the-art SBFL techniques significantly (e.g., ranking 39.2% / 82.3% more real/artificial faults at Top-1 compared with the most effective traditional SBFL technique) with low overhead (e.g., around 6 minutes average extra overhead on real faults) on 395 real faults from 6 Defects4J projects and 96925 artificial (i.e., mutation) faults from 240 GitHub projects. To further validate PRFL's effectiveness, we compare PRFL with multiple recent proposed fault localization techniques (e.g., Multric, Metallaxis and MBFL-hybrid-avg), and the experimental results show that PRFL outperforms them as well. Furthermore, we study the performance of PRFLMA, and the experimental results present it can locate 137 real faults (73.4%/ 24.5% more compared with the most effective SBFL/PRFL technique) and 35058 artificial faults (159.6% / 28.1% more than SBFL/PRFL technique) at Top-1. At last, we study the generalizability of PRFL on another benchmark, Bugs.jar, and the result shows PRFL can help locate around 30 percent more faults at Top 1.

作者

我是这篇论文的作者
点击您的名字以认领此论文并将其添加到您的个人资料中。

评论

主要评分

4.6
评分不足

次要评分

新颖性
-
重要性
-
科学严谨性
-
评价这篇论文

推荐

暂无数据
暂无数据