Files
typescript-action/script/release
T

134 lines
4.7 KiB
Bash
Raw Normal View History

2023-10-31 17:50:45 -06:00
#!/bin/bash
2024-07-01 02:39:31 +01:00
# Exit early
# See: https://www.gnu.org/savannah-checkouts/gnu/bash/manual/bash.html#The-Set-Builtin
set -e
2023-10-31 17:52:55 -06:00
# About:
2024-02-01 10:23:43 -05:00
#
# This is a helper script to tag and push a new release. GitHub Actions use
# release tags to allow users to select a specific version of the action to use.
#
# See: https://github.com/actions/typescript-action#publishing-a-new-release
# See: https://github.com/actions/toolkit/blob/master/docs/action-versioning.md#recommendations
2024-02-01 10:23:43 -05:00
#
2023-10-31 17:52:55 -06:00
# This script will do the following:
2024-02-01 10:23:43 -05:00
#
2024-07-01 04:33:03 +01:00
# 1. Retrieve the latest release tag
# 2. Display the latest release tag
# 3. Prompt the user for a new release tag
# 4. Validate the new release tag
# 5. Remind user to update the version field in package.json
# 6. Tag a new release
# 7. Set 'is_major_release' variable
# 8. Point separate major release tag (e.g. v1, v2) to the new release
# 9. Push the new tags (with commits, if any) to remote
2024-07-01 17:21:55 +01:00
# 10. If this is a major release, create a 'releases/v#' branch and push
2024-02-01 10:23:43 -05:00
#
2023-10-31 17:50:45 -06:00
# Usage:
2024-02-01 10:23:43 -05:00
#
2023-10-31 17:50:45 -06:00
# script/release
2024-07-01 02:17:03 +01:00
# Variables
2024-07-01 17:21:55 +01:00
semver_tag_regex='v[0-9]+\.[0-9]+\.[0-9]+$'
semver_tag_glob='v[0-9].[0-9].[0-9]*'
git_remote='origin'
2024-07-01 17:21:55 +01:00
major_semver_tag_regex='\(v[0-9]*\)'
2024-07-01 02:17:03 +01:00
2024-02-01 10:23:43 -05:00
# Terminal colors
2023-10-31 17:50:45 -06:00
OFF='\033[0m'
2024-07-01 02:42:58 +01:00
BOLD_RED='\033[1;31m'
BOLD_GREEN='\033[1;32m'
BOLD_BLUE='\033[1;34m'
BOLD_PURPLE='\033[1;35m'
BOLD_UNDERLINED='\033[1;4m'
2024-07-01 03:22:26 +01:00
BOLD='\033[1m'
2023-10-31 17:50:45 -06:00
2024-07-01 04:33:03 +01:00
# 1. Retrieve the latest release tag
2024-07-01 17:21:55 +01:00
if ! latest_tag=$(git describe --abbrev=0 --match="$semver_tag_glob"); then
2024-02-22 09:47:59 -05:00
# There are no existing release tags
echo -e "No tags found (yet) - Continue to create and push your first tag"
latest_tag="[unknown]"
2023-10-31 17:55:51 -06:00
fi
2024-07-01 04:33:03 +01:00
# 2. Display the latest release tag
2024-07-01 02:42:58 +01:00
echo -e "The latest release tag is: ${BOLD_BLUE}${latest_tag}${OFF}"
2023-10-31 18:15:24 -06:00
2024-07-01 04:33:03 +01:00
# 3. Prompt the user for a new release tag
2024-02-01 10:23:43 -05:00
read -r -p 'Enter a new release tag (vX.X.X format): ' new_tag
2024-07-01 04:33:03 +01:00
# 4. Validate the new release tag
2024-07-01 17:21:55 +01:00
if echo "$new_tag" | grep -q -E "$semver_tag_regex"; then
2024-07-01 03:22:26 +01:00
# Release tag is valid
echo -e "Tag: ${BOLD_BLUE}$new_tag${OFF} is valid syntax"
2023-10-31 18:15:24 -06:00
else
2024-07-01 03:48:57 +01:00
# Release tag is not in `vX.X.X` format
2024-07-01 03:22:26 +01:00
echo -e "Tag: ${BOLD_BLUE}$new_tag${OFF} is ${BOLD_RED}not valid${OFF} (must be in ${BOLD}vX.X.X${OFF} format)"
2024-02-22 09:47:59 -05:00
exit 1
2023-10-31 17:50:45 -06:00
fi
2024-07-01 04:33:03 +01:00
# 5. Remind user to update the version field in package.json
echo -e -n "Make sure the version field in package.json is ${BOLD_BLUE}$new_tag${OFF}. Yes? [Y/${BOLD_UNDERLINED}n${OFF}] "
read -r YN
if [[ ! ($YN == "y" || $YN == "Y") ]]; then
# Package.json version field is not up to date
echo -e "Please update the package.json version to ${BOLD_PURPLE}$new_tag${OFF} and commit your changes"
exit 1
fi
2024-07-01 04:33:03 +01:00
# 6. Tag a new release
2024-07-01 03:25:01 +01:00
git tag "$new_tag" --annotate --message "$new_tag Release"
2024-07-01 03:22:26 +01:00
echo -e "Tagged: ${BOLD_GREEN}$new_tag${OFF}"
2023-10-31 17:50:45 -06:00
2024-07-01 04:33:03 +01:00
# 7. Set 'is_major_release' variable
2024-07-01 17:21:55 +01:00
new_major_release_tag=$(expr "$new_tag" : "$major_semver_tag_regex")
2025-01-10 10:28:32 -05:00
if [[ "$latest_tag" = "[unknown]" ]]; then
# This is the first major release
is_major_release='yes'
else
2025-01-10 10:28:32 -05:00
# Compare the major version of the latest tag with the new tag
latest_major_release_tag=$(expr "$latest_tag" : "$major_semver_tag_regex")
if ! [[ "$new_major_release_tag" = "$latest_major_release_tag" ]]; then
is_major_release='yes'
else
is_major_release='no'
fi
fi
2024-07-01 04:33:03 +01:00
# 8. Point separate major release tag (e.g. v1, v2) to the new release
if [ $is_major_release = 'yes' ]; then
2024-12-30 10:53:51 +09:00
# Create a new major version tag and point it to this release
2024-07-01 17:21:55 +01:00
git tag "$new_major_release_tag" --annotate --message "$new_major_release_tag Release"
echo -e "New major version tag: ${BOLD_GREEN}$new_major_release_tag${OFF}"
else
2024-12-30 10:53:51 +09:00
# Update the major version tag to point it to this release
2024-07-01 17:21:55 +01:00
git tag "$latest_major_release_tag" --force --annotate --message "Sync $latest_major_release_tag tag with $new_tag"
echo -e "Synced ${BOLD_GREEN}$latest_major_release_tag${OFF} with ${BOLD_GREEN}$new_tag${OFF}"
fi
2024-07-01 04:33:03 +01:00
# 9. Push the new tags (with commits, if any) to remote
git push --follow-tags
if [ $is_major_release = 'yes' ]; then
# New major version tag is pushed with the '--follow-tags' flags
2024-07-01 17:21:55 +01:00
echo -e "Tags: ${BOLD_GREEN}$new_major_release_tag${OFF} and ${BOLD_GREEN}$new_tag${OFF} pushed to remote"
else
# Force push the updated major version tag
2024-07-01 17:21:55 +01:00
git push $git_remote "$latest_major_release_tag" --force
echo -e "Tags: ${BOLD_GREEN}$latest_major_release_tag${OFF} and ${BOLD_GREEN}$new_tag${OFF} pushed to remote"
fi
2024-07-01 17:21:55 +01:00
# 10. If this is a major release, create a 'releases/v#' branch and push
if [ $is_major_release = 'yes' ]; then
2025-01-10 10:28:32 -05:00
git branch "releases/$new_major_release_tag" "$new_major_release_tag"
echo -e "Branch: ${BOLD_BLUE}releases/$new_major_release_tag${OFF} created from ${BOLD_BLUE}$new_major_release_tag${OFF} tag"
git push --set-upstream $git_remote "releases/$new_major_release_tag"
echo -e "Branch: ${BOLD_GREEN}releases/$new_major_release_tag${OFF} pushed to remote"
fi
# Completed
2024-07-01 02:42:58 +01:00
echo -e "${BOLD_GREEN}Done!${OFF}"