From 12f0bd491588fb754a6049d3f52c728808fdaf3f Mon Sep 17 00:00:00 2001 From: rabi Date: Wed, 6 Nov 2024 18:29:35 +0530 Subject: [PATCH] Don't use rescue block with any_errors_fatal: true This seems broken with ansible 2.17.x. Also the current logic of running certain tasks for failed hosts won't work with `any_errors_fatal` as it would run them for all nodes. Signed-off-by: rabi --- roles/edpm_frr/tasks/configure.yml | 5 ++++- roles/edpm_users/tasks/create_users_and_groups.yml | 10 ++++++++-- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/roles/edpm_frr/tasks/configure.yml b/roles/edpm_frr/tasks/configure.yml index 820839697..ee0e6d2ae 100644 --- a/roles/edpm_frr/tasks/configure.yml +++ b/roles/edpm_frr/tasks/configure.yml @@ -31,12 +31,15 @@ - name: Construct FRR uplink interfaces from os-net-config mappings ansible.builtin.set_fact: edpm_frr_bgp_uplinks_mapped: "{{ edpm_frr_bgp_uplinks | map('extract', iface_map) | list }}" - rescue: + register: check_edpm_frr_bgp_uplinks_mapped + ignore_errors: true + - name: Failed to construct FRR uplink interfaces ansible.builtin.fail: msg: | Failed to map at least one interface from {{ edpm_frr_bgp_uplinks }} to {{ iface_map }}. Please check value of Ansible variable edpm_frr_bgp_uplinks. + when: check_edpm_frr_bgp_uplinks_mapped is failed - name: Gather facts if they don't exist when: "'system' not in ansible_facts" diff --git a/roles/edpm_users/tasks/create_users_and_groups.yml b/roles/edpm_users/tasks/create_users_and_groups.yml index f1cf7dcef..1fdb32e55 100644 --- a/roles/edpm_users/tasks/create_users_and_groups.yml +++ b/roles/edpm_users/tasks/create_users_and_groups.yml @@ -23,14 +23,20 @@ ansible.builtin.getent: database: passwd key: "{{ item.name }}" - rescue: + register: user_check + ignore_errors: true + - name: Ensure group is present on the host [ {{ item.name }} ] ansible.builtin.group: name: "{{ item.name }}" gid: "{{ item.gid }}" state: present + when: user_check is failed + - name: Ensure user is present on the host [ {{ item.name }} ] - when: not (item.group_only | default(false)) + when: + - not (item.group_only | default(false)) + - user_check is failed ansible.builtin.user: name: "{{ item.name }}" uid: "{{ item.uid }}"