Generate new modules WFJT and WFJT node Touch up generated syntax, test new modules Add utility method in awxkit Fix some issues with non-name identifier in AWX collection module_utils Update workflow docs for workflow node identifier Test and fix WFJT modules survey_spec Plug in survey spec for the new module Handle survey spec idempotency and test add associations for node connections Handle node credential prompts as well Add indexes for new identifier field Test with unicode dragon in name
AWX Ansible Collection
This Ansible collection allows for easy interaction with an AWX or Ansible Tower server via Ansible playbooks.
The previous home for this collection was in https://github.com/ansible/ansible
inside the folder lib/ansible/modules/web_infrastructure/ansible_tower
as well as other folders for the inventory plugin, module utils, and
doc fragment.
Building and Installing
This collection templates the galaxy.yml file it uses.
Run make build_collection from the root folder of the AWX source tree.
This will create the tar.gz file inside the awx_collection folder
with the current AWX version, for example: awx_collection/awx-awx-9.2.0.tar.gz.
Installing the tar.gz involves no special instructions.
Running
Modules in this collection may have any of the following python requirements:
See requirements in the DOCUMENTATION string specific to each module.
Release and Upgrade Notes
The release 7.0.0 of the awx.awx collection is intended to be identical
to the content prior to the migration, aside from changes necessary to
have it function as a collection.
The following notes are changes that may require changes to playbooks:
- When a project is created, it will wait for the update/sync to finish by default; this can be turned off with the
waitparameter, if desired. - Creating a "scan" type job template is no longer supported.
- Specifying a custom certificate via the
TOWER_CERTIFICATEenvironment variable no longer works. - Type changes of variable fields
extra_varsin thetower_job_launchmodule worked with alistpreviously, but now only works with adicttype.extra_varsin thetower_workflow_job_templatemodule worked with astringpreviously but now expects adict.- When the
extra_varsparameter is used with thetower_job_launchmodule, the launch will fail unlessask_extra_varsorsurvey_enabledis explicitly set toTrueon the Job Template. - The
variablesparameter in thetower_group,tower_hostandtower_inventorymodules now expects adicttype and no longer supports the use of@syntax for a file.
- Type changes of other types of fields
inputsorinjectorsin thetower_credential_typemodule worked with a string previously but now expects adict.schemain thetower_workflow_job_templatemodule worked with astringpreviously but not expects alistofdicts.
tower_groupused to also service inventory sources, but this functionality has been removed from this module; usetower_inventory_sourceinstead.- Specified
tower_configfile used to handlek=vpairs on a single line; this is no longer supported. Please use a file formatted asyaml,jsonorinionly. - Some return values (e.g.,
credential_type) have been removed. Use ofidis recommended.
Running Unit Tests
Tests to verify compatibility with the most recent AWX code are in awx_collection/test/awx.
These can be ran by make test_collection in the development container.
To run outside of the development container, or to run against
Ansible or tower-cli source, set up a working environment:
mkvirtualenv my_new_venv
# may need to replace psycopg2 with psycopg2-binary in requirements/requirements.txt
pip install -r requirements/requirements.txt -r requirements/requirements_dev.txt -r requirements/requirements_git.txt
make clean-api
pip install -e <path to your Ansible>
pip install -e .
py.test awx_collection/test/awx/
If you do not install tower-cli, it will skip tests for modules that require it.
Running Integration Tests
The integration tests require a virtualenv with ansible >= 2.9 and tower_cli.
The collection must first be installed, which can be done using make install_collection.
You also need a configuration file at ~/.tower_cli.cfg or
/etc/tower/tower_cli.cfg with the credentials for accessing tower. This can
be populated using tower-cli:
tower-cli config host $HOST
tower-cli config username $USERNAME
tower-cli config password $PASSWORD
# This tells the tower-cli not to veriffy the ssl certs in the tower, if your tower has good certs you should leave this to true
tower-cli config verify_ssl false
Finally you can run the tests:
# ansible-test must be run from the directory in which the collection is installed
cd ~/.ansible/collections/ansible_collections/awx/awx/
ansible-test integration
Licensing
All content in this folder is licensed under the same license as Ansible, which is the same as license that applied before the split into an independent collection.