forked from sapporo-wes/sapporo-service
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrelease.sh
54 lines (40 loc) · 1.33 KB
/
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
#!/usr/bin/env bash
set -euxo pipefail
if [[ $# -lt 1 ]]; then
echo "Usage: $0 <new_version>"
exit 1
fi
PREV_VERSION=$(git describe --abbrev=0 --tags)
NEW_VERSION=$1
read -p "Does update version from $PREV_VERSION to $NEW_VERSION? (y/n) :" YN
if [[ "$YN" != "y" ]]; then
echo "Aborted."
exit 1
fi
NOW_BRANCH=$(git rev-parse --abbrev-ref HEAD)
if [[ "$NOW_BRANCH" != "main" ]]; then
echo "You must be on main branch."
git checkout main
fi
echo "Merge develop branch to main branch."
git merge develop
echo "Rewrite files."
sed -i "s/version=\"$PREV_VERSION\"/version=\"$NEW_VERSION\"/g" Dockerfile
sed -i "s/sapporo-service:$PREV_VERSION/sapporo-service:$NEW_VERSION/g" docker-compose.yml
sed -i "s/\"sapporo-version\": \"$PREV_VERSION\"/\"sapporo-version\": \"$NEW_VERSION\"/g" sapporo/service-info.json
sed -i "s/version=\"$PREV_VERSION\"/version=\"$NEW_VERSION\"/g" setup.py
echo "Commit and push."
git add Dockerfile docker-compose.yml sapporo/service-info.json setup.py
git commit -m "Update version to $NEW_VERSION"
git push origin main
echo "Tag and push."
git tag $NEW_VERSION
git push origin $NEW_VERSION
echo "Merge main branch to develop branch."
git checkout develop
git merge main
git push origin develop
echo "Done."
echo "Summary of changes."
git log --oneline --pretty=tformat:"%h %s" "$PREV_VERSION..$NEW_VERSION"
exit 0