forked from eclipse-che/che
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmake-release.sh
executable file
·207 lines (172 loc) · 6.6 KB
/
make-release.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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
#!/bin/bash
# Copyright (c) 2021-2023 Red Hat, Inc.
# This program and the accompanying materials are made
# available under the terms of the Eclipse Public License 2.0
# which is available at https://www.eclipse.org/legal/epl-2.0/
#
# SPDX-License-Identifier: EPL-2.0
#
# Contributors:
# Red Hat, Inc. - initial API and implementation
#
set -e
REPO=git@github.com:eclipse-che/che-server
MAIN_BRANCH="main"
TMP=""
ISSUE_TEMPLATE_FILE=".github/ISSUE_TEMPLATE/bug_report.yml"
while [[ "$#" -gt 0 ]]; do
case $1 in
'-v'|'--version') VERSION="$2"; shift 1;;
'-tmp'|'--use-tmp-dir') TMP=$(mktemp -d); shift 0;;
esac
shift 1
done
sed_in_place() {
SHORT_UNAME=$(uname -s)
if [ "$(uname)" == "Darwin" ]; then
sed -i '' "$@"
elif [ "${SHORT_UNAME:0:5}" == "Linux" ]; then
sed -i "$@"
fi
}
# Update the issue template with released version and add current latest as previous item
update_issue_template() {
local -r currentReleaseVersion=$1
local -r templateFile=$2
# take only two first digits of the version that we will release
# will get 7.74 from input 7.74.0-next
local -r versionXY=$(echo "${currentReleaseVersion}" | sed -ne 's/[^0-9]*\(\([0-9]\.\)\{0,4\}[0-9][^.]\).*/\1/p')
# now extract the current latest version specified in the issue template
# for example extract 7.34 if there is - "7.34@latest" as available item
local -r latestVersionInIssueTemplate=$(sed -n 's/.*- "\(.*\)@latest"/\1/p' "${templateFile}")
# if version to tag is not already seen as latest, add VERSION_X_Y as new latest
if [ "${versionXY}" != "${latestVersionInIssueTemplate}" ]; then
# replace 7.34@latest for example by ${versionXY}@latest
sed_in_place "s/${latestVersionInIssueTemplate}@latest/${versionXY}@latest/" "${templateFile}"
fi
# Now check if we have the previous version in the template
# if not, need to add it
if ! grep -q "\"${versionXY}\"" "${templateFile}" ; then
# add the version just after the current next version
# really want \'$'\n'
# shellcheck disable=SC1003
sed_in_place -e '/- \"next (development version)\"/a\'$'\n'' - \"'"${latestVersionInIssueTemplate}"'\"' "${templateFile}"
fi
}
bump_version () {
CURRENT_BRANCH=$(git rev-parse --abbrev-ref HEAD)
NEXT_VERSION=$1
BUMP_BRANCH=$2
git checkout "${BUMP_BRANCH}"
echo "Updating project version to ${NEXT_VERSION}"
echo "${NEXT_VERSION}" > VERSION
pushd tests/e2e >/dev/null || exit
npm --no-git-tag-version version --allow-same-version "${NEXT_VERSION}"
# update devworkspace generator version only for bugfix releases (e.g. for 7.74.x branch, version would be next-7.74.x)
if [[ "${BASEBRANCH}" == "${BRANCH}" ]]; then
jq ".\"dependencies\".\"@eclipse-che/che-devworkspace-generator\" = \"next-${BRANCH}\"" package.json > package.json.update
mv package.json.update package.json
fi
npm run prettier
popd >/dev/null || exit
COMMIT_MSG="chore: Bump to ${NEXT_VERSION} in ${BUMP_BRANCH}"
git commit -asm "${COMMIT_MSG}"
git pull origin "${BUMP_BRANCH}"
set +e
PUSH_TRY="$(git push origin "${BUMP_BRANCH}")"
# shellcheck disable=SC2181
if [[ $? -gt 0 ]] || [[ $PUSH_TRY == *"protected branch hook declined"* ]]; then
PR_BRANCH=pr-${BUMP_BRANCH}-to-${NEXT_VERSION}
# create pull request for the main branch branch, as branch is restricted
git branch "${PR_BRANCH}"
git checkout "${PR_BRANCH}"
git pull origin "${PR_BRANCH}"
git push origin "${PR_BRANCH}"
lastCommitComment="$(git log -1 --pretty=%B)"
gh pr create -f -B "${BUMP_BRANCH}" -H "${PR_BRANCH}"
fi
set -e
git checkout "${CURRENT_BRANCH}"
}
usage ()
{
echo "Usage: $0 --version [VERSION TO RELEASE]"
echo -e "Example: $0 --version v0.1.0\n";
}
if [[ ! ${VERSION} ]]; then
usage
exit 1
fi
# derive bugfix branch from version
BRANCH=${VERSION#v}
BRANCH=${BRANCH%.*}.x
# if doing a .0 release, use main branch; if doing a .z release, use $BRANCH
if [[ ${VERSION} == *".0" ]]; then
BASEBRANCH="${MAIN_BRANCH}"
else
BASEBRANCH="${BRANCH}"
fi
# work in tmp dir
if [[ $TMP ]] && [[ -d $TMP ]]; then
pushd "$TMP" > /dev/null || exit 1
# get sources from ${BASEBRANCH} branch
echo "Check out ${REPO} to ${TMP}/${REPO##*/}"
git clone "${REPO}" -q
cd "${REPO##*/}" || exit 1
fi
git remote show origin
# get sources from ${BASEBRANCH} branch
git fetch origin "${BASEBRANCH}":"${BASEBRANCH}" || true
git checkout "${BASEBRANCH}"
# create new branch off ${BASEBRANCH} (or check out latest commits if branch already exists), then push to origin
if [[ "${BASEBRANCH}" != "${BRANCH}" ]]; then
git branch "${BRANCH}" || git checkout "${BRANCH}"
git push origin "${BRANCH}"
git fetch origin "${BRANCH}:${BRANCH}" || true
git checkout "${BRANCH}"
else
git fetch origin "${BRANCH}:${BRANCH}" || true
git checkout "${BRANCH}"
fi
set -e
# change VERSION file
echo "${VERSION}" > VERSION
pushd tests/e2e >/dev/null || exit
# update devworkspace generator version
jq ".\"dependencies\".\"@eclipse-che/che-devworkspace-generator\" = \"${VERSION}\"" package.json > package.json.update
mv package.json.update package.json
npm i -g prettier
npm --no-git-tag-version version --allow-same-version "${VERSION}"
npm run prettier
popd >/dev/null || exit
docker build -t quay.io/eclipse/che-e2e:${VERSION} -f tests/e2e/build/dockerfiles/Dockerfile tests/e2e
docker tag quay.io/eclipse/che-e2e:${VERSION} quay.io/eclipse/che-e2e:latest
docker push quay.io/eclipse/che-e2e:${VERSION}
docker push quay.io/eclipse/che-e2e:latest
# update template in the release tag
update_issue_template "${VERSION}" "${ISSUE_TEMPLATE_FILE}"
COMMIT_MSG="chore: Release ${VERSION}"
git commit -asm "${COMMIT_MSG}"
# tag the release
git tag "${VERSION}"
git push origin "${VERSION}"
# now update ${BASEBRANCH} to the new next version
git checkout "${BASEBRANCH}"
# update template in the branch
update_issue_template "${VERSION}" "${ISSUE_TEMPLATE_FILE}"
# change VERSION file + commit change into ${BASEBRANCH} branch
if [[ "${BASEBRANCH}" != "${BRANCH}" ]]; then
# bump the y digit, if it is a major release
[[ $BRANCH =~ ^([0-9]+)\.([0-9]+)\.x ]] && BASE=${BASH_REMATCH[1]}; NEXT=${BASH_REMATCH[2]}; (( NEXT=NEXT+1 )) # for BRANCH=0.1.x, get BASE=0, NEXT=2
NEXT_VERSION_Y="${BASE}.${NEXT}.0-next"
bump_version "${NEXT_VERSION_Y}" "${BASEBRANCH}"
fi
# bump the z digit
[[ ${VERSION#v} =~ ^([0-9]+)\.([0-9]+)\.([0-9]+) ]] && BASE="${BASH_REMATCH[1]}.${BASH_REMATCH[2]}"; NEXT="${BASH_REMATCH[3]}"; (( NEXT=NEXT+1 )) # for VERSION=0.1.2, get BASE=0.1, NEXT=3
NEXT_VERSION_Z="${BASE}.${NEXT}-next"
bump_version "${NEXT_VERSION_Z}" "${BRANCH}"
# cleanup tmp dir
if [[ $TMP ]] && [[ -d $TMP ]]; then
popd > /dev/null || exit
rm -fr "$TMP"
fi