-
Notifications
You must be signed in to change notification settings - Fork 162
/
releaseNewVersion.sh
executable file
·116 lines (96 loc) · 4.27 KB
/
releaseNewVersion.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#!/usr/bin/env bash
# VARIABLES
read -r -d '' purposeMsg <<'EOF'
Releasing a new Auspice version
This script attempts to do 10 things. It will exit if any steps fail...
(1) checkout master & ensure it is up to date with github
(2) increment Version number (in `src/version.js` and `package.json`) by prompting the user
(3) add a title with the version number to the CHANGELOG
(4) commit to master
(5) checkout `release` branch from github (will fail if it exists locally)
(6) merge master -> release
(7) tag release with new version
(8) push release branch to github (this triggers GitHub Actions CI to build and publish to npm)
(9) checkout `master` and remove local `release` branch
(10) Create a GitHub Release
EOF
# FUNCTIONS:
function errorFound {
echo -e "\nScript Failed at step $step (Line $1)\nYou are responsible for clean up (sorry!)"
exit 2
}
# TRAPS
trap 'errorFound $LINENO' ERR
# MAIN
echo "$purposeMsg"
echo -e "\n"
# exit if release branch exists locally
if git rev-parse --verify --quiet release
then
echo "release branch already exists locally - fatal"
exit 2
fi
# exit early if user is not authenticated with the GitHub CLI (or doesn't have it)
gh auth status
# step 1: check master is up to date with github
step="1"
git diff-index --quiet HEAD -- # $? = 1 if uncommited changes
git checkout master
git fetch origin
git status -uno | grep "up-to-date\|up to date" # $? = 1 if not up-to-date OR up to date
git diff-index --quiet HEAD -- # $? = 1 if uncommited changes
# step 2: increment version number (req user input)
step="2"
packagesVersion=$(grep "\"version\":" package.json | perl -pe 's/.*([0-9]+.[0-9]+.[0-9]+).*/\1/')
srcVersion=$(grep "const version" src/version.js | perl -pe 's/.*([0-9]+.[0-9]+.[0-9]+).*/\1/')
if [ ${packagesVersion} != ${srcVersion} ]
then
echo "packages.json version (${packagesVersion}) doesn't match version.js version (${srcVersion}). Fatal."
exit 2
fi
parts=(${srcVersion//./ }) # magic
bumps=($((${parts[0]}+1)) $((${parts[1]}+1)) $((${parts[2]}+1)))
echo -e "\nCurrent version: ${srcVersion}. Is this a major new release (${bumps[0]}.0.0), a feature release (${parts[0]}.${bumps[1]}.0) or a minor fix (${parts[0]}.${parts[1]}.${bumps[2]})?\n"
select yn in "major-new-release" "feature-release" "minor-fix"; do
case $yn in
major-new-release ) msg="major new release"; newVersion="${bumps[0]}.0.0"; break;;
feature-release ) msg="feature release"; newVersion="${parts[0]}.${bumps[1]}.0"; break;;
minor-fix ) msg="minor fix"; newVersion="${parts[0]}.${parts[1]}.${bumps[2]}"; break;;
esac
done
echo -e "\n"
# now replace the version in NPM files and version.js (inplace!)
npm version "${newVersion}" --no-git-tag-version
perl -pi -e "s/version = \"${srcVersion}\";/version = \"${newVersion}\";/" src/version.js
unset packagesVersion srcVersion parts bumps yn
# step 3: add h2 title to CHANGELOG.md with newVersion & date, while preserving the h1 title
today=$(date +'%Y/%m/%d')
echo -e "# Changelog\n\n## version ${newVersion} - ${today}\n\n$(tail -n +2 CHANGELOG.md)" > CHANGELOG.md
unset today
# step 4: commit to current branch (master) & push to github (origin)
step="4"
git add .
git commit -m "version bump to ${newVersion} for release"
git push origin master # push master, with the updated version number...
echo -e "Master successfully updated and pushed to github"
# step 5: checkout release branch from github
step="5"
git checkout -b release origin/release
# step 6: merge master into release
step="6"
git merge --ff-only master
# # step 7: tag
step="7"
git tag -a v${newVersion} -m "${msg}"
# step 8: push to github, including the tag
step="8"
git push --follow-tags origin release
# step 9: go back to master & delete release branch (locally)
step="9"
git checkout master
git branch -d release
echo -e "\n$msg (version ${newVersion}) pushed to github:release and github:master"
echo -e "\nThe 'CI' GitHub Action will automatically publish this version to npm"
echo -e "\nNow attempting to make a GitHub release (https://github.com/nextstrain/auspice/releases). If this step fails please do this manually."
# Step 10: create a release based off the tag with content from the changlog
node scripts/extract-release-notes.js | gh release create v${newVersion} --repo nextstrain/auspice -t "Auspice ${newVersion}" --notes-file -