mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-07-26 14:41:23 -07:00
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 #18411
This commit is contained in:
parent
2e073e73d2
commit
ef8c9798d3
13 changed files with 86 additions and 10 deletions
|
@ -137,10 +137,13 @@ class TaskQueueManager:
|
|||
handler_list = []
|
||||
for handler_block in play.handlers:
|
||||
handler_list.extend(_process_block(handler_block))
|
||||
|
||||
# then initialize it with the given handler list
|
||||
self.update_handler_list(handler_list)
|
||||
|
||||
def update_handler_list(self, handler_list):
|
||||
for handler in handler_list:
|
||||
if handler._uuid not in self._notified_handlers:
|
||||
display.debug("Adding handler %s to notified list" % handler.name)
|
||||
self._notified_handlers[handler._uuid] = []
|
||||
if handler.listen:
|
||||
listeners = handler.listen
|
||||
|
@ -149,6 +152,7 @@ class TaskQueueManager:
|
|||
for listener in listeners:
|
||||
if listener not in self._listening_handlers:
|
||||
self._listening_handlers[listener] = []
|
||||
display.debug("Adding handler %s to listening list" % handler.name)
|
||||
self._listening_handlers[listener].append(handler._uuid)
|
||||
|
||||
def load_callbacks(self):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue