mirror of https://github.com/ansible/ansible.git
include_role handlers bug fix (#26335)
* Ensure that include_role properly fires handlers include_role needs to ensure that any handlers included with the role are added to the _notified_handler and _listening_handler lists of the TaskQueueManager, otherwise it fails when trying to run the handler. Additionally, the handler needs to be added to the PlayIterator's `_uuid_cache` or it fails after running the handler Add more uuid debug statements - this code was hard to debug with existing debug statements, so add more uuid information at little additional output cost. Fixes #18411 * Add tests for include_role handlers Tests for #18411pull/20618/head
parent
2e073e73d2
commit
ef8c9798d3
@ -1 +1,2 @@
|
|||||||
posix/ci/group3
|
posix/ci/group3
|
||||||
|
handlers
|
||||||
|
|||||||
@ -0,0 +1,5 @@
|
|||||||
|
- name: set handler fact
|
||||||
|
set_fact:
|
||||||
|
handler_called: True
|
||||||
|
- name: test handler
|
||||||
|
debug: msg="handler called"
|
||||||
@ -0,0 +1 @@
|
|||||||
|
dependencies: []
|
||||||
@ -0,0 +1,47 @@
|
|||||||
|
# This file is part of Ansible
|
||||||
|
#
|
||||||
|
# Ansible is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# Ansible is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
|
||||||
|
- name: reset handler_called variable to false for all hosts
|
||||||
|
set_fact:
|
||||||
|
handler_called: False
|
||||||
|
tags: scenario1
|
||||||
|
|
||||||
|
- name: notify the handler for host A only
|
||||||
|
shell: echo
|
||||||
|
notify:
|
||||||
|
- set handler fact
|
||||||
|
when: inventory_hostname == 'A'
|
||||||
|
tags: scenario1
|
||||||
|
|
||||||
|
- name: force handler execution now
|
||||||
|
meta: "flush_handlers"
|
||||||
|
tags: scenario1
|
||||||
|
|
||||||
|
- debug: var=handler_called
|
||||||
|
tags: scenario1
|
||||||
|
|
||||||
|
- name: validate the handler only ran on one host
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "inventory_hostname == 'A' and handler_called == True or handler_called == False"
|
||||||
|
tags: scenario1
|
||||||
|
|
||||||
|
# item below is passed in by the playbook that calls this
|
||||||
|
- name: 'test notify with loop'
|
||||||
|
debug: msg='a task'
|
||||||
|
changed_when: item == 1
|
||||||
|
notify: test handler
|
||||||
|
tags: scenario2
|
||||||
@ -0,0 +1,8 @@
|
|||||||
|
- name: verify that play can include handler
|
||||||
|
hosts: testhost
|
||||||
|
tasks:
|
||||||
|
- include_role:
|
||||||
|
name: test_handlers_include_role
|
||||||
|
with_items:
|
||||||
|
- 1
|
||||||
|
- 2
|
||||||
Loading…
Reference in New Issue