Skip to content

RAID is a tool pipeline that seamlessly enriches GitHub diff results with refactoring information.

License

Notifications You must be signed in to change notification settings

rodrigo-brito/refactoring-aware-diff

Repository files navigation

RAID: Refactoring-aware and Intelligent Diffs

Tests and Lint Chrome Web Store MIT license

Code review is a key practice in modern software development. Currently, this practice is performed using textual diff tools, such as the one provided by GitHub. However, diff results can easily become complex and hard to understand. Refactorings, for example, are not represented at all in diff results. This makes diff understanding more complex because reviewers need to infer themselves that a given group of added and removed lines of code represent, for example, an extract method.

result

RAID is a tool pipeline that seamlessly enriches GitHub diff results with refactoring information. See the following figure:

As presented in this figure, this pipeline has three key components:

  • RefDiff: a tool to detect refactoring operations in commits. We rely on GitHub Actions to automatically execute RefDiff after each Pull Request.

  • An external server, that collects the list of refactorings produced by RefDiff.

  • A Chrome plug-in that seamlessly annotates diff chunks with refactoring data (see the following snapshot).

Example of Move Method

Move Method

Supported Refactorings

RAID relies on RefDiff and support the following refactorings

Language Language Refactorings
Java Move, Extract Function, Inline Function, Rename, Change Signature, Pull Up, Push Down
JavaScript Move, Extract Function, Inline Function, Rename, Change Signature, Pull Up, Push Down
C Move, Extract Function, Inline Function, Rename, Change Signature
Go Move, Extract Function, Inline Function, Rename, Change Signature

Installation

To detect refactorings in your repository, you must first install this Chrome plug-in and configure RefDiff on Github Actions.

To execute RefDiff as Github Actions, you need to create a workflow file in .github/workflows folder with .yaml extension. Example of configuration: .github/workflows/workflow.yml:

on: [pull_request] # Trigger RefDiff after each pull request

jobs:
    main:
        runs-on: ubuntu-latest
        name: Refactoring Detection
        steps:
            - name: Git Checkout
              uses: actions/checkout@v2
              with:
                  fetch-depth: 0

            - name: raid
              env:
                  LANGUAGE: ${{ github.event.repository.language }} # Supports Java, Javascrit, C and Go.
                  REV_BEFORE: ${{ github.event.pull_request.base.sha }}
                  REV_AFTER: ${{ github.event.pull_request.head.sha }}
              uses: rodrigo-brito/refactoring-aware-diff@action

Simple Example

We created a simple pull request with commits including toy refactorings, to illustrate the usage of our plug-in. See here (but first you need to install our plug in).

How cite RAID

@inproceedings{brito2021, 
  author = {Rodrigo Brito and Marco Tulio Valente}, 
  title = {{RAID}: Tool Support for Refactoring-Aware Code Reviews}, 
  booktitle = {29th International Conference on Program Comprehension (ICPC)}, 
  year = {2021}, 
  pages = {265--275}
}

DOI: https://doi.ieeecomputersociety.org/10.1109/ICPC52881.2021.00033

License

Distributed under the MIT License. See LICENSE for more information.

About

RAID is a tool pipeline that seamlessly enriches GitHub diff results with refactoring information.

Topics

Resources

License

Stars

Watchers

Forks

Languages