-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.travis.yml
50 lines (50 loc) · 1.59 KB
/
.travis.yml
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
language: python
sudo: required
services:
- docker
env:
- SH="docker exec -t epochard bash -c"
before_install:
- docker run --detach --name epochard -v $(pwd):/travis -w /travis python:3.7-slim-stretch
tail -f /dev/null
- docker ps
addons:
apt:
update: true
packages:
- openvpn # need for deployment
- psmisc # need for killall
- unzip
on:
branch: master
install:
- $SH "pip install pipenv"
- $SH "pipenv install --dev --system"
script: skip
after_failure:
- curl -X POST -d 'message="epochard build failed"' https://${HOME_API_USER}:${HOME_API_AUTHKEY}@${HOME_API_SERVER}/api/pushover
after_success:
- curl -X POST -d 'message="epochard build successful"' https://${HOME_API_USER}:${HOME_API_AUTHKEY}@${HOME_API_SERVER}/api/pushover
before_deploy:
- $SH "apt-get update -qy && apt-get install --no-install-recommends -qfy python-dev python-setuptools build-essential"
- curl -L -o deploy.zip https://www.dropbox.com/sh/kuodr7jj9c1kby0/AAB_i5nXy-B_TYe2FQmGpjCka?dl=0
- unzip deploy.zip -x / # command fails without the exlude
- openssl aes-256-cbc -K "${SSL_KEY}" -iv "${SSL_IV}" -in secrets.enc -out secrets.tar -d
- tar xvf secrets.tar
# setup ssh
- nohup sudo openvpn deploy.ovpn > /dev/null 2>&1 &
- sleep 30
- ping -c 4 $REMOTE_SERVER
- mv id_rsa ~/.ssh/
- sudo chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -H $REMOTE_SERVER > ~/.ssh/known_hosts
# build binaries
- $SH "pyinstaller --distpath /travis/bin/ --onefile /travis/src/epochard.py"
deploy:
skip_cleanup: true
provider: script
script: bash deploy.sh
on:
branch: master
after_deploy:
- sudo killall openvpn || sudo killall nohup