2015-01-21 16:59:42 +08:00
|
|
|
---
|
|
|
|
language: python
|
|
|
|
python: "2.7"
|
|
|
|
|
|
|
|
env:
|
|
|
|
- SITE=test.yml
|
|
|
|
|
|
|
|
before_install:
|
|
|
|
- sudo apt-get update -qq
|
|
|
|
- sudo apt-get install -y curl
|
|
|
|
|
|
|
|
install:
|
|
|
|
# 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.
|
2015-01-21 23:30:24 +08:00
|
|
|
- "ansible-playbook -i dummy-ansible-hosts $SITE --syntax-check"
|
2015-01-21 16:59:42 +08:00
|
|
|
|
|
|
|
# Run the role/playbook with ansible-playbook.
|
2015-01-21 23:30:24 +08:00
|
|
|
#- "ansible-playbook -i dummy-ansible-hosts $SITE --connection=local --sudo"
|
2015-01-21 16:59:42 +08:00
|
|
|
|
|
|
|
# Run the role/playbook again, checking to make sure it's idempotent.
|
2015-01-21 23:30:24 +08:00
|
|
|
#- >
|
|
|
|
# ansible-playbook -i dummy-ansible-hosts $SITE --connection=local --sudo
|
|
|
|
# | grep -q 'changed=0.*failed=0'
|
|
|
|
# && (echo 'Idempotence test: pass' && exit 0)
|
|
|
|
# || (echo 'Idempotence test: fail' && exit 1)
|
2015-01-21 16:59:42 +08:00
|
|
|
|
|
|
|
# Make sure Ansible is installed (yes, this is contrived, since Ansible was
|
|
|
|
# already installed via pip earlier...).
|
|
|
|
- "which ansible"
|