1
0
mirror of https://github.com/ansible/awx.git synced 2024-10-27 09:25:10 +03:00
awx/awx_collection
softwarefactory-project-zuul[bot] 43bf370f8c
Merge pull request #5195 from AlanCoding/job_fail_json
In tower_job_wait intentionally fail module for failure

Reviewed-by: https://github.com/apps/softwarefactory-project-zuul
2019-10-31 17:53:53 +00:00
..
plugins Merge pull request #5195 from AlanCoding/job_fail_json 2019-10-31 17:53:53 +00:00
test/awx Merge pull request #5195 from AlanCoding/job_fail_json 2019-10-31 17:53:53 +00:00
tests/sanity Remove sanity exceptions no longer needed 2019-10-30 12:56:36 -04:00
COPYING rename awx modules folder to collection 2019-09-27 14:29:04 -04:00
galaxy.yml.j2 rename playbook vars to have collection_ 2019-10-01 13:45:07 -04:00
README.md Add tests for AWX collection credential fixes (#3893) 2019-10-29 11:24:16 -04:00
setup.cfg rename awx modules folder to collection 2019-09-27 14:29:04 -04:00
template_galaxy.yml use fully qualified inventory plugin name 2019-10-10 08:51:18 -04:00

AWX Ansible Collection

This Ansible collection allows for easy interaction with an AWX or Ansible Tower server in 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.

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.

  • Specifying inputs or injectors as strings in the tower_credential_type module is no longer supported. Provide as dictionaries instead.

Running

To use this collection, the "old" tower-cli needs to be installed in the virtual environment where the collection runs. You can install it from either:

To use this collection in AWX, you should create a custom virtual environment to install the requirement into. NOTE: running locally, you will also need to set the job template extra_vars to include ansible_python_interpreter to be the python in that virtual environment.

Running Tests

Tests to verify compatibility with the most recent AWX code are in awx_collection/test/awx. These tests require that python packages are available for all of awx, ansible, tower_cli, and the collection itself.

Inside Development Container

The target make prepare_collection_venv will prepare some requirements in the awx_collection_test_venv folder so that make test_collection can be ran to actually run the tests. A single test can be ran via:

make test_collection COLLECTION_TEST_DIRS=awx_collection/test/awx/test_organization.py

Manually

As a faster alternative if you do not want to use the container, or run against Ansible or tower-cli source, it is possible to set up a working environment yourself.

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 <path to your tower-cli>
pip install -e .
PYTHONPATH=awx_collection:$PYTHONPATH py.test awx_collection/test/awx/

Building

The build target make build_collection will template out a galaxy.yml file with automatic detection of the current AWX version. Then it builds the collection with the ansible-galaxy CLI.

Roadmap

Major future development items on the agenda include:

  • Removing tower-cli as a dependency
  • Renaming the modules, for example tower_organization to just organization and giving a deprecation period for the switch

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.