5
0
Fork 0
mirror of https://github.com/pre-commit/action.git synced 2025-11-07 02:36:55 +00:00
a GitHub action to run pre-commit
Find a file
Anthony Sottile ef992f5a23
Merge pull request #43 from Julian/patch-1
Update README example to use latest actions/setup-python and actions/checkout versions
2020-08-26 16:14:37 -07:00
.github/workflows Initial commit 2019-11-24 19:27:32 -08:00
.gitignore Initial commit 2019-11-24 19:27:32 -08:00
.pre-commit-config.yaml Run pre-commit autoupdate 2020-05-11 14:14:30 -07:00
action.yml Support extra_args keyword in pre-commit GitHub action 2020-05-15 08:14:38 -07:00
index.js do not save the cache if it was restored 2020-06-13 12:58:38 -07:00
LICENSE add LICENSE resolves #25 2020-05-16 09:34:36 -07:00
Makefile include the license in the release output 2020-05-22 13:06:23 -07:00
package-lock.json Bump elliptic from 6.5.2 to 6.5.3 2020-08-01 05:31:15 +00:00
package.json embedding cache steps by using @actions/cache 2020-06-13 12:43:57 -07:00
README.md Same for actions/checkout. 2020-08-26 19:04:09 -04:00
webpack.config.js set mode: production to silence webpack warning 2020-05-22 14:29:06 -07:00

Build Status

pre-commit/action

a GitHub action to run pre-commit

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: pre-commit/action@v2.0.0

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: pre-commit/action@v2.0.0
      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: pre-commit/action@v2.0.0
      with:
        token: ${{ secrets.GITHUB_TOKEN }}

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!