forked from wamp-proto/wamp-proto
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.travis-deploy.sh
executable file
·56 lines (42 loc) · 1.84 KB
/
.travis-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
#!/bin/bash
# build docs/website and upload to "wamp-proto.org" S3 bucket
export AWS_DEFAULT_REGION=eu-central-1
export AWS_S3_BUCKET_NAME=wamp-proto.org
export AWS_S3_BUCKET_PATH=
# AWS_ACCESS_KEY_ID : must be set in Travis CI build context
# AWS_SECRET_ACCESS_KEY : must be set in Travis CI build context
set -ev
# TRAVIS_BRANCH, TRAVIS_PULL_REQUEST, TRAVIS_TAG
# PR => don't deploy and exit
if [ "$TRAVIS_PULL_REQUEST" = "true" ]; then
echo '[1] deploy script called for PR - exiting ..';
exit 0;
# direct push to master => deploy
elif [ "$TRAVIS_BRANCH" = "master" -a "$TRAVIS_PULL_REQUEST" = "false" ]; then
echo '[2] deploy script called for direct push to master: continuing to deploy!';
# tagged release => deploy
elif [ -n "$TRAVIS_TAG" ]; then
echo '[3] deploy script called for tagged release: continuing to deploy!';
# outside travis? => deploy
else
echo '[?] deploy script called outside Travis? continuing to deploy!';
fi
# only show number of env vars .. should be 4 on master branch!
# https://docs.travis-ci.com/user/pull-requests/#Pull-Requests-and-Security-Restrictions
# Travis CI makes encrypted variables and data available only to pull requests coming from the same repository.
echo 'aws env vars (should be 4 - but only on master branch!):'
env | grep AWS | wc -l
# set up awscli package
echo 'installing aws tools ..'
pip install awscli
which aws
aws --version
aws s3 ls ${AWS_S3_BUCKET_NAME}
# build and deploy latest docs/website:
# => https://s3.eu-central-1.amazonaws.com/wamp-proto.org/index.html
tox -c tox.ini -e sphinx
npm run build
aws s3 cp --recursive --acl public-read ${HOME}/wamp-docs s3://${AWS_S3_BUCKET_NAME}/${AWS_S3_BUCKET_PATH}
# invalidate cloudfront distribution:
# => https://wamp-proto.org/index.html
aws cloudfront create-invalidation --distribution-id E2QKV23X400P1P --paths "/*"