sudo: required env: - distribution: centos version: 6 init: /sbin/init run_opts: "" container_id: $(mktemp) - distribution: centos version: 7 init: /usr/lib/systemd/systemd run_opts: "--privileged --volume=/sys/fs/cgroup:/sys/fs/cgroup:ro" container_id: $(mktemp) - distribution: ubuntu version: 14.04 init: /sbin/init run_opts: "" container_id: $(mktemp) - distribution: ubuntu version: 12.04 init: /sbin/init run_opts: "" container_id: $(mktemp) services: - docker before_install: - sudo apt-get update # Pull container - sudo docker pull ${distribution}:${version} # Customize container - sudo docker build --rm=true --file=tests/Dockerfile.${distribution}-${version} --tag=${distribution}-${version}:ansible tests script: # # Run test playbook # # Run container in detached state - sudo docker run --detach --volume="${PWD}":/etc/ansible/roles/role_under_test:ro ${run_opts} ${distribution}-${version}:ansible "${init}" > "${container_id}" # Ansible syntax check. - 'sudo docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/role_under_test/tests/test.yml --syntax-check' # Test role. - 'sudo docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/role_under_test/tests/test.yml' # Test role idempotence. - > sudo docker exec "$(cat ${container_id})" ansible-playbook /etc/ansible/roles/role_under_test/tests/test.yml | grep -q 'changed=0.*failed=0' && (echo 'Idempotence test: pass' && exit 0) || (echo 'Idempotence test: fail' && exit 1) # Clean up - 'sudo docker stop "$(cat ${container_id})"'