Merge pull request #144 from Jakuje/tests

Rename tests to follow best practices and make gallaxy linters happy
This commit is contained in:
Matt Willsher 2020-10-28 17:52:15 +00:00 committed by GitHub
commit 6ad8a3e706
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 17 additions and 22 deletions

View file

@ -2,6 +2,9 @@
os: linux
dist: focal
language: python
addons:
apt_packages:
- yamllint
notifications:
webhooks: https://galaxy.ansible.com/api/v1/notifications/
@ -14,48 +17,52 @@ install:
- "{ echo '[defaults]'; echo 'roles_path = ../'; echo 'deprecation_warnings=False'; } >> ansible.cfg"
script:
# Test 0: Check the roles syntax.
- "ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_default.yml --syntax-check"
# Test 0a: Check the roles syntax.
- "ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_default.yml --syntax-check"
# Test 0b: Run yamllint with galaxy configuration to avoid quality score penalty
- wget https://raw.githubusercontent.com/ansible/galaxy/devel/galaxy/importer/linters/yamllint.yaml
- "yamllint -c yamllint.yaml **/*.yml"
# Test 1a: Run the role
- "ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_default.yml --connection=local --become -v"
- "ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_default.yml --connection=local --become -v"
# Test 1b: Run the role through include
- "ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_default_include.yml --connection=local --become -v"
- "ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_default_include.yml --connection=local --become -v"
# Test 2: Run the role/playbook again, checking to make sure it's idempotent.
- >
ansible-playbook -i tests/inventory tests/test_default.yml --connection=local --become | grep -q 'changed=0.*failed=0'
ansible-playbook -i tests/inventory tests/tests_default.yml --connection=local --become | grep -q 'changed=0.*failed=0'
&& (echo 'Idempotence test: pass' && exit 0)
|| (echo 'Idempotence test: fail' && exit 1)
# Test 3: Check we can set arbitrary configuration options
- >
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_set_common.yml --connection=local --become -v
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_set_common.yml --connection=local --become -v
&& (echo 'Common variables test: pass' && exit 0)
|| (echo 'Common variables test: fail' && exit 1)
# Test 4: Check if we set uncommon or unsupported configuration option, it will not fail hard
- >
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_set_uncommon.yml --connection=local --become -v
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_set_uncommon.yml --connection=local --become -v
&& (echo 'Uncommon configuration test: pass' && exit 0)
|| (echo 'Uncommon configuration test: fail' && exit 1)
# Test 5: Make sure we can modify other files, for example for inclusion
# in the main sshd_config or second sshd service
- >
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_alternative_file.yml --connection=local --become -v
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_alternative_file.yml --connection=local --become -v
&& (echo 'Alternative configuration file test: pass' && exit 0)
|| (echo 'Alternative configuration file test: fail' && exit 1)
# Test 6: Test match blocks generators
- >
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_match.yml --connection=local --become -v
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_match.yml --connection=local --become -v
&& (echo 'Match blocks test: pass' && exit 0)
|| (echo 'Match blocks test: fail' && exit 1)
# Test 7: Test match blocks generators with iteration
- >
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/test_match_iterate.yml --connection=local --become -v
ANSIBLE_FORCE_COLOR=1 ansible-playbook -i tests/inventory tests/tests_match_iterate.yml --connection=local --become -v
&& (echo 'Match blocks with iteration test: pass' && exit 0)
|| (echo 'Match blocks with iteration test: fail' && exit 1)

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: Configure alternative sshd_config file
include_role:

View file

@ -1,5 +1,4 @@
---
- hosts: all
become: true
roles:
- ansible-sshd

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: "Configure sshd"
include_role:

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: Configure sshd
include_role:
@ -24,7 +23,6 @@
PasswordAuthentication: no
PermitTunnel: yes
- name: Verify the options are correctly set
block:
- meta: flush_handlers
@ -70,4 +68,3 @@
- "'Match User sftponly' in config.stdout"
- "'Match User root' in config.stdout"
tags: tests::verify

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: Configure sshd
include_role:
@ -22,7 +21,6 @@
PasswordAuthentication: no
PermitTunnel: yes
- name: Verify the options are correctly set
block:
- meta: flush_handlers
@ -68,4 +66,3 @@
- "'Match User sftponly' in config.stdout"
- "'Match User root' in config.stdout"
tags: tests::verify

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: Configure sshd
include_role:

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: Configure sshd with uncommon options, making sure it keeps running
block:

View file

@ -1,6 +1,5 @@
---
- hosts: all
become: true
tasks:
- name: Configure sshd
include_role: