2018-09-11 11:51:47 -05:00
:orphan:
2018-04-25 13:18:52 -05:00
.. _testing_running_locally:
2017-04-28 09:08:26 +01:00
***** ***** *****
2017-04-13 17:46:21 -07:00
Testing Ansible
2017-04-28 09:08:26 +01:00
***** ***** *****
2017-04-13 17:46:21 -07:00
2017-04-28 09:08:26 +01:00
.. contents :: Topics
2017-04-28 11:58:38 +01:00
This document describes how to:
2017-04-28 09:08:26 +01:00
* Run tests locally using `` ansible-test ``
* Extend
2017-04-13 17:46:21 -07:00
Requirements
============
There are no special requirements for running `` ansible-test `` on Python 2.7 or later.
The `` argparse `` package is required for Python 2.6.
The requirements for each `` ansible-test `` command are covered later.
Test Environments
=================
Most `` ansible-test `` commands support running in one or more isolated test environments to simplify testing.
Remote
------
The `` --remote `` option runs tests in a cloud hosted environment.
An API key is required to use this feature.
Recommended for integration tests.
2017-04-28 09:08:26 +01:00
See the `list of supported platforms and versions <https://github.com/ansible/ansible/blob/devel/test/runner/completion/remote.txt> `_ for additional details.
2017-04-13 17:46:21 -07:00
2018-03-06 18:28:06 -06:00
Environment Variables
---------------------
When using environment variables to manipulate tests there some limitations to keep in mind. Environment variables are:
2018-09-11 11:51:47 -05:00
* Not propagated from the host to the test environment when using the `` --docker `` or `` --remote `` options.
2018-03-06 18:28:06 -06:00
* Not exposed to the test environment unless whitelisted in `` test/runner/lib/util.py `` in the `` common_environment `` function.
* Not exposed to the test environment when using the `` --tox `` option unless whitelisted in `` test/runner/tox.ini `` by the `` passenv `` definition.
2018-09-11 11:51:47 -05:00
Example: `` ANSIBLE_KEEP_REMOTE_FILES=1 `` can be set when running `` ansible-test integration --tox `` . However, using the `` --docker `` option would
require running `` ansible-test shell `` to gain access to the Docker environment. Once at the shell prompt, the environment variable could be set
and the tests executed. This is useful for debugging tests inside a container by following the
2018-03-06 18:28:06 -06:00
:ref: `Debugging AnsibleModule-based modules <debugging_ansiblemodule_based_modules>` instructions.
2017-04-13 17:46:21 -07:00
Interactive Shell
=================
Use the `` ansible-test shell `` command to get an interactive shell in the same environment used to run tests. Examples:
* `` ansible-test shell --docker `` - Open a shell in the default docker container.
2018-12-01 06:16:01 +11:00
* `` ansible-test shell --tox 3.6 `` - Open a shell in the Python 3.6 `` tox `` environment.
2017-04-13 17:46:21 -07:00
2018-03-06 18:28:06 -06:00
2017-04-13 17:46:21 -07:00
Code Coverage
=============
2017-10-19 21:36:57 +01:00
Code coverage reports make it easy to identify untested code for which more tests should
be written. Online reports are available but only cover the `` devel `` branch (see
2019-06-26 13:59:33 -05:00
:ref: `developing_testing` ). For new code local reports are needed.
2017-10-19 21:36:57 +01:00
Add the `` --coverage `` option to any test command to collect code coverage data. If you
aren't using the `` --tox `` or `` --docker `` options which create an isolated python
environment then you may have to use the `` --requirements `` option to ensure that the
2019-03-06 13:45:22 -05:00
correct version of the coverage module is installed::
2017-10-19 21:36:57 +01:00
ansible-test units --coverage apt
ansible-test integration --coverage aws_lambda --tox --requirements
ansible-test coverage html
2017-04-13 17:46:21 -07:00
Reports can be generated in several different formats:
* `` ansible-test coverage report `` - Console report.
* `` ansible-test coverage html `` - HTML report.
* `` ansible-test coverage xml `` - XML report.
2017-10-19 21:36:57 +01:00
To clear data between test runs, use the `` ansible-test coverage erase `` command. For a full list of features see the online help::
ansible-test coverage --help