Evaluating Refactoring-Aware Merging: An Experimental Study
- Contact:
- Manuel Ohrndorf
- Timo Kehrer
Context
Traditional merge tools (e.g., Git merge) often treat refactorings as conflicting changes, leading to unnecessary conflicts. On the contrary, a refactoring-aware approach may recognize and account for refactorings, preventing false positives in conflict detection.
Motivation
While the concept of refactoring-aware merging has been proposed in the literature, practical experience with tooling remains limited and not widely adopted in mainstream development workflows.
Goal
This work aims to experimentally evaluate the potential and limitations of refactoring-aware merging by setting up an experimental environment, populating it with controlled conflict scenarios, and analyzing the results.
Project Outline
- Create (and extend during the project) a catalog of minimalistic examples for refactoring-aware merge scenarios.
- Introduce a detailed logging in the refactoring-aware merge tool, recording the computational steps (and their assumptions).
- Design and implement a, e.g., web-based, visualization of the process log.
Requirements
- Very good programming skills in Java
- A good understanding of the concept of object-oriented refactoring
- Experience in collaborative software development with Git, dealing with merge conflicts
- Interest in diving into recent research literature on refactoring-aware merging
Pointers
- Ellis, Max, Sarah Nadi, and Danny Dig. “Operation-based refactoring-aware merging: An empirical evaluation.” IEEE Transactions on Software Engineering 49.4 (2022): 2698-2721. https://arxiv.org/pdf/2112.10370
- RefMerge Dev Container