Run Ansible playbooks within Ansible execution environments (EE) using Terraform.
Features
- Run Ansible playbooks against Terraform managed infrastructure (without the
local-exec
provisioner). Eliminates the need for additional scripting or pipeline steps.
- Construct Ansible inventories using other data sources and resources. Set Ansible host and group variables to values and secrets from other providers.
- Utilize Ansible execution environments (containers images) to customize and run the Ansible software stack. Isolate Ansible and its related dependencies (Python/System packages, collections, etc) to simplify pipeline and workstation setup.
- Write JSONPath queries against playbook artifacts. Extract values from the playbook run for use elsewhere in the configuration. Examples include: Ansible facts, remote file contents, task results -- the possibilities are endless!
- Control playbook re-run behavior using several "lifecycle" options, including a flag for running the playbook on resource destruction. Implement conditional plays/tasks with the environment variable
ANSIBLE_TF_OPERATION
.
Complete Examples
Support Matrix
[!WARNING]
Windows builds of this provider are unlikely to work. Bug reports and PRs are welcome.
[!WARNING]
All versions released prior to v1.0.0
are to be considered breaking changes.
Release |
Ansible Navigator |
Terraform |
< v1.0.0 |
>= 3.5.0 |
>= 1.5.0 |
Development Requirements
Building The Provider
- Clone the repository
- Enter the repository directory
- Build the provider using the Go
install
command:
go install
Adding Dependencies
This provider uses Go modules.
Please see the Go documentation for the most up to date information about using Go modules.
To add a new dependency github.com/author/dependency
to your Terraform provider:
go get github.com/author/dependency
go mod tidy
Then commit the changes to go.mod
and go.sum
.
Developing the Provider
If you wish to work on the provider, you'll first need Go installed on your machine (see Requirements above).
To compile the provider, run go install
. This will build the provider and put the provider binary in the $GOPATH/bin
directory.
To generate or update documentation, run make docs
.
In order to run the full suite of Acceptance tests, run make test/acc
.
Note: Acceptance tests create real resources, and often cost money to run.
make test/acc