chore(ci): update script to generate Artifacthub annotations
This commit is contained in:
parent
dff777e6de
commit
975eaa0d5d
@ -4,13 +4,12 @@ set -e
|
|||||||
|
|
||||||
CHART_FILE="Chart.yaml"
|
CHART_FILE="Chart.yaml"
|
||||||
if [ ! -f "${CHART_FILE}" ]; then
|
if [ ! -f "${CHART_FILE}" ]; then
|
||||||
echo "ERROR: ${CHART_FILE} not found!"
|
echo "ERROR: ${CHART_FILE} not found!" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
DEFAULT_NEW_TAG="$(git tag --sort=-version:refname | head -n 1)"
|
||||||
DEFAULT_NEW_TAG="$(git describe --abbrev=0)"
|
DEFAULT_OLD_TAG="$(git tag --sort=-version:refname | head -n 2 | tail -n 1)"
|
||||||
DEFAULT_OLD_TAG="$(git describe --abbrev=0 --tags "$(git rev-list --tags --skip=1 --max-count=1)")"
|
|
||||||
|
|
||||||
if [ -z "${1}" ]; then
|
if [ -z "${1}" ]; then
|
||||||
read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG
|
read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG
|
||||||
@ -19,7 +18,7 @@ if [ -z "${1}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
while [ -z "$(git tag --list "${OLD_TAG}")" ]; do
|
while [ -z "$(git tag --list "${OLD_TAG}")" ]; do
|
||||||
echo "ERROR: Tag '${OLD_TAG}' not found!"
|
echo "ERROR: Tag '${OLD_TAG}' not found!" 1>&2
|
||||||
read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG
|
read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG
|
||||||
if [ -z "${OLD_TAG}" ]; then
|
if [ -z "${OLD_TAG}" ]; then
|
||||||
OLD_TAG="${DEFAULT_OLD_TAG}"
|
OLD_TAG="${DEFAULT_OLD_TAG}"
|
||||||
@ -28,29 +27,29 @@ if [ -z "${1}" ]; then
|
|||||||
else
|
else
|
||||||
OLD_TAG=${1}
|
OLD_TAG=${1}
|
||||||
if [ -z "$(git tag --list "${OLD_TAG}")" ]; then
|
if [ -z "$(git tag --list "${OLD_TAG}")" ]; then
|
||||||
echo "ERROR: Tag '${OLD_TAG}' not found!"
|
echo "ERROR: Tag '${OLD_TAG}' not found!" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "${1}" ]; then
|
if [ -z "${2}" ]; then
|
||||||
read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG
|
read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG
|
||||||
if [ -z "${NEW_TAG}" ]; then
|
if [ -z "${NEW_TAG}" ]; then
|
||||||
NEW_TAG="${DEFAULT_NEW_TAG}"
|
NEW_TAG="${DEFAULT_NEW_TAG}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
while [ -z "$(git tag --list "${NEW_TAG}")" ]; do
|
while [ -z "$(git tag --list "${NEW_TAG}")" ]; do
|
||||||
echo "ERROR: Tag '${NEW_TAG}' not found!"
|
echo "ERROR: Tag '${NEW_TAG}' not found!" 1>&2
|
||||||
read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG
|
read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG
|
||||||
if [ -z "${NEW_TAG}" ]; then
|
if [ -z "${NEW_TAG}" ]; then
|
||||||
NEW_TAG="${DEFAULT_NEW_TAG}"
|
NEW_TAG="${DEFAULT_NEW_TAG}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
else
|
else
|
||||||
NEW_TAG=${1}
|
NEW_TAG=${2}
|
||||||
|
|
||||||
if [ -z "$(git tag --list "${NEW_TAG}")" ]; then
|
if [ -z "$(git tag --list "${NEW_TAG}")" ]; then
|
||||||
echo "ERROR: Tag '${NEW_TAG}' not found!"
|
echo "ERROR: Tag '${NEW_TAG}' not found!" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -80,7 +79,9 @@ function map_type_to_kind() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMIT_TITLES=$(git log "${OLD_TAG}..${NEW_TAG}" --pretty=format:"%s")
|
COMMIT_TITLES="$(git log --pretty=format:"%s" "${OLD_TAG}..${NEW_TAG}")"
|
||||||
|
|
||||||
|
echo "INFO: Generate change log entries from ${OLD_TAG} until ${NEW_TAG}"
|
||||||
|
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
if [[ "${line}" =~ ^([a-zA-Z]+)(\([^\)]+\))?\:\ (.+)$ ]]; then
|
if [[ "${line}" =~ ^([a-zA-Z]+)(\([^\)]+\))?\:\ (.+)$ ]]; then
|
||||||
@ -93,11 +94,17 @@ while IFS= read -r line; do
|
|||||||
DESC="${BASH_REMATCH[3]}"
|
DESC="${BASH_REMATCH[3]}"
|
||||||
KIND=$(map_type_to_kind "${TYPE}")
|
KIND=$(map_type_to_kind "${TYPE}")
|
||||||
|
|
||||||
|
echo "- ${KIND}: ${DESC}"
|
||||||
|
|
||||||
yq --inplace ". += [ {\"kind\": \"${KIND}\", \"description\": \"${DESC}\"}]" "${YAML_FILE}"
|
yq --inplace ". += [ {\"kind\": \"${KIND}\", \"description\": \"${DESC}\"}]" "${YAML_FILE}"
|
||||||
fi
|
fi
|
||||||
done <<< "${COMMIT_TITLES}"
|
done <<< "${COMMIT_TITLES}"
|
||||||
|
|
||||||
yq --no-colors --inplace ".annotations.\"artifacthub.io/changes\" |= loadstr(\"${YAML_FILE}\") | sort_keys(.)" "${CHART_FILE}"
|
if [ -s "${YAML_FILE}" ]; then
|
||||||
yq --no-colors --inplace ".version = \"${NEW_TAG}\"" "${CHART_FILE}"
|
yq --no-colors --inplace ".annotations.\"artifacthub.io/changes\" |= loadstr(\"${YAML_FILE}\") | sort_keys(.)" "${CHART_FILE}"
|
||||||
|
else
|
||||||
|
echo "ERROR: Changelog file is empty: ${YAML_FILE}" 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
rm "${YAML_FILE}"
|
rm "${YAML_FILE}"
|
||||||
|
@ -15,15 +15,16 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
apk update
|
apk update
|
||||||
apk add git npm yq
|
apk add git npm yq
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Add Artifacthub.io annotations
|
- name: Add Artifacthub.io annotations
|
||||||
run: |
|
run: |
|
||||||
NEW_TAG="$(git describe --abbrev=0)"
|
NEW_TAG="$(git tag --sort=-version:refname | head -n 1)"
|
||||||
OLD_TAG="$(git describe --abbrev=0 --tags "$(git rev-list --tags --skip=1 --max-count=1)")"
|
OLD_TAG="$(git tag --sort=-version:refname | head -n 2 | tail -n 1)"
|
||||||
.gitea/scripts/add-annotations.sh "${NEW_TAG}" "${OLD_TAG}"
|
.gitea/scripts/add-annotations.sh "${OLD_TAG}" "${NEW_TAG}"
|
||||||
|
|
||||||
- name: Package chart
|
- name: Package chart
|
||||||
env:
|
env:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user