Automatic patch generation with context-based change application

Jindae Kim, Sunghun Kim

Research output: Contribution to journalArticlepeer-review

28 Scopus citations

Abstract

Automatic patch generation is often described as a search problem of patch candidate space, and it has two major issues: one is search space size, and the other is navigation. An effective patch generation technique should have a large search space with a high probability that patches for bugs are included, and it also needs to locate such patches effectively. We introduce ConFix, an automatic patch generation technique using context-based change application. ConFix collects abstract AST changes from human-written patches with their AST contexts to provide abundant resources for patch generation. These collected changes are only applied to possible fix locations with the same contexts for patch generation. By considering changes with a matching context only, ConFix selects a necessary change for a possible fix location more effectively than considering all the collected changes. Also, ConFix filters out fix locations with no collected changes in the same context, which means that such locations have not been modified in human-written patches, hence they are not desirable for modifications. We evaluated ConFix with 357 real bugs from Defects4j dataset. ConFix successfully fixed 22 bugs including six bugs which were not fixed by compared existing techniques. With context-based strategy, ConFix checked on average 48% less fix locations than a strategy using only a spectrum-based fault localization technique until patches were generated. Also, it ranked changes required for patches at the top for 63.6%, and within top-3 for 81.8% of the fixed bugs.

Original languageEnglish
Pages (from-to)4071-4106
Number of pages36
JournalEmpirical Software Engineering
Volume24
Issue number6
DOIs
StatePublished - 1 Dec 2019

Keywords

  • Automatic patch generation
  • Automatic program repair
  • Context-based change application

Fingerprint

Dive into the research topics of 'Automatic patch generation with context-based change application'. Together they form a unique fingerprint.

Cite this