Anirban166 / Autocomment-atime-results

GitHub Action that automatically comments a plot and other atime-based results on PRs

Home Page:https://github.com/marketplace/actions/autocomment-atime-results

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

A GitHub Action for R packages that runs atime::atime_pkg and comments the generated results on pull requests to help identify potential performance regressions introduced from the incoming changes.

Contents of the comment consist of:

  • A plot comparing different versions1 of the package on all the test cases (portrayed side-by-side) that are defined in the .ci/atime/tests.R file within the respository. 1Versions include base (the target branch), HEAD (the PR/source branch), merge-base (their common ancestor), and CRAN (yup, your package needs to be there :).
  • The SHA for the commit that triggered the workflow (or as an end result, generated that comment) within the PR.
  • A download link to retrieve a zipped file containing the atime-generated results.
  • The elapsed time from the job's start to the completion of the standard installation steps, and the time it took to run all the tests.

To avoid flooding the pull request on every push to it, only one comment will exist in the PR thread at all times. After the initial comment generated from the first commit on the pull request branch, subsequent pushes will simply update the comment's body.

Usage

For any GitHub repository of an R package, one can use this template:

name: Autocomment atime-based performance regression analysis on PRs

on:
  pull_request:
    branches:
      - '*'
    types:
      - opened
      - reopened
      - synchronize

jobs:
  comment:
    runs-on: ubuntu-latest
    container: ghcr.io/iterative/cml:0-dvc2-base1
    env:
      GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }}
      repo_token: ${{ secrets.GITHUB_TOKEN }}
      R_KEEP_PKG_SOURCE: yes
    steps:
      - uses: Anirban166/Autocomment-atime-results@v1.2.0

Emplace the contents in .github/workflows/<workflowName>.yml. The example I provided above can be customized further as needed, as long as a few things are kept intact:

  • The workflow runs on a pull_request event
  • GITHUB_PAT is supplied (required to authenticate git operations, have higher rate limits, etc.)
  • The container and repo_token fields are specified as I did above (required for cml functionality)

About

GitHub Action that automatically comments a plot and other atime-based results on PRs

https://github.com/marketplace/actions/autocomment-atime-results