diff options
author | Matt Strapp <matt@mattstrapp.net> | 2024-01-23 11:11:51 -0600 |
---|---|---|
committer | Matt Strapp <matt@mattstrapp.net> | 2024-01-23 11:16:21 -0600 |
commit | 86b8df3c7ca69f8647277403c6652ef42fde1793 (patch) | |
tree | 69e68aebcea77443da8ed1d7fe4d1041b1d854f7 | |
parent | Run build on PR too (diff) | |
download | trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.tar trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.tar.gz trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.tar.bz2 trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.tar.lz trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.tar.xz trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.tar.zst trinkets-86b8df3c7ca69f8647277403c6652ef42fde1793.zip |
Add stolen dependabot auto-merge
Signed-off-by: Matt Strapp <matt@mattstrapp.net>
Diffstat (limited to '')
-rw-r--r-- | .github/workflows/dependabot-auto.yaml | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/.github/workflows/dependabot-auto.yaml b/.github/workflows/dependabot-auto.yaml new file mode 100644 index 0000000..69e889b --- /dev/null +++ b/.github/workflows/dependabot-auto.yaml @@ -0,0 +1,43 @@ +# Shamelessly stolen from https://nicolasiensen.github.io/2022-07-23-automating-dependency-updates-with-dependabot-github-auto-merge-and-github-actions/ + +name: Dependabot reviewer + +on: pull_request_target + +permissions: + pull-requests: write + contents: write + +jobs: + review-dependabot-pr: + runs-on: ubuntu-latest + if: ${{ github.event.pull_request.user.login == 'dependabot[bot]' }} + steps: + - name: Dependabot metadata + id: dependabot-metadata + uses: dependabot/fetch-metadata@v1.3.1 + - name: Enable auto-merge for Dependabot PRs + run: gh pr merge --auto --rebase "$PR_URL" + env: + PR_URL: ${{github.event.pull_request.html_url}} + GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} + - name: Approve patch and minor updates + if: ${{steps.dependabot-metadata.outputs.update-type == 'version-update:semver-patch' || steps.dependabot-metadata.outputs.update-type == 'version-update:semver-minor'}} + run: gh pr review $PR_URL --approve -b "I'm **approving** this pull request because **it includes a patch or minor update**" + env: + PR_URL: ${{github.event.pull_request.html_url}} + GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} + - name: Approve major updates of development dependencies + if: ${{steps.dependabot-metadata.outputs.update-type == 'version-update:semver-major' && steps.dependabot-metadata.outputs.dependency-type == 'direct:development'}} + run: gh pr review $PR_URL --approve -b "I'm **approving** this pull request because **it includes a major update of a dependency used only in development**" + env: + PR_URL: ${{github.event.pull_request.html_url}} + GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} + - name: Comment on major updates of non-development dependencies + if: ${{steps.dependabot-metadata.outputs.update-type == 'version-update:semver-major' && steps.dependabot-metadata.outputs.dependency-type == 'direct:production'}} + run: | + gh pr comment $PR_URL --body "I'm **not approving** this PR because **it includes a major update of a dependency used in production**" + gh pr edit $PR_URL --add-label "requires-manual-qa" + env: + PR_URL: ${{github.event.pull_request.html_url}} + GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
\ No newline at end of file |