• 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