2020-06-20 21:19:56 +00:00
|
|
|
name: PR Lint keyboards
|
|
|
|
|
2022-12-22 23:41:16 +00:00
|
|
|
permissions:
|
|
|
|
contents: read
|
|
|
|
|
2020-06-20 21:19:56 +00:00
|
|
|
on:
|
|
|
|
pull_request:
|
|
|
|
paths:
|
|
|
|
- 'keyboards/**'
|
|
|
|
|
|
|
|
jobs:
|
2020-11-07 17:56:08 +00:00
|
|
|
lint:
|
2020-06-20 21:19:56 +00:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
2023-03-17 01:32:09 +00:00
|
|
|
container: ghcr.io/qmk/qmk_cli
|
2020-06-20 21:19:56 +00:00
|
|
|
|
|
|
|
steps:
|
2023-02-28 20:27:11 +00:00
|
|
|
- name: Disable safe.directory check
|
|
|
|
run : git config --global --add safe.directory '*'
|
|
|
|
|
2023-09-05 17:50:04 +00:00
|
|
|
- uses: actions/checkout@v4
|
2020-06-20 21:19:56 +00:00
|
|
|
with:
|
|
|
|
fetch-depth: 0
|
|
|
|
|
2022-06-09 20:02:16 +00:00
|
|
|
- name: Install dependencies
|
|
|
|
run: pip3 install -r requirements-dev.txt
|
|
|
|
|
2022-11-28 20:04:04 +00:00
|
|
|
- name: Get changed files
|
2020-08-17 09:12:45 +00:00
|
|
|
id: file_changes
|
2023-09-25 03:00:34 +00:00
|
|
|
uses: tj-actions/changed-files@v39
|
2020-08-17 09:12:45 +00:00
|
|
|
|
2020-06-20 21:19:56 +00:00
|
|
|
- name: Print info
|
|
|
|
run: |
|
|
|
|
git rev-parse --short HEAD
|
|
|
|
echo ${{ github.event.pull_request.base.sha }}
|
2022-11-28 20:04:04 +00:00
|
|
|
echo '${{ steps.file_changes.outputs.all_changed_files}}'
|
2020-06-20 21:19:56 +00:00
|
|
|
|
2020-11-07 17:56:08 +00:00
|
|
|
- name: Run qmk lint
|
2023-06-23 23:22:14 +00:00
|
|
|
if: always()
|
2020-06-20 21:19:56 +00:00
|
|
|
shell: 'bash {0}'
|
|
|
|
run: |
|
2022-11-28 20:04:04 +00:00
|
|
|
QMK_CHANGES=$(echo -e '${{ steps.file_changes.outputs.all_changed_files}}' | sed 's/ /\n/g')
|
2020-06-20 21:19:56 +00:00
|
|
|
QMK_KEYBOARDS=$(qmk list-keyboards)
|
|
|
|
|
|
|
|
exit_code=0
|
2023-01-22 03:15:10 +00:00
|
|
|
|
2020-06-20 21:19:56 +00:00
|
|
|
for KB in $QMK_KEYBOARDS; do
|
|
|
|
KEYBOARD_CHANGES=$(echo "$QMK_CHANGES" | grep -E '^(keyboards/'${KB}'/)')
|
|
|
|
if [[ -z "$KEYBOARD_CHANGES" ]]; then
|
|
|
|
# skip as no changes for this keyboard
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
|
|
|
|
KEYMAP_ONLY=$(echo "$KEYBOARD_CHANGES" | grep -cv /keymaps/)
|
|
|
|
if [[ $KEYMAP_ONLY -gt 0 ]]; then
|
|
|
|
echo "linting ${KB}"
|
|
|
|
|
2020-11-07 19:36:47 +00:00
|
|
|
qmk lint --keyboard ${KB} && qmk info -l --keyboard ${KB}
|
2020-11-10 15:21:59 +00:00
|
|
|
exit_code=$(($exit_code + $?))
|
2020-06-20 21:19:56 +00:00
|
|
|
fi
|
|
|
|
done
|
2023-01-22 03:15:10 +00:00
|
|
|
|
|
|
|
qmk format-text ${{ steps.file_changes.outputs.all_changed_files}} || true
|
|
|
|
for file in ${{ steps.file_changes.outputs.all_changed_files}}; do
|
|
|
|
if ! git diff --quiet $file; then
|
|
|
|
echo "File '${file}' Requires Formatting"
|
|
|
|
echo "::error file=${file}::Requires Formatting"
|
|
|
|
exit_code=$(($exit_code + 1))
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2020-11-10 15:21:59 +00:00
|
|
|
if [[ $exit_code -gt 255 ]]; then
|
|
|
|
exit 255
|
|
|
|
fi
|
2020-06-20 21:19:56 +00:00
|
|
|
exit $exit_code
|
2023-06-23 23:22:14 +00:00
|
|
|
|
|
|
|
- name: Verify at most one added keyboard
|
|
|
|
if: always()
|
|
|
|
shell: 'bash {0}'
|
|
|
|
run: |
|
|
|
|
git reset --hard
|
|
|
|
git clean -xfd
|
|
|
|
|
|
|
|
# Get the keyboard list and count for the target branch
|
|
|
|
git checkout -f ${{ github.base_ref }}
|
|
|
|
git pull --ff-only
|
|
|
|
QMK_KEYBOARDS_BASE=$(qmk list-keyboards)
|
|
|
|
QMK_KEYBOARDS_BASE_COUNT=$(qmk list-keyboards | wc -l)
|
|
|
|
|
|
|
|
# Get the keyboard list and count for the PR
|
|
|
|
git checkout -f ${{ github.head_ref }}
|
|
|
|
git merge --no-commit --squash ${{ github.base_ref }}
|
|
|
|
QMK_KEYBOARDS_PR=$(qmk list-keyboards)
|
|
|
|
QMK_KEYBOARDS_PR_COUNT=$(qmk list-keyboards | wc -l)
|
|
|
|
|
|
|
|
echo "::group::Keyboards changes in this PR"
|
|
|
|
diff -d -U 0 <(echo "$QMK_KEYBOARDS_BASE") <(echo "$QMK_KEYBOARDS_PR") | grep -vE '^(---|\+\+\+|@@)' | sed -e 's@^-@Removed: @g' -e 's@^+@ Added: @g'
|
|
|
|
echo "::endgroup::"
|
|
|
|
|
|
|
|
if [[ $QMK_KEYBOARDS_PR_COUNT -gt $(($QMK_KEYBOARDS_BASE_COUNT + 1)) ]]; then
|
|
|
|
echo "More than one keyboard added in this PR -- see the PR Checklist."
|
|
|
|
echo "::error::More than one keyboard added in this PR -- see the PR Checklist."
|
|
|
|
exit 1
|
|
|
|
fi
|