Clear flag indicating role had run before each play is run
Fixes #11514
This commit is contained in:
parent
48827a31bc
commit
2e5dfd57cc
3 changed files with 11 additions and 2 deletions
|
@ -25,6 +25,7 @@ from ansible import constants as C
|
||||||
from ansible.errors import *
|
from ansible.errors import *
|
||||||
from ansible.executor.task_queue_manager import TaskQueueManager
|
from ansible.executor.task_queue_manager import TaskQueueManager
|
||||||
from ansible.playbook import Playbook
|
from ansible.playbook import Playbook
|
||||||
|
from ansible.playbook.role import role_reset_has_run
|
||||||
from ansible.plugins import module_loader
|
from ansible.plugins import module_loader
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
|
|
||||||
|
@ -83,6 +84,10 @@ class PlaybookExecutor:
|
||||||
self._display.vv('%d plays in %s' % (len(plays), playbook_path))
|
self._display.vv('%d plays in %s' % (len(plays), playbook_path))
|
||||||
|
|
||||||
for play in plays:
|
for play in plays:
|
||||||
|
# clear out the flag on all roles indicating they had any tasks run
|
||||||
|
role_reset_has_run()
|
||||||
|
|
||||||
|
# clear any filters which may have been applied to the inventory
|
||||||
self._inventory.remove_restriction()
|
self._inventory.remove_restriction()
|
||||||
|
|
||||||
# Create a temporary copy of the play here, so we can run post_validate
|
# Create a temporary copy of the play here, so we can run post_validate
|
||||||
|
|
|
@ -41,7 +41,7 @@ from ansible.plugins import get_all_plugin_loaders, push_basedir
|
||||||
from ansible.utils.vars import combine_vars
|
from ansible.utils.vars import combine_vars
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['Role', 'ROLE_CACHE', 'hash_params']
|
__all__ = ['Role', 'ROLE_CACHE', 'hash_params', 'role_reset_has_run']
|
||||||
|
|
||||||
# FIXME: this should be a utility function, but can't be a member of
|
# FIXME: this should be a utility function, but can't be a member of
|
||||||
# the role due to the fact that it would require the use of self
|
# the role due to the fact that it would require the use of self
|
||||||
|
@ -70,6 +70,10 @@ def hash_params(params):
|
||||||
# will be based on the repr() of the dictionary object)
|
# will be based on the repr() of the dictionary object)
|
||||||
ROLE_CACHE = dict()
|
ROLE_CACHE = dict()
|
||||||
|
|
||||||
|
def role_reset_has_run():
|
||||||
|
for (role_name, cached_roles) in ROLE_CACHE.iteritems():
|
||||||
|
for (hashed_params, role) in cached_roles.iteritems():
|
||||||
|
role._had_task_run = False
|
||||||
|
|
||||||
class Role(Base, Become, Conditional, Taggable):
|
class Role(Base, Become, Conditional, Taggable):
|
||||||
|
|
||||||
|
|
|
@ -195,7 +195,7 @@ class StrategyBase:
|
||||||
# with the correct object and mark it as executed
|
# with the correct object and mark it as executed
|
||||||
for (entry, role_obj) in ROLE_CACHE[task_result._task._role._role_name].iteritems():
|
for (entry, role_obj) in ROLE_CACHE[task_result._task._role._role_name].iteritems():
|
||||||
hashed_entry = hash_params(task_result._task._role._role_params)
|
hashed_entry = hash_params(task_result._task._role._role_params)
|
||||||
if entry == hashed_entry :
|
if entry == hashed_entry:
|
||||||
role_obj._had_task_run = True
|
role_obj._had_task_run = True
|
||||||
|
|
||||||
ret_results.append(task_result)
|
ret_results.append(task_result)
|
||||||
|
|
Loading…
Reference in a new issue