2020-09-22 09:28:04 +02:00
|
|
|
name: check-whitespace
|
|
|
|
|
|
|
|
# Get the repo with the commits(+1) in the series.
|
|
|
|
# Process `git log --check` output to extract just the check errors.
|
|
|
|
# Add a comment to the pull request with the check errors.
|
|
|
|
|
|
|
|
on:
|
|
|
|
pull_request:
|
|
|
|
types: [opened, synchronize]
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
check-whitespace:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- name: Set commit count
|
|
|
|
shell: bash
|
2020-11-07 02:21:45 +01:00
|
|
|
run: echo "COMMIT_DEPTH=$((1+$COMMITS))" >>$GITHUB_ENV
|
2020-09-22 09:28:04 +02:00
|
|
|
env:
|
|
|
|
COMMITS: ${{ github.event.pull_request.commits }}
|
|
|
|
|
|
|
|
- uses: actions/checkout@v2
|
|
|
|
with:
|
|
|
|
fetch-depth: ${{ env.COMMIT_DEPTH }}
|
|
|
|
|
|
|
|
- name: git log --check
|
|
|
|
id: check_out
|
|
|
|
run: |
|
|
|
|
log=
|
|
|
|
commit=
|
|
|
|
while read dash etc
|
|
|
|
do
|
|
|
|
case "${dash}" in
|
|
|
|
"---")
|
|
|
|
commit="${etc}"
|
|
|
|
;;
|
|
|
|
"")
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
if test -n "${commit}"
|
|
|
|
then
|
|
|
|
log="${log}\n${commit}"
|
|
|
|
echo ""
|
|
|
|
echo "--- ${commit}"
|
|
|
|
fi
|
|
|
|
commit=
|
|
|
|
log="${log}\n${dash} ${etc}"
|
|
|
|
echo "${dash} ${etc}"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done <<< $(git log --check --pretty=format:"---% h% s" -${{github.event.pull_request.commits}})
|
|
|
|
|
|
|
|
if test -n "${log}"
|
|
|
|
then
|
|
|
|
echo "::set-output name=checkout::"${log}""
|
|
|
|
exit 2
|
|
|
|
fi
|
|
|
|
|
|
|
|
- name: Add Check Output as Comment
|
|
|
|
uses: actions/github-script@v3
|
|
|
|
id: add-comment
|
2020-11-03 16:55:31 +01:00
|
|
|
env:
|
|
|
|
log: ${{ steps.check_out.outputs.checkout }}
|
2020-09-22 09:28:04 +02:00
|
|
|
with:
|
|
|
|
script: |
|
2020-11-03 16:55:31 +01:00
|
|
|
await github.issues.createComment({
|
2020-09-22 09:28:04 +02:00
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
2020-11-03 16:55:31 +01:00
|
|
|
body: `Whitespace errors found in workflow ${{ github.workflow }}:\n\n\`\`\`\n${process.env.log.replace(/\\n/g, "\n")}\n\`\`\``
|
2020-09-22 09:28:04 +02:00
|
|
|
})
|
|
|
|
if: ${{ failure() }}
|