You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mitogen/tests/ansible
Alex Willmer c6c8bfb690 tests: Skip vanilla Ansible on Linux unpriviliged -> unprivileged become
CI containers lack the necessary `setfacl` command. This has not previously
been noticed because no vanilla Ansible jobs were being run on Linux, only on
macOS.

refs #1118
1 month ago
..
bench tests: Fix duplicate local task executions 6 months ago
files
hosts tests: Test templating of ansible_ssh_common_args et al 2 months ago
integration tests: Skip vanilla Ansible on Linux unpriviliged -> unprivileged become 1 month ago
lib ansible_mitogen: Remove Python 2.4 and 2.5 backward compatibility fallbacks 1 month ago
regression ansible_mitogen: Add regression test for ActionModuleMixin._remote_chmod() 2 months ago
setup tests: Add regression for add_host with host_key_checking 6 months ago
soak
templates tests: Test templating of ansible_ssh_common_args et al 2 months ago
tests
.gitignore
Makefile
README.md
all.yml
ansible.cfg tests: Add regression for add_host with host_key_checking 6 months ago
ara_env.py
compare_output_test.py
mitogen_ansible_playbook.py
requirements.txt CI: Workaround "No module named 'setuptools.command.test'" 3 months ago
run_ansible_playbook.py

README.md

tests/ansible Directory

This is an an organically growing collection of integration and regression tests used for development and end-user bug reports.

It will be tidied up over time, meanwhile, the playbooks here are a useful demonstrator for what does and doesn't work.

Preparation

See ../image_prep/README.md.

run_ansible_playbook.py

This is necessary to set some environment variables used by future tests, as there appears to be no better way to inject them into the top-level process environment before the Mitogen connection process forks.

Running Everything

ANSIBLE_STRATEGY=mitogen_linear ./run_ansible_playbook.py all.yml

hosts/ and common-hosts

To support running the tests against a dev machine that has the requisite user accounts, the the default inventory is a directory containing a 'localhost' file that defines 'localhost' to be named 'target' in Ansible inventory, and a symlink to 'common-hosts', which defines additional targets that all derive from 'target'.

This allows ansible_tests.sh to reuse the common-hosts definitions while replacing localhost as the test target by creating a new directory that similarly symlinks in common-hosts.

There may be a better solution for this, but it works fine for now.