DocumentCode
44694
Title
Automated Fixing of Programs with Contracts
Author
Yu Pei ; Furia, Carlo A. ; Nordio, Martin ; Yi Wei ; Meyer, Bertrand ; Zeller, A.
Author_Institution
Dept. of Comput. Sci., ETH Zurich, Zurich, Switzerland
Volume
40
Issue
5
fYear
2014
fDate
May-14
Firstpage
427
Lastpage
449
Abstract
This paper describes AutoFix, an automatic debugging technique that can fix faults in general-purpose software. To provide high-quality fix suggestions and to enable automation of the whole debugging process, AutoFix relies on the presence of simple specification elements in the form of contracts (such as pre- and postconditions). Using contracts enhances the precision of dynamic analysis techniques for fault detection and localization, and for validating fixes. The only required user input to the AutoFix supporting tool is then a faulty program annotated with contracts; the tool produces a collection of validated fixes for the fault ranked according to an estimate of their suitability. In an extensive experimental evaluation, we applied AutoFix to over 200 faults in four code bases of different maturity and quality (of implementation and of contracts). AutoFix successfully fixed 42 percent of the faults, producing, in the majority of cases, corrections of quality comparable to those competent programmers would write; the used computational resources were modest, with an average time per fix below 20 minutes on commodity hardware. These figures compare favorably to the state of the art in automated program fixing, and demonstrate that the AutoFix approach is successfully applicable to reduce the debugging burden in real-world scenarios.
Keywords
contracts; fault diagnosis; program debugging; program diagnostics; software tools; AutoFix approach; AutoFix supporting tool; automated program fixing; automatic debugging technique; commodity hardware; computational resources; contracts; debugging process; dynamic analysis techniques; fault detection; fault localization; general-purpose software fault fixing; high-quality fix suggestions; Automation; Contracts; Debugging; Indexes; Libraries; Software; Software engineering; Automatic program repair; contracts; dynamic analysis;
fLanguage
English
Journal_Title
Software Engineering, IEEE Transactions on
Publisher
ieee
ISSN
0098-5589
Type
jour
DOI
10.1109/TSE.2014.2312918
Filename
6776507
Link To Document