Skip to content

Commit 1ec10a2

Browse files
committed
refactor: Use vars/RedHat_N.yml symlink for CentOS, Rocky, Alma wherever possible
We have a lot of requests to support Rocky and Alma in various system roles. The first part of adding support is adding `vars/` files for these platforms. In almost every case, for a given major version N, the vars file RedHat_N.yml can be used for CentOS, Rocky, and Alma. Rather than making a copy of the RedHat_N.yml file, just use a symlink to reduce size and maintenance burden, and standardize this across all system roles for consistency. NOTE: There is no Alma or Rocky version 7 or less. NOTE: OracleLinux is not a strict clone, so we are not going to do this for OracleLinux at this time. Support for OracleLinux will need to be done in separate PRs. For more information, see linux-system-roles/cockpit#130 **Question**: Why not just use `ansible_facts["os_family"] == "RedHat"`? **Answer**: This is what Ansible uses as the RedHat os_family: https://github.com/ansible/ansible/blob/1e6ffc1d02559a26def6c9c3b07baf27032865a2/lib/ansible/module_utils/facts/system/distribution.py#L511 There are a lot of distributions in there. I know that Fedora is not a clone of RHEL, but it is very closely related. Most of the others are not clones, and it would generally not work to replace ansible_distribution in ['CentOS', 'Fedora', 'RedHat'] with ansible_facts['os_family'] == 'RedHat' (but it would probably work in specific cases with specific distributions). For example, OracleLinux is in there, and we know that doesn't generally work. The only ones we can be pretty sure about are `RedHat`, `CentOS`, `Fedora`, `AlmaLinux`, and `Rocky`. **Question**: Does my role really need this because it should already work on RHEL clones? **Answer**: Maybe not - but: * it doesn't hurt anything * it's there if we need it in the future * the role will be inconsistent with the other system roles if we don't have this **Question**: Why do I need the `tests/vars/rh_distros_vars.yml` file? Doesn't the test load the vars from the role? **Answer**: No, the test does not load the vars from the role until the role is included, and many tests use version and distribution before including the role. **Question**: Do we need to change the code now to use the new variables? **Answer**: No, not now, in subsequent PRs, hopefully by Alma and Rocky users. Note that there may be more work to be done to the role to fully support Rocky and Alma. Many roles have conditionals like this: ```yaml some_var: "{{ 'some value' if ansible_distribution in ['CentOS', 'RedHat'] else 'other value' }}" another_var: "{{ 'some value' if ansible_distribution in ['CentOS', 'Fedora', 'RedHat'] else 'other value' }}" ... - name: Do something when: ansible_distribution in ['CentOS', 'RedHat'] ... - name: Do something else when: ansible_distribution in ['CentOS', 'Fedora', 'RedHat'] ... ``` Adding Rocky and AlmaLinux to these conditionals will have to be done separately. In order to simplify the task, some new variables are being introduced: ```yaml __$rolename_rh_distros: - AlmaLinux - CentOS - RedHat - Rocky __$rolename_rh_distros_fedora: "{{ __$rolename_rh_distros + ['Fedora'] }}" __$rolename_is_rh_distro: "{{ ansible_distribution in __$rolename_rh_distros }}" __$rolename_is_rh_distro_fedora: "{{ ansible_distribution in __$rolename_rh_distros_fedora }}" ``` Then the conditionals can be rewritten as: ```yaml some_var: "{{ 'some value' if __$rolename_is_rh_distro else 'other value' }}" another_var: "{{ 'some value' if __$rolename_is_rh_distro_fedora else 'other value' }}" ... - name: Do something when: __$rolename_is_rh_distro | bool ... - name: Do something else when: __$rolename_is_rh_distro_fedora | bool ... ``` For tests - tests that use such conditionals will need to use `vars_files` or `include_vars` to load the variables that are defined in `tests/vars/rh_distros_vars.yml`: ```yaml vars_files: - vars/rh_distros_vars.yml ``` We don't currently have CI testing for Rocky or Alma, so someone wanting to run tests on those platforms would need to change the test code to use these. Signed-off-by: Rich Megginson <rmeggins@redhat.com>
1 parent ba6d4e7 commit 1ec10a2

File tree

3 files changed

+39
-0
lines changed

3 files changed

+39
-0
lines changed

meta/main.yml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@ galaxy_info:
1414
versions:
1515
- all
1616
galaxy_tags:
17+
- el
1718
- el8
1819
- el9
1920
- el10

tests/vars/rh_distros_vars.yml

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
# vars for handling conditionals for RedHat and clones
2+
# DO NOT EDIT - file is auto-generated
3+
# repo is https://github.com/linux-system-roles/.github
4+
# file is playbooks/templates/tests/vars/rh_distros_vars.yml
5+
---
6+
# Ansible distribution identifiers that the role treats like RHEL
7+
__sudo_rh_distros:
8+
- AlmaLinux
9+
- CentOS
10+
- RedHat
11+
- Rocky
12+
13+
# Same as above but includes Fedora
14+
__sudo_rh_distros_fedora: "{{ __sudo_rh_distros + ['Fedora'] }}"
15+
16+
# Use this in conditionals to check if distro is Red Hat or clone
17+
__sudo_is_rh_distro: "{{ ansible_distribution in __sudo_rh_distros }}"
18+
19+
# Use this in conditionals to check if distro is Red Hat or clone, or Fedora
20+
__sudo_is_rh_distro_fedora: "{{ ansible_distribution in __sudo_rh_distros_fedora }}"

vars/main.yml

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,3 +10,21 @@ __sudo_required_facts:
1010
- os_family
1111
__sudo_required_facts_subsets: "{{ ['!all', '!min'] +
1212
__sudo_required_facts }}"
13+
14+
# BEGIN - DO NOT EDIT THIS BLOCK - rh distros variables
15+
# Ansible distribution identifiers that the role treats like RHEL
16+
__sudo_rh_distros:
17+
- AlmaLinux
18+
- CentOS
19+
- RedHat
20+
- Rocky
21+
22+
# Same as above but includes Fedora
23+
__sudo_rh_distros_fedora: "{{ __sudo_rh_distros + ['Fedora'] }}"
24+
25+
# Use this in conditionals to check if distro is Red Hat or clone
26+
__sudo_is_rh_distro: "{{ ansible_distribution in __sudo_rh_distros }}"
27+
28+
# Use this in conditionals to check if distro is Red Hat or clone, or Fedora
29+
__sudo_is_rh_distro_fedora: "{{ ansible_distribution in __sudo_rh_distros_fedora }}"
30+
# END - DO NOT EDIT THIS BLOCK - rh distros variables

0 commit comments

Comments
 (0)