forked from johanmeiring/ansible-sftp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun-local-tests.sh
executable file
·35 lines (29 loc) · 2.28 KB
/
run-local-tests.sh
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
32
33
34
35
#!/bin/bash
set -e
run_test() {
echo "Testing role on Ansible version $3 on $1 $2....."
docker pull $1:$2
docker build --rm=true --file=tests/Dockerfile.$1-$2.ansible-$3 --tag=$1-$2:ansible-$3 tests
container_id=$(mktemp)
docker run --rm=true --detach --volume="${PWD}":/etc/ansible/roles/role_under_test:ro $1-$2:ansible-$3 /sbin/init > "${container_id}"
docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/role_under_test/tests/test.yml --syntax-check
docker exec --tty "$(cat ${container_id})" env TERM=xterm ansible-playbook /etc/ansible/roles/role_under_test/tests/test.yml
docker exec --tty "$(cat ${container_id})" env TERM=xterm grep "user1" /etc/shadow && (echo 'User created' && exit 0) || (echo 'User not created' && exit 1)
docker exec --tty "$(cat ${container_id})" env TERM=xterm test -d /home/user1/test1 && (echo 'Directory created' && exit 0) || (echo 'Directory not created' && exit 1)
docker exec --tty "$(cat ${container_id})" env TERM=xterm grep "foobar" /etc/group && (echo 'Group created' && exit 0) || (echo 'Group not created' && exit 1)
docker exec --tty "$(cat ${container_id})" env TERM=xterm stat -c '%G' /home/user2
docker exec --tty "$(cat ${container_id})" env TERM=xterm '[ $(stat --format '%G' /home/user2) = "foobar" ]' && (echo 'Good directory ownership' && exit 0) || (echo 'Wrong directory ownership' && exit 1)
docker exec --tty "$(cat ${container_id})" env TERM=xterm '[ $(stat --format '%G' /home/user1) = "sftpusers" ]' && (echo 'Good directory ownership' && exit 0) || (echo 'Wrong directory ownership' && exit 1)
docker exec --tty "$(cat ${container_id})" env TERM=xterm test -d /home/user1/test3 && (echo 'User Directory created' && exit 0) || (echo 'User Directory not created' && exit 1)
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)
docker stop "$(cat ${container_id})"
}
run_test ubuntu 14.04 2.2.2.0
run_test ubuntu 14.04 2.3.0.0
run_test ubuntu 16.04 2.2.2.0
run_test ubuntu 16.04 2.3.0.0
run_test ubuntu 18.04 2.5.0.0
run_test centos 6 2.2.2.0
run_test centos 6 2.3.0.0
run_test centos 7 2.2.2.0
run_test centos 7 2.3.0.0