/github-action-pre-commit

A GitHub action to run pre-commit and allow overriding the git config user name and email

Primary LanguageJavaScriptMIT LicenseMIT

cloudposse/github-action-pre-commit

A GitHub action to run pre-commit

NOTE: This is a fork of pre-commit/action to add additional features.

Permissions required: repo and workflow

using this action

To use this action, make a file .github/workflows/pre-commit.yml. Here's a template to get started:

name: pre-commit

on:
  pull_request:
  push:
    branches: [master]

jobs:
  pre-commit:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v2
    - uses: actions/setup-python@v2
    - uses: makeshift/github-action-pre-commit@v2.1.2

This does a few things:

  • clones the code
  • installs python
  • sets up the pre-commit cache

using this action with custom invocations

By default, this action runs all the hooks against all the files. extra_args lets users specify a single hook id and/or options to pass to pre-commit run.

Here's a sample step configuration that only runs the flake8 hook against all the files (use the template above except for the pre-commit action):

    - uses: cloudposse/github-action-pre-commit@v2.1.2
      with:
        extra_args: flake8 --all-files

using this action in private repositories

this action also provides an additional behaviour when used in private repositories. when configured with a github token, the action will push back fixes to the pull request branch.

using the template above, you'll make two replacements for individual actions:

first is the checkout step, which needs to use unlimited fetch depth for pushing

    - uses: actions/checkout@v2
      with:
        fetch-depth: 0

next is passing the token to the pre-commit action

    - uses: cloudposse/github-action-pre-commit@v2.1.2
      with:
        token: ${{ secrets.GITHUB_TOKEN }}
        git_user_name: pre-commit
        git_user_email: pre-commit@example.com
        git_commit_message: "pre-commit fixes"

note that secrets.GITHUB_TOKEN is automatically provisioned and will not require any special configuration.

while you could technically configure this for a public repository (using a personal access token), I can't think of a way to do this safely without exposing a privileged token to pull requests -- if you have any ideas, please leave an issue!

additions by Makeshift

  • cancel_if_changed ('true' by default) - If true, will cancel this workflow run if pre-commit makes any changes to the repo.
  • start_if_changed ('true' by default) - If true, will start a new invocation of this workflow run if pre-commit makes any changes to the repo.

If both are true, then the current run will be cancelled and replaced with a new run with the changes made by pre-commit.