DocumentCode :
1606315
Title :
DirectFix: Looking for Simple Program Repairs
Author :
Mechtaev, Sergey ; Jooyong Yi ; Roychoudhury, Abhik
Author_Institution :
Nat. Univ. of Singapore, Singapore, Singapore
Volume :
1
fYear :
2015
Firstpage :
448
Lastpage :
458
Abstract :
Recent advances in program repair techniques have raised the possibility of patching bugs automatically. For an automatically generated patch to be accepted by developers, it should not only resolve the bug but also satisfy certain human-related factors including readability and comprehensibility. In this paper, we focus on the simplicity of patches (the size of changes). We present a novel semantics-based repair method that generates the simplest patch such that the program structure of the buggy program is maximally preserved. To take into account the simplicity of repairs in an efficient way (i.e., Without explicitly enumerating each repair candidate for each fault location), our method fuses fault localization and repair generation into one step. We do so by leveraging partial Max SAT constraint solving and component-based program synthesis. We compare our prototype implementation, Direct Fix, with the state-of-the-art semantics-based repair tool Sem Fix, that performs fault localization before repair generation. In our experiments with SIR programs and GNU Coreutils, Direct Fix generates repairs that are simpler than those generated by Sem Fix. Since both Direct Fix and Sem Fix are test-driven repair tools, they can introduce regressions for other tests which do not drive the repair. We found that Direct Fix causes substantially less regression errors than Sem Fix.
Keywords :
human factors; object-oriented programming; program debugging; regression analysis; software fault tolerance; software maintenance; DirectFix; Max SAT constraint solving; bug patching; component-based program synthesis; comprehensibility; fault location; human-related factor; patch simplicity; program repair technique; readability; regression error; repair generation; semantics-based repair method; Computer bugs; Encoding; Fault location; Fuses; Maintenance engineering; Semantics; Automated Repair; Program Synthesis; SMT solving;
fLanguage :
English
Publisher :
ieee
Conference_Titel :
Software Engineering (ICSE), 2015 IEEE/ACM 37th IEEE International Conference on
Conference_Location :
Florence
Type :
conf
DOI :
10.1109/ICSE.2015.63
Filename :
7194596
Link To Document :
بازگشت