Skip to content

Commit

Permalink
โš™๏ธ config(ci): Add workflow to test precommit hook.
Browse files Browse the repository at this point in the history
Fixes #794.
  • Loading branch information
make-github-pseudonymous-again committed May 22, 2024
1 parent d4cbde9 commit 939c99a
Showing 1 changed file with 81 additions and 0 deletions.
81 changes: 81 additions & 0 deletions .github/workflows/ci:precommit.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
name: ci:precommit

on:
push:
branches:
- main
pull_request:
merge_group:

concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true

jobs:

test:
name: Continuous integration (test precommit)
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- name: Checkout ๐Ÿ›Ž๏ธ
uses: actions/checkout@v4
with:
# TODO Fetch sparingly with something similar to
# https://github.com/rmacklin/fetch-through-merge-base/blob/main/action.yml
# Maybe could use commit count (does not exist on merge_group
# somehow)
# Maybe setting .git/shallow to base first would work in all cases?
# See https://stackoverflow.com/a/76573878
fetch-depth: 0

# TODO Make this a reusable action
- name: Compute BASE_SHA and HEAD_SHA for push event ๐Ÿ“œ
if: github.event_name == 'push'
run: |
BASE_SHA="${{ github.event.before }}"
echo "BASE_SHA=${BASE_SHA}" >> "${GITHUB_ENV}"
HEAD_SHA="${{ github.event.after }}"
echo "HEAD_SHA=${HEAD_SHA}" >> "${GITHUB_ENV}"
- name: Compute BASE_SHA and HEAD_SHA for pull_request event ๐Ÿ“œ
if: github.event_name == 'pull_request'
run: |
BASE_SHA="${{ github.event.pull_request.base.sha }}"
echo "BASE_SHA=${BASE_SHA}" >> "${GITHUB_ENV}"
HEAD_SHA="${{ github.event.pull_request.head.sha }}"
echo "HEAD_SHA=${HEAD_SHA}" >> "${GITHUB_ENV}"
- name: Compute BASE_SHA and HEAD_SHA for merge_group event ๐Ÿ“œ
if: github.event_name == 'merge_group'
run: |
BASE_SHA="${{ github.event.merge_group.base_sha }}"
echo "BASE_SHA=${BASE_SHA}" >> "${GITHUB_ENV}"
HEAD_SHA="${{ github.event.merge_group.head_sha }}"
echo "HEAD_SHA=${HEAD_SHA}" >> "${GITHUB_ENV}"
- name: Compute MERGE_BASE ๐ŸŒฑ
id: history
env:
BASE_SHA: ${{ env.BASE_SHA }}
HEAD_SHA: ${{ env.HEAD_SHA }}
run: |
FIRST_NEW_COMMIT="$(git log "${BASE_SHA}..${HEAD_SHA}" --pretty=format:%H | tail -1)"
MERGE_BASE="$(git rev-list -n1 "${FIRST_NEW_COMMIT}~")"
echo "merge-base=${MERGE_BASE}" >> "${GITHUB_OUTPUT}"
- name: Stage MERGE_BASE...HEAD_SHA โฎ๏ธ
env:
HEAD_SHA: ${{ env.HEAD_SHA }}
MERGE_BASE: ${{ steps.history.outputs.merge-base }}
run: |
git reset --hard "${HEAD_SHA}"
git reset --soft "${MERGE_BASE}"
# TODO Do something destructive to check that it is not picked up.
- name: Install ๐Ÿ’พ
uses: ./.github/actions/install

- name: Run precommit ๐Ÿ”ฌ
run: |
npm run precommit

0 comments on commit 939c99a

Please sign in to comment.