79 lines
2.6 KiB
Docker
79 lines
2.6 KiB
Docker
|
---
|
||
|
## from https://github.com/geerlingguy/ansible-role-apache/blob/master/.travis.yml
|
||
|
sudo: required
|
||
|
|
||
|
env:
|
||
|
# - distribution: centos
|
||
|
# version: 6
|
||
|
# init: /sbin/init
|
||
|
# run_opts: ""
|
||
|
- distribution: centos
|
||
|
version: 7
|
||
|
init: /usr/lib/systemd/systemd
|
||
|
run_opts: "--privileged --volume=/sys/fs/cgroup:/sys/fs/cgroup:ro"
|
||
|
- distribution: ubuntu
|
||
|
version: 16.04
|
||
|
init: /lib/systemd/systemd
|
||
|
run_opts: "--privileged --volume=/sys/fs/cgroup:/sys/fs/cgroup:ro"
|
||
|
# run_opts: "--cap-add SYS_ADMIN"
|
||
|
- distribution: ubuntu
|
||
|
version: 14.04
|
||
|
init: /sbin/init
|
||
|
run_opts: ""
|
||
|
# - distribution: ubuntu
|
||
|
# version: 12.04
|
||
|
# init: /sbin/init
|
||
|
# run_opts: ""
|
||
|
# - distribution: alpine
|
||
|
# version: 3.4
|
||
|
# init: /sbin/init
|
||
|
# run_opts: ""
|
||
|
|
||
|
services:
|
||
|
- docker
|
||
|
|
||
|
before_install:
|
||
|
# - sudo apt-get update
|
||
|
# Pull container
|
||
|
- 'sudo docker pull ${distribution}:${version}'
|
||
|
- env
|
||
|
- pwd
|
||
|
- find -ls
|
||
|
- ln -s ansible-fprobe ../juju4.fprobe
|
||
|
- ./get-dependencies.sh
|
||
|
- cp test/travis/initctl_faker test/
|
||
|
# Customize container
|
||
|
- 'sudo docker build --rm=true --file=test/travis/Dockerfile.${distribution}-${version} --tag=${distribution}-${version}:ansible test'
|
||
|
|
||
|
script:
|
||
|
- container_id=$(mktemp)
|
||
|
# Run container in detached state
|
||
|
- 'sudo docker run --detach --volume="${PWD%/*}":/etc/ansible/roles:ro ${run_opts} ${distribution}-${version}:ansible "${init}" > "${container_id}"'
|
||
|
|
||
|
- 'sudo docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible --version'
|
||
|
|
||
|
# Ansible syntax check.
|
||
|
- 'sudo docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/juju4.fprobe/test/integration/default/default.yml --syntax-check'
|
||
|
|
||
|
# Test role.
|
||
|
- 'sudo docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/juju4.fprobe/test/integration/default/default.yml'
|
||
|
|
||
|
# Test role idempotence.
|
||
|
- >
|
||
|
sudo docker exec "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/juju4.fprobe/test/integration/default/default.yml
|
||
|
| tee /tmp/idempotency.log
|
||
|
| grep -q 'changed=0.*failed=0'
|
||
|
&& (echo 'Idempotence test: pass' && exit 0)
|
||
|
|| (echo 'Idempotence test: fail' && cat /tmp/idempotency.log && exit 1)
|
||
|
|
||
|
# serverspec tests
|
||
|
## travis/docker: Errno::EROFS: Read-only file system @ dir_s_mkdir - /etc/ansible/roles/ansible-MISP/test/integration/default/serverspec/.bundle
|
||
|
# - 'sudo docker exec --tty "$(cat ${container_id})" /etc/ansible/roles/MISP/test/integration/default/serverspec/run-local-tests.sh'
|
||
|
|
||
|
# Clean up
|
||
|
- 'sudo docker stop "$(cat ${container_id})"'
|
||
|
|
||
|
notifications:
|
||
|
webhooks: https://galaxy.ansible.com/api/v1/notifications/
|
||
|
|