mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-11-22 07:28:10 +00:00
ci: add check for release branches
If release branch, CI now checks that all commits are either cherry-picked from master (using `-x` option) or contain [NO MASTER].
This commit is contained in:
parent
f054bf6e95
commit
503bbb0eb3
31
ci/check_release_commit_messages.sh
Executable file
31
ci/check_release_commit_messages.sh
Executable file
@ -0,0 +1,31 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
fail=0
|
||||||
|
|
||||||
|
# list all commits between HEAD and master
|
||||||
|
for commit in $(git rev-list origin/master..)
|
||||||
|
do
|
||||||
|
message=$(git log -n1 --format=%B $commit)
|
||||||
|
echo "Checking $commit"
|
||||||
|
|
||||||
|
# The commit message must contain either
|
||||||
|
# 1. "cherry-picked from [some commit in master]"
|
||||||
|
if [[ $message =~ "(cherry picked from commit" ]]; then
|
||||||
|
# remove last ")" and extract commit hash
|
||||||
|
master_commit=$(echo ${message:0:-1} | tr ' ' '\n' | tail -1)
|
||||||
|
# check if master really contains this commit hash
|
||||||
|
if [[ $(git branch -a --contains $master_commit | grep --only-matching master) == "master" ]]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 2. [NO MASTER] substring
|
||||||
|
if [[ $message =~ "[NO MASTER]" ]]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
fail=1
|
||||||
|
echo "FAILURE! Neither 'cherry picked from..' nor '[NO MASTER]' substring found in this commit message."
|
||||||
|
done
|
||||||
|
|
||||||
|
exit $fail
|
@ -34,3 +34,10 @@ gen prebuild:
|
|||||||
- "**/*.pyi"
|
- "**/*.pyi"
|
||||||
script:
|
script:
|
||||||
- pipenv run make gen_check
|
- pipenv run make gen_check
|
||||||
|
|
||||||
|
release commit messages prebuild:
|
||||||
|
stage: prebuild
|
||||||
|
only:
|
||||||
|
- /^release\//
|
||||||
|
script:
|
||||||
|
- ci/check_release_commit_messages.sh
|
||||||
|
Loading…
Reference in New Issue
Block a user