Abstract
Writing a test case reproducing a reported software crash is a common practice to identify the root cause of an anomaly in the software under test. However, this task is usually labor-intensive and time-taking. Hence, evolutionary intelligence approaches have been successfully applied to assist developers during debugging by generating a test case reproducing reported crashes. These approaches use a single fitness function called Crash Distance to guide the search process toward reproducing a target crash. Despite the reported achievements, these approaches do not always successfully reproduce some crashes due to a lack of test diversity (premature convergence). In this study, we introduce a new approach, called MO-HO, that addresses this issue via multi-objectivization. In particular, we introduce two new Helper-Objectives for crash reproduction, namely test length (to minimize) and method sequence diversity (to maximize), in addition to Crash Distance. We assessed MOHO using five multi-objective evolutionary algorithms (NSGA-II, SPEA2, PESA-II, MOEA/D, FEMO) on 124 non-trivial crashes stemming from open-source projects. Our results indicate that SPEA2 is the best-performing multi-objective algorithm for MO-HO. We evaluated this best-performing algorithm for MO-HO against the state-of-the-art: single-objective approach (Single-Objective Search) and decomposition-based multi-objectivization approach (De-MO). Our results show that MO-HO reproduces five crashes that cannot be reproduced by the current state-of-the-art. Besides, MO-HO improves the effectiveness (+10% and +8% in reproduction ratio) and the efficiency in 34.6% and 36% of crashes (i.e., significantly lower running time) compared to Single-Objective Search and De-MO, respectively. For some crashes, the improvements are very large, being up to +93.3% for reproduction ratio and -92% for the required running time.
Original language | English |
---|---|
Title of host publication | Proceedings - 2020 35th IEEE/ACM International Conference on Automated Software Engineering, ASE 2020 |
Subtitle of host publication | Proceedings of the 35th IEEE/ACM International Conference on Automated Software Engineering |
Editors | John Grundy, David Lo, Claire Le Goues |
Place of Publication | New York |
Publisher | ACM |
Pages | 211-223 |
Number of pages | 13 |
ISBN (Electronic) | 9781450367684 |
DOIs | |
Publication status | Published - 2020 |
Event | 35th IEEE/ACM International Conference on Automated Software Engineering (ASE ’20), - Duration: 21 Sept 2020 → 25 Sept 2020 Conference number: 35 |
Publication series
Name | Proceedings - 2020 35th IEEE/ACM International Conference on Automated Software Engineering, ASE 2020 |
---|
Conference
Conference | 35th IEEE/ACM International Conference on Automated Software Engineering (ASE ’20), |
---|---|
Abbreviated title | ASE ’20 |
Period | 21/09/20 → 25/09/20 |
Other | Virtual/online event due to COVID-19 |
Keywords
- crash reproduction
- search-based software testing
- multi-objective evolutionary algorithms