-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathsoftware-release.sh
executable file
·74 lines (58 loc) · 2.11 KB
/
software-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
#!/bin/sh
# Author : Abayomi Mosaku
# Copyright (c) ebi.ac.uk
# Ensure all branches ready for release are merged into dev branch
DEV_BRANCH='dev'
MASTER_BRANCH='master'
DOCUMENTATION_BRANCH='documentation'
echo "What is the new version number ?"
read VERSION_NUMBER
echo "Initializing Software Release for version $VERSION_NUMBER"
# Check out documentation, merge documentation branch back into dev branch.
git checkout $DOCUMENTATION_BRANCH
git pull origin $DOCUMENTATION_BRANCH
# switch to dev branch, pull changes from remote dev branch, integrate contents of documentation branch to dev branch
git checkout $DEV_BRANCH
git pull origin $DEV_BRANCH
git merge $DOCUMENTATION_BRANCH
git push origin $DEV_BRANCH
# switch to master branch, pull changes from remote master branch, integrate contents of dev branch with master branch
git checkout $MASTER_BRANCH
git pull origin $MASTER_BRANCH
git merge $DEV_BRANCH
# compile to ensure evrything is still as expected
if mvn clean compile; then
echo "compilation was successful"
else
echo "compilation failed"
exit;
fi
# Create a new temporary branch for release
git checkout -b release-branch
# run the version number upgrade script
./update-version.sh -v $VERSION_NUMBER
# Ensure everything still builds
if mvn clean compile; then
echo "compilation was successful after version number update"
else
echo "compilation failed after version number update"
exit;
fi
git commit -a -m "$VERSION_NUMBER: Release done"
# CREATE A NEW TAG AND PUSH TO REMOTE MASTER.
git tag -a $VERSION_NUMBER -m "$VERSION_NUMBER tag"
git push origin --tags $MASTER_BRANCH
# Check out documentation , merge the release branch back into documentation.
git checkout $DOCUMENTATION_BRANCH
git merge release-branch
git push origin $DOCUMENTATION_BRANCH
# Check out dev , merge the documentation branch back into dev.
git checkout $DEV_BRANCH
git merge $DOCUMENTATION_BRANCH
git push origin $DEV_BRANCH
# Check out master, Merge dev back to master
git checkout $MASTER_BRANCH
git merge $DEV_BRANCH
git push origin $MASTER_BRANCH
# then delete the unnecessary temporary branch
git branch -d release-branch