mirror of
https://github.com/geerlingguy/ansible-role-php.git
synced 2024-11-05 09:17:39 +01:00
45 lines
1.2 KiB
YAML
45 lines
1.2 KiB
YAML
---
|
|
language: python
|
|
python: "2.7"
|
|
|
|
env:
|
|
- SITE=test-install-package.yml
|
|
- SITE=test-install-from-source.yml
|
|
|
|
before_install:
|
|
- sudo apt-get update -qq
|
|
|
|
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.
|
|
- "ansible-playbook -i tests/inventory tests/$SITE --syntax-check"
|
|
|
|
# Run the role/playbook with ansible-playbook.
|
|
- "ansible-playbook -i tests/inventory tests/$SITE --connection=local --sudo"
|
|
|
|
# Run the role/playbook again, checking to make sure it's idempotent.
|
|
- >
|
|
ansible-playbook -i tests/inventory tests/$SITE --connection=local --sudo
|
|
| grep -q 'changed=0.*failed=0'
|
|
&& (echo 'Idempotence test: pass' && exit 0)
|
|
|| (echo 'Idempotence test: fail' && exit 1)
|
|
|
|
# Run the role/playbook in --check mode.
|
|
- "ansible-playbook -i tests/inventory tests/$SITE --connection=local --sudo --check"
|
|
|
|
# Make sure PHP is available.
|
|
- >
|
|
php -v
|
|
| grep -q 'The PHP Group'
|
|
&& (echo 'PHP is installed' && exit 0)
|
|
|| (echo 'PHP is not installed' && exit 1)
|
|
|
|
# And for posterity...
|
|
- php -v
|