-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy path.travis.yml
31 lines (25 loc) · 1.08 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
---
language: python
python: "2.7"
env:
- TESTBOOK=test.yml
before_install:
- sudo apt-get update -qq
install:
#Workaround for ssl exception
- wget https://bin.equinox.io/c/VdrWdbjqyF/cloudflared-stable-linux-amd64.deb -P /tmp/
# Install Ansible.
- pip install ansible
# Add ansible.cfg to pick up roles path.
- "{ echo '[defaults]'; echo 'roles_path = ../'; } >> ansible.cfg"
script:
# Check the role/playbook's syntax.
- "ansible-playbook -i tests/inventory tests/$TESTBOOK --syntax-check"
# Run role and ensure it completes successfully.
- "ansible-playbook -i tests/inventory tests/$TESTBOOK --skip-tags systemd"
# Check setting ansible port
- "ansible-playbook -i tests/inventory tests/$TESTBOOK --extra-vars 'cloudflared_port=53' --skip-tags systemd"
# Run role again and check for idempotence.
- "ansible-playbook -i tests/inventory tests/$TESTBOOK --skip-tags systemd | grep -q 'changed=0.*failed=0' && (echo 'Idempotence test: pass' && exit 0) || (echo 'Idempotence test: fail' && exit 1)"
# Check cloudflared has been installed correctly
- "cloudflared"