forked from gratipay/gratipay.com
-
Notifications
You must be signed in to change notification settings - Fork 0
/
deploy.sh
executable file
·120 lines (89 loc) · 2.83 KB
/
deploy.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
#!/bin/sh
# Fail on error
set -e
# Be somewhere predictable
cd "`dirname $0`"
# Helpers
yesno () {
proceed=""
while [ "$proceed" != "y" ]; do
read -p"$1 (y/n) " proceed
[ "$proceed" = "n" ] && return 1
done
return 0
}
require () {
if [ ! `which $1` ]; then
echo "The '$1' command was not found."
exit 1
fi
}
# Check that we have the required tools
require heroku
require git
require curl
# Make sure we have the latest master
if [ "`git rev-parse --abbrev-ref HEAD`" != "master" ]; then
echo "Not on master, checkout master first."
exit
fi
git pull
# Compute the next version number
prev="$(git describe --tags --match '[0-9]*' | cut -d- -f1 | sed 's/\.//g')"
version="$((prev + 1))"
# Check that the environment contains all required variables
heroku config -s -a gratipay | ./env/bin/honcho run -e /dev/stdin \
./env/bin/python gratipay/wireup.py
# Sync the translations
echo "Syncing translations ..."
if [ ! -e .transifexrc -a ! -e ~/.transifexrc ]; then
heroku config -s -a gratipay | ./env/bin/honcho run -e /dev/stdin make transifexrc
fi
make i18n_upload
make i18n_download
git add i18n
if git commit --dry-run &>/dev/null; then git commit -m "update i18n files"; fi
# Check for a branch.sql
if [ -e sql/branch.sql ]; then
# Merge branch.sql into schema.sql
git rm --cached sql/branch.sql
echo | cat sql/branch.sql >>sql/schema.sql
echo "sql/branch.sql has been appended to sql/schema.sql"
read -p "Please make the necessary manual modifications to schema.sql now, then press Enter to continue... " enter
git add sql/schema.sql
git commit -m "merge branch.sql into schema.sql"
# Deployment options
if yesno "Should branch.sql be applied before deploying to Heroku instead of after?"; then
run_sql="before"
if yesno "Should the maintenance mode be turned on during deployment?"; then
maintenance="yes"
fi
else
run_sql="after"
fi
fi
# Ask confirmation and bump the version
yesno "Tag and deploy version $version?" || exit
echo $version >www/version.txt
git commit www/version.txt -m "Bump version to $version"
git tag $version
# Deploy to Heroku
[ "$maintenance" = "yes" ] && heroku maintenance:on -a gratipay
[ "$run_sql" = "before" ] && heroku pg:psql -a gratipay <sql/branch.sql
git push --force heroku master
[ "$maintenance" = "yes" ] && heroku maintenance:off -a gratipay
[ "$run_sql" = "after" ] && heroku pg:psql -a gratipay <sql/branch.sql
rm -f sql/branch.sql
# Push to GitHub
git push
git push --tags
# Check for schema drift
if [[ $run_sql ]]; then
if ! make schema-diff; then
echo "schema.sql doesn't match the production DB, please fix it"
exit 1
fi
fi
# Provide visual confirmation of deployment.
echo "Checking version.txt ..."
curl https://gratipay.com/version.txt