This Ansible Collection includes Ansible content to help automate the management of Flight Control resources.
This collection enables organizations to automate time-consuming, error-prone tasks, enhancing efficiency and reducing manual effort. By leveraging it, teams can quickly adapt to shifting conditions across diverse IT environments, improving both operational agility and resilience. Its primary goal is to streamline mission-critical workflows for better overall performance.
Tested with the Ansible Core >= 2.15.0 versions, and the current development version of Ansible.
This collection requires Python 3.10 or greater.
You can either call modules, rulebooks and playbooks by their Fully Qualified Collection Name (FQCN), such as ansible.eda.activation, or you can call modules by their short name if you list the flightctl.core collection in the playbook's collections keyword:
---
- name: Create a new test device
flightctl.core.flightctl_resource:
kind: Device
name: "test-ansible-device"
api_version: v1alpha1
- name: Create a new device
flightctl.core.flightctl_resource:
kind: Device
name: "test-ansible-device-2"
resource_definition: "{{ lookup('file', 'device.yml') | from_yaml }}"
- name: Update new test device
flightctl.core.flightctl_resource:
kind: Device
name: "test-ansible-device"
api_version: v1alpha1
resource_definition:
apiVersion: v1alpha1
kind: Device
metadata:
labels:
fleet: default
novalue: ""
- name: Get information about a specific device
flightctl.core.flightctl_resource_info:
kind: Device
name: "test-ansible-device"
- name: Delete a test device
flightctl.core.flightctl_resource:
kind: Device
name: "test-ansible-device"
state: absent
- name: Get all devices
flightctl.core.flightctl_resource_info:
kind: Device
- name: Get all fleets
flightctl.core.flightctl_resource_info:
kind: Fleet
- name: Update the resource definition for a fleet
flightctl.core.flightctl_resource:
kind: Fleet
name: "ansible-test-fleet"
resource_definition:
spec:
os:
image: quay.io/redhat/rhde:9.3
There are unit, sanity, and integration tests configured to run for this repository. Tests are configured to run via github actions on pull requests and can also be run locally.
ansible-test
is used to run each of the test types. For ansible-test
to properly work the collection must be present in the following directory structure on your local machine:
{...}/ansible_collections/flightctl/core/{code_from_this_repo}
Run locally via make unit-test
Run locally via make sanity-test
Integration tests are dependent on:
- A flightctl instance the tests can hit
- The flightctl_host var inside integration_config.yml set to the running flightctl api service
The easiest way to run tests locally is to:
- Run
make deploy
from the main flightctl repository - Run
make write-integration-config
from this repository to create the proper integration config from your running services - Run locally via
make integration-test
If you encounter issues or have questions, you can submit a support request through the following channels:
- GitHub Issues: Report bugs, request features, or ask questions by opening an issue in the GitHub repository.
See the changelog.
More information about Flight Control can be found in the main repo. The user docs in particular are helpful for understanding the concepts and capabilities of Flight Control.
See LICENSE to see the full text.