status-go/_assets/scripts/commit_check.sh
2024-08-14 19:55:09 +01:00

34 lines
1.1 KiB
Bash
Executable File

#!/usr/bin/env bash
set -euo pipefail
parse_commits() {
BASE_BRANCH=${BASE_BRANCH:-develop}
start_commit=${1:-origin/${BASE_BRANCH}}
end_commit=${2:-HEAD}
is_breaking_change=false
echo "checking commits between: $start_commit $end_commit" >&2
# Run the loop in the current shell using process substitution
while IFS= read -r message || [ -n "$message" ]; do
# Check if commit message follows conventional commits format
if [[ $message =~ ^(build|chore|ci|docs|feat|fix|perf|refactor|revert|style|test)(\(.*\))?(\_|!):.*$ ]]; then
# Check for breaking changes
if [[ ${BASH_REMATCH[3]} == *'!'* ]]; then
is_breaking_change=true
break
fi
else
echo "Commit message \"$message\" is not well-formed. Aborting merge. We use https://www.conventionalcommits.org/en/v1.0.0/ but with _ for non-breaking changes"
# Uncomment the line below if you want to exit on an invalid commit message
exit 1
fi
done < <(git log --format=%s "$start_commit".."$end_commit")
echo "$is_breaking_change"
}
parse_commits "$@"