forked from Foundry376/Mailspring
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.travis.yml
114 lines (101 loc) · 3.01 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
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
sudo: true
git:
submodules: false
language: node_js
node_js:
- '6.9'
addons:
artifacts:
working_dir: app/dist
target_paths: client/${TRAVIS_COMMIT:0:8}/${TRAVIS_OS_NAME}
permissions: public-read
paths:
- mailsync.tar.gz
- Mailspring.dmg
- Mailspring.zip
- $(find . -type f -name mailspring-*.deb | tr "\n" ":")
- $(find . -type f -name mailspring-*.rpm | tr "\n" ":")
apt:
sources:
- ubuntu-toolchain-r-test
packages:
- build-essential
- clang
- cmake
- fakeroot
- g++-5
- git
- libgnome-keyring-dev
- libsecret-1-dev
- xvfb
- rpm
- autoconf
- automake
- libtool
- libc-ares-dev
- libctemplate-dev
- libcurl4-openssl-dev
- libicu-dev
- libxext-dev
- libsasl2-dev
- libsasl2-modules
- libsasl2-modules-gssapi-mit
- libssl-dev
- libtidy-dev
- libxtst-dev
- libxkbfile-dev
- libglib2.0-dev
- libxml2-dev
- uuid-dev
branches:
only:
- master
- "/ci-.*/"
- "/stable.*/"
matrix:
include:
- os: linux
env: CC=gcc-5 CXX=g++-5
- os: osx
osx_image: xcode8.3
env: CC=clang CXX=clang++ SIGN_BUILD=true
before_install:
# Decrypt and uncompress code signing certs, etc.
- openssl aes-256-cbc -K $encrypted_faf2708e46e2_key -iv $encrypted_faf2708e46e2_iv
-in app/build/resources/certs.tar.enc -out app/build/resources/certs.tar -d;
- mkdir app/build/resources/certs;
- tar xvf app/build/resources/certs.tar --directory=app/build/resources/;
- source app/build/resources/certs/mac/set_unix_env.sh;
# Checkout the (currently private) C++ Mailsync codebase
- GIT_SSH_COMMAND='ssh -i app/build/resources/certs/mailsync-deploy-key -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no'
SSH_ASKPASS=/Users/travis/build/Foundry376/Mailspring/app/build/resources/certs/ssh-askpass-fix
DISPLAY=nothing:0
git submodule update --init mailsync
before_script:
- if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then export DISPLAY=:99.0; sh -e /etc/init.d/xvfb start; fi
script:
- npm run ci-setup-mac-keychain
- npm run lint
- mailsync/build.sh
- mv ./mailsync ./mailsync-src
- DEBUG=electron-packager,electron-osx-sign npm run build
cache:
directories:
- node_modules
- app/node_modules
- /tmp/mailsync-build-deps
# after_success:
# # Grab the version number from the .deb product and update the snapcraft.yml file
# - sed "s/MAILSPRING_VERSION/$(grep -E -o '([0-9]+.[0-9]+.[0-9]+)' <<< "$(find app/dist -type f -name mailspring-*.deb)")/g" snap/snapcraft.template.yaml > snap/snapcraft.yaml
# # Decrypt the snapcraft login information
# - openssl aes-256-cbc -K $encrypted_f8421d18d2b7_key -iv $encrypted_f8421d18d2b7_iv
# -in .snapcraft/travis_snapcraft.cfg -out .snapcraft/snapcraft.cfg -d
# services:
# - docker
# deploy:
# 'on':
# branch: master
# condition: $TRAVIS_OS_NAME = linux
# provider: script
# script: docker run -v $(pwd):$(pwd) -t snapcore/snapcraft sh -c "apt update -qq && cd $(pwd) && snapcraft && snapcraft push *.snap --release edge"
# skip_cleanup: true