Detecting semantic conflicts with unit tests
Journal article, 2024

While modern merge techniques, such as 3-way and structured merge, can resolve textual conflicts automatically, they fail when the conflict arises not at the syntactic, but at the semantic level. Detecting such semantic conflicts requires understanding the behavior of the software, which is beyond the capabilities of most existing merge tools. Although semantic merge tools have been proposed, they are usually based on heavyweight static analyses, or need explicit specifications of program behavior. In this work, we take a different route and propose SAM (SemAntic Merge), a semantic merge tool based on the automated generation of unit tests that are used as partial specifications of the changes to be merged, and that drive the detection of unwanted behavior changes (conflicts) when merging software. To evaluate SAM's feasibility for detecting conflicts, we perform an empirical study relying on a dataset of more than 80 pairs of changes integrated to common class elements (constructors, methods, and fields) from 51 merge scenarios. We also assess how the four unit test generation tools used by SAM individually contribute to conflict identification. Our results show that SAM performs best when combining only the tests generated by Differential EvoSuite and EvoSuite, and using our proposed testability transformations (nine detected conflicts out of 29). These results reinforce previous findings about the potential of using test-case generation to detect conflicts as a method that is versatile and requires only limited deployment effort in practice.

Semantic conflicts

Differential testing

Behavior change

Author

Léuson Da Silva

École Polytechnique de Montréal

Federal University of Pernambuco

Paulo Borba

Federal University of Pernambuco

Toni Maciel

Federal University of Pernambuco

Wardah Mahmood

Software Engineering 2

University of Gothenburg

Thorsten Berger

Ruhr-Universität Bochum

Software Engineering 2

University of Gothenburg

Joao Moisakis

Federal University of Pernambuco

Aldiberg Gomes

Federal University of Pernambuco

Vinícius Leite

Federal University of Pernambuco

Journal of Systems and Software

0164-1212 (ISSN)

Vol. 214 112070

Subject Categories

Computer Science

DOI

10.1016/j.jss.2024.112070

More information

Latest update

6/24/2024