house-keeping: PR workflow check improvements
This commit is contained in:
parent
048c39abdf
commit
09cf4a17e0
1 changed files with 33 additions and 1 deletions
34
.github/workflows/formal.yml
vendored
34
.github/workflows/formal.yml
vendored
|
@ -22,7 +22,7 @@ jobs:
|
|||
echo "Building for $BRANCH"
|
||||
echo "BRANCH=$BRANCH" >> $GITHUB_ENV
|
||||
|
||||
- name: Test for merge, subject and S.O.B.
|
||||
- name: Test for merge commits, subject, S.O.B., and email
|
||||
run: |
|
||||
source .github/workflows/ci_helpers.sh
|
||||
|
||||
|
@ -34,22 +34,54 @@ jobs:
|
|||
RET=1
|
||||
fi
|
||||
|
||||
authorname="$(git show -s --format=%aN $commit)"
|
||||
if echo $authorname | grep -q '\S\+\s\+\S\+'; then
|
||||
success "Author name ($authorname) seems ok"
|
||||
elif echo $authorname | grep -q '\S\+'; then
|
||||
success "Author name ($authorname) seems to be nick or alias"
|
||||
else
|
||||
err "Author name ($authorname) must be one of: real name 'firstname lastname' OR nickname/alias/handle "
|
||||
RET=1
|
||||
fi
|
||||
|
||||
committername="$(git show -s --format=%cN $commit)"
|
||||
# Pattern \S\+\s\+\S\+ matches >= 2 names i.e. 3 and more e.g. "John Von Doe" also match
|
||||
if echo $committername | grep -q '\S\+\s\+\S\+'; then
|
||||
success "Committer name ($committername) seems ok"
|
||||
elif echo $committername | grep -q '\S\+'; then
|
||||
# Pattern \S\+ matches single names, typical of nicks or handles
|
||||
success "Committer name ($committername) seems to be nick or alias"
|
||||
else
|
||||
err "Committer name ($committername) must be one of: real name 'firstname lastname' OR nickname/alias/handle "
|
||||
RET=1
|
||||
fi
|
||||
|
||||
subject="$(git show -s --format=%s $commit)"
|
||||
if echo "$subject" | grep -q -e '^[0-9A-Za-z,+/_-]\+: ' -e '^Revert '; then
|
||||
success "Commit subject line seems ok ($subject)"
|
||||
elif echo "$subject" | grep -iq '^Translated using Weblate.*'; then
|
||||
success "Weblate commit subject line exception OK: $subject"
|
||||
else
|
||||
err "Commit subject line MUST start with '<package name>: ' ($subject)"
|
||||
RET=1
|
||||
fi
|
||||
|
||||
body="$(git show -s --format=%b $commit)"
|
||||
authoremail="$(git show -s --format='<%aE>' $commit)"
|
||||
sob="$(git show -s --format='Signed-off-by: %aN <%aE>' $commit)"
|
||||
if echo "$body" | grep -qF "$sob"; then
|
||||
success "Signed-off-by matches author"
|
||||
elif echo "$authoremail" | grep -iqF "<hosted@weblate.org>"; then
|
||||
success "Signed-off-by exception: authored by Weblate"
|
||||
else
|
||||
err "Signed-off-by is missing or doesn't match author (should be '$sob')"
|
||||
RET=1
|
||||
fi
|
||||
|
||||
if echo "$authoremail" | grep -iqF "users.noreply"; then
|
||||
err "Real email address policy: please configure GitHub email ($authoremail) to a real one"
|
||||
RET=1
|
||||
fi
|
||||
done
|
||||
|
||||
exit $RET
|
||||
|
|
Loading…
Reference in a new issue