Skip to content
UBI 8 Docker container for Ansible playbook and role testing.
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
.travis.yml Initial commit. Jul 23, 2019
Dockerfile Add hostname dependency, needed for some kinds of testing. Jul 23, 2019
LICENSE Initial commit. Jul 23, 2019 Use python3 pip3 instead of a hack to use system python. Jul 23, 2019

Universal Base Image 8 Ansible Test Image

Build Status Docker Automated build

UBI 8 (base of Red Hat Enterprise Linux 8) Docker container for Ansible playbook and role testing.


  • latest: Latest stable version of Ansible.
  • testing: Same as latest, but with additional testing dependencies, including:
    • yamllint
    • ansible-lint
    • flake8
    • testinfra
    • molecule

The latest tag is a lightweight image for basic validation of Ansible playbooks. The testing tag also includes a comprehensive suite of Ansible and infrastructure testing tools in case you want them pre-installed.

How to Build

This image is built on Docker Hub automatically any time the upstream OS container is rebuilt, and any time a commit is made or merged to the master branch. But if you need to build the image on your own locally, do the following:

  1. Install Docker.
  2. cd into this directory.
  3. Run docker build -t ubi8-ansible .

Note: Switch between master and testing depending on whether you want the extra testing tools present in the resulting image.

How to Use

  1. Install Docker.
  2. Pull this image from Docker Hub: docker pull geerlingguy/docker-ubi8-ansible:latest (or use the image you built earlier, e.g. ubi8-ansible:latest).
  3. Run a container from the image: docker run --detach --privileged --volume=/sys/fs/cgroup:/sys/fs/cgroup:ro geerlingguy/docker-ubi8-ansible:latest (to test my Ansible roles, I add in a volume mounted from the current working directory with --volume=`pwd`:/etc/ansible/roles/role_under_test:ro).
  4. Use Ansible inside the container: a. docker exec --tty [container_id] env TERM=xterm ansible --version b. docker exec --tty [container_id] env TERM=xterm ansible-playbook /path/to/ansible/playbook.yml --syntax-check


I use Docker to test my Ansible roles and playbooks on multiple OSes using CI tools like Jenkins and Travis. This container allows me to test roles and playbooks using Ansible running locally inside the container.

Important Note: I use this image for testing in an isolated environment—not for production—and the settings and configuration used may not be suitable for a secure and performant production environment. Use on production servers/in the wild at your own risk!


Created in 2019 by Jeff Geerling, author of Ansible for DevOps.

You can’t perform that action at this time.