-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrelease.sh
executable file
·56 lines (43 loc) · 1.79 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
55
#!/bin/bash
master="master"
develop="develop"
master_latest=$(git ls-remote origin $master | awk '{ print $1 }')
develop_latest=$(git ls-remote origin $develop | awk '{ print $1 }')
local_master_latest=$(git rev-parse $master)
local_develop_latest=$(git rev-parse $develop)
current_branch=$(git branch --show-current)
if [ "$master_latest" != "$develop_latest" ]; then
echo "ERROR: remote $master's latest commit $master_latest differs from remote $develop's $develop_latest."
exit 1
fi
if [ "$master_latest" != "$local_master_latest" ]; then
echo "ERROR: local $master's latest commit $local_master_latest differs from remote $master's $master_latest."
exit 1
fi
if [ "$develop_latest" != "$local_develop_latest" ]; then
echo "ERROR: local $develop's latest commit $local_develop_latest differs from remote $develop's $develop_latest."
exit 1
fi
if [ "$current_branch" != "$develop" ]; then
echo "ERROR: you must release from $develop, you're currently on $current_branch"
exit 1
fi
npm run release
develop_after_release_local=$(git rev-parse HEAD)
if [ "$develop_latest" = "$develop_after_release_local" ]; then
echo "ERROR: after the release there is no new commits. Are you sure the release went fine? Please commit your release changes, push it to $develop and ff merge back the release commit to $master"
exit 1
fi
develop_after_release_remote=$(git ls-remote origin $develop | awk '{ print $1 }')
if [ "$develop_after_release_local" != "$develop_after_release_remote" ]; then
echo "Somewhy npm was not pushed the release commit to remote. Would you like to push it now?"
select yn in "Yes" "No"; do
case $yn in
Yes ) git push; break;;
No ) exit;;
esac
done
fi
git checkout $master
git pull --ff-only origin $develop
git push