feat(release-notes-assistant): if no labels, fallback to prefix

* support feat: fix: feat!: fix! conventional commits prefixes
* add unit tests
This commit is contained in:
Twenty Panda 2024-07-23 16:45:44 +02:00
parent 14d079a1eb
commit db64236f85
3 changed files with 227 additions and 54 deletions

View file

@ -19,6 +19,7 @@ jobs:
- uses: https://code.forgejo.org/actions/setup-go@v4 - uses: https://code.forgejo.org/actions/setup-go@v4
with: with:
go-version-file: "go.mod" go-version-file: "go.mod"
cache: false
- name: apt install jq - name: apt install jq
run: | run: |

View file

@ -75,6 +75,10 @@ jobs:
apt-get -q install -qq -y git apt-get -q install -qq -y git
rm /etc/apt/sources.list.d/testing.list rm /etc/apt/sources.list.d/testing.list
apt-get update -qq apt-get update -qq
- name: test release-notes-assistant.sh
run: |
apt-get -q install -qq -y jq
./release-notes-assistant.sh test_main
- run: | - run: |
su forgejo -c 'make deps-backend' su forgejo -c 'make deps-backend'
- run: | - run: |

View file

@ -2,72 +2,240 @@
# Copyright twenty-panda <twenty-panda@posteo.com> # Copyright twenty-panda <twenty-panda@posteo.com>
# SPDX-License-Identifier: MIT # SPDX-License-Identifier: MIT
label_worth=worth
label_bug=bug
label_feature=feature
label_ui=forgejo/ui
label_breaking=breaking
payload=$(mktemp) payload=$(mktemp)
pr=$(mktemp) pr=$(mktemp)
trap "rm $payload $pr" EXIT trap "rm $payload $pr" EXIT
cat >$payload function test_main() {
# set -ex
# If this is a backport, refer to the original PR to figure PS4='${BASH_SOURCE[0]}:$LINENO: ${FUNCNAME[0]}: '
# out the classification.
# test_payload_labels $label_worth $label_breaking $label_feature
if $(jq --raw-output .IsBackportedFrom <$payload); then test "$(categorize)" = 'AA Breaking features'
test_payload_labels $label_worth $label_breaking $label_bug
test "$(categorize)" = 'AB Breaking bug fixes'
test_payload_labels $label_worth $label_breaking
test "$(categorize)" = 'ZC Breaking changes without a feature or bug label'
test_payload_labels $label_worth $label_ui $label_feature
test "$(categorize)" = 'BA User Interface features'
test_payload_labels $label_worth $label_ui $label_bug
test "$(categorize)" = 'BB User Interface bug fixes'
test_payload_labels $label_worth $label_ui
test "$(categorize)" = 'ZD User Interface changes without a feature or bug label'
test_payload_labels $label_worth $label_feature
test "$(categorize)" = 'CA Features'
test_payload_labels $label_worth $label_bug
test "$(categorize)" = 'CB Bug fixes'
test_payload_labels $label_worth
test "$(categorize)" = 'ZE Other changes without a feature or bug label'
test_payload_labels
test "$(categorize)" = 'ZF Included for completness but not worth a release note'
test_payload_draft "feat!: breaking feature"
test "$(categorize)" = 'AA Breaking features'
test_payload_draft "fix!: breaking bug fix"
test "$(categorize)" = 'AB Breaking bug fixes'
test_payload_draft "feat: feature"
test "$(categorize)" = 'CA Features'
test_payload_draft "fix: bug fix"
test "$(categorize)" = 'CB Bug fixes'
test_payload_draft "something with no prefix"
test "$(categorize)" = 'ZE Other changes without a feature or bug label'
}
function main() {
cat >$payload
categorize
}
function categorize() {
#
# If this is a backport, refer to the original PR to figure
# out the classification.
#
if $(jq --raw-output .IsBackportedFrom <$payload); then
jq --raw-output '.BackportedFrom[0]' <$payload >$pr jq --raw-output '.BackportedFrom[0]' <$payload >$pr
else else
jq --raw-output '.Pr' <$payload >$pr jq --raw-output '.Pr' <$payload >$pr
fi fi
labels=$(jq --raw-output '.labels[].name' <$pr) labels=$(jq --raw-output '.labels[].name' <$pr)
# #
# Was this PR labeled `worth a release note`? # Was this PR labeled `worth a release note`?
# #
if echo "$labels" | grep --quiet worth; then if echo "$labels" | grep --quiet $label_worth; then
worth=true worth=true
else else
worth=false worth=false
fi fi
# #
# If there was no release-notes/N.md file and it is not # If there was no release-notes/N.md file and it is not
# worth a release note, just forget about it. # worth a release note, just forget about it.
# #
if test -z "$(jq --raw-output .Draft <$payload)"; then if test -z "$(jq --raw-output .Draft <$payload)"; then
if ! $worth; then if ! $worth; then
echo -n ZA Included for completness but not worth a release note echo -n ZF Included for completness but not worth a release note
exit 0 exit 0
fi fi
fi fi
case "$labels" in is_ui=false
*bug*) is_bug=false
is_feature=false
is_breaking=false
#
# first try to figure out the category from the labels
#
case "$labels" in
*$label_bug*)
is_bug=true
;;
*$label_feature*)
is_feature=true
;;
esac
case "$labels" in
*$label_breaking*)
is_breaking=true
;;
esac
case "$labels" in
*$label_ui*)
is_ui=true
;;
esac
#
# then try the prefix of the release note
#
if ! $is_bug && ! $is_feature; then
draft="$(jq --raw-output .Draft <$payload)"
case "$draft" in
fix!:*)
is_bug=true
is_breaking=true
;;
fix:*)
is_bug=true
;;
feat!:*)
is_feature=true
is_breaking=true
;;
feat:*)
is_feature=true
;;
esac
fi
if $is_bug; then
if $(jq --raw-output .IsBackportedTo <$payload); then if $(jq --raw-output .IsBackportedTo <$payload); then
# #
# if it has been backported, it was in the release notes of an older stable release # if it has been backported, it was in the release notes of an older stable release
# and does not need to be in this more recent release notes # and does not need to be in this more recent release notes
# #
echo -n ZB Already announced in the release notes of an older stable release echo -n ZG Already announced in the release notes of an older stable release
exit 0 exit 0
fi fi
;; fi
esac
case "$labels" in if $is_breaking; then
*breaking*) if $is_feature; then
case "$labels" in echo -n AA Breaking features
*feature*) echo -n AA Breaking features ;; elif $is_bug; then
*bug*) echo -n AB Breaking bug fixes ;; echo AB Breaking bug fixes
*) echo -n ZC Breaking changes without a feature or bug label ;; else
esac echo -n ZC Breaking changes without a feature or bug label
;; fi
*forgejo/ui*) elif $is_ui; then
case "$labels" in if $is_feature; then
*feature*) echo -n BA User Interface features ;; echo -n BA User Interface features
*bug*) echo -n BB User Interface bug fixes ;; elif $is_bug; then
*) echo -n ZD User Interface changes without a feature or bug label ;; echo -n BB User Interface bug fixes
esac else
;; echo -n ZD User Interface changes without a feature or bug label
*feature*) echo -n CA Features ;; fi
*bug*) echo -n CB Bug fixes ;; else
*) echo -n ZE Other changes without a feature or bug label ;; if $is_feature; then
esac echo -n CA Features
elif $is_bug; then
echo -n CB Bug fixes
else
echo -n ZE Other changes without a feature or bug label
fi
fi
}
function test_payload_labels() {
local label1="$1"
local label2="$2"
local label3="$3"
local label4="$4"
cat >$payload <<EOF
{
"Pr": {
"labels": [
{
"name": "$label1"
},
{
"name": "$label2"
},
{
"name": "$label3"
},
{
"name": "$label4"
}
]
},
"IsBackportedFrom": false,
"Draft": ""
}
EOF
}
function test_payload_draft() {
local draft="$1"
cat >$payload <<EOF
{
"Pr": {
"labels": [
{
"name": "$label_worth"
}
]
},
"IsBackportedFrom": false,
"Draft": "$draft"
}
EOF
}
"${@:-main}"