357fe38766
Notably - Python 2.7 and 3.6 are no longer supported by Ansible on targets - The yum module has been removed, and redirected to dnf - _INTERPRETER_PYTHON_DISTRO_MAP has been neutered. Interpreter discovery always favours specific `python3.<x>` interpreters in decending version order, then generic `python3` or `python`. - Add the ability for an action plugin to call self._execute_module(*, ignore_unknown_opts=True) to execute a module with options that may not be supported for the version being called. https://docs.ansible.com/ansible/devel/porting_guides/porting_guide_10.html https://github.com/ansible-community/ansible-build-data/blob/main/10/CHANGELOG-v10.md https://github.com/ansible/ansible/blob/stable-2.17/changelogs/CHANGELOG-v2.17.rst fixes #1074, refs #1082 Co-authored-by: Claude Becker <becker@phys.ethz.ch> |
3 months ago | |
---|---|---|
.. | ||
bench | 6 months ago | |
files | 9 months ago | |
hosts | 3 months ago | |
integration | 3 months ago | |
lib | 3 months ago | |
regression | 3 months ago | |
setup | 7 months ago | |
soak | 8 months ago | |
tests | 8 months ago | |
.gitignore | 5 years ago | |
Makefile | 6 years ago | |
README.md | 3 years ago | |
all.yml | 3 years ago | |
ansible.cfg | 7 months ago | |
ara_env.py | 6 years ago | |
compare_output_test.py | 6 years ago | |
mitogen_ansible_playbook.py | 3 years ago | |
requirements.txt | 4 months ago | |
run_ansible_playbook.py | 2 years ago |
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
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.