Fix tag filtering on included files and add more debugging

Previously, we were filtering the task list on tags for each host
that was including the file, based on the idea that the variables
had to include the host information. However, the top level task
filtering is play-context only, which should also apply to the
included tasks. Tags cannot and should not be based on hostvars.
This commit is contained in:
James Cammarata 2015-11-16 17:13:55 -05:00
parent 5cbeab5a3c
commit 984729016e
4 changed files with 41 additions and 10 deletions

View file

@ -24,6 +24,12 @@ import os
from ansible.errors import AnsibleError from ansible.errors import AnsibleError
from ansible.template import Templar from ansible.template import Templar
try:
from __main__ import display
except ImportError:
from ansible.utils.display import Display
display = Display()
class IncludedFile: class IncludedFile:
def __init__(self, filename, args, task): def __init__(self, filename, args, task):

View file

@ -414,6 +414,7 @@ class StrategyBase:
Loads an included YAML file of tasks, applying the optional set of variables. Loads an included YAML file of tasks, applying the optional set of variables.
''' '''
display.debug("loading included file: %s" % included_file._filename)
try: try:
data = self._loader.load_from_file(included_file._filename) data = self._loader.load_from_file(included_file._filename)
if data is None: if data is None:
@ -474,6 +475,7 @@ class StrategyBase:
# finally, send the callback and return the list of blocks loaded # finally, send the callback and return the list of blocks loaded
self._tqm.send_callback('v2_playbook_on_include', included_file) self._tqm.send_callback('v2_playbook_on_include', included_file)
display.debug("done processing included file")
return block_list return block_list
def run_handlers(self, iterator, play_context): def run_handlers(self, iterator, play_context):

View file

@ -156,13 +156,18 @@ class StrategyModule(StrategyBase):
display.warning(str(e)) display.warning(str(e))
continue continue
for host in hosts_left: display.debug("generating all_blocks data")
if host in included_file._hosts: all_blocks = dict((host, []) for host in hosts_left)
task_vars = self._variable_manager.get_vars(loader=self._loader, play=iterator._play, host=host, task=included_file._task) display.debug("done generating all_blocks data")
final_blocks = [] for new_block in new_blocks:
for new_block in new_blocks: task_vars = self._variable_manager.get_vars(loader=self._loader, play=iterator._play, task=included_file._task)
final_blocks.append(new_block.filter_tagged_tasks(play_context, task_vars)) final_block = new_block.filter_tagged_tasks(play_context, task_vars)
iterator.add_tasks(host, final_blocks) for host in hosts_left:
if host in included_file._hosts:
all_blocks[host].append(final_block)
for host in hosts_left:
iterator.add_tasks(host, all_blocks[host])
# pause briefly so we don't spin lock # pause briefly so we don't spin lock
time.sleep(0.05) time.sleep(0.05)

View file

@ -264,31 +264,44 @@ class StrategyModule(StrategyBase):
return False return False
if len(included_files) > 0: if len(included_files) > 0:
display.debug("we have included files to process")
noop_task = Task() noop_task = Task()
noop_task.action = 'meta' noop_task.action = 'meta'
noop_task.args['_raw_params'] = 'noop' noop_task.args['_raw_params'] = 'noop'
noop_task.set_loader(iterator._play._loader) noop_task.set_loader(iterator._play._loader)
display.debug("generating all_blocks data")
all_blocks = dict((host, []) for host in hosts_left) all_blocks = dict((host, []) for host in hosts_left)
display.debug("done generating all_blocks data")
for included_file in included_files: for included_file in included_files:
display.debug("processing included file: %s" % included_file._filename)
# included hosts get the task list while those excluded get an equal-length # included hosts get the task list while those excluded get an equal-length
# list of noop tasks, to make sure that they continue running in lock-step # list of noop tasks, to make sure that they continue running in lock-step
try: try:
new_blocks = self._load_included_file(included_file, iterator=iterator) new_blocks = self._load_included_file(included_file, iterator=iterator)
display.debug("iterating over new_blocks loaded from include file")
for new_block in new_blocks: for new_block in new_blocks:
task_vars = self._variable_manager.get_vars(
loader=self._loader,
play=iterator._play,
task=included_file._task,
)
display.debug("filtering new block on tags")
final_block = new_block.filter_tagged_tasks(play_context, task_vars)
display.debug("done filtering new block on tags")
noop_block = Block(parent_block=task._block) noop_block = Block(parent_block=task._block)
noop_block.block = [noop_task for t in new_block.block] noop_block.block = [noop_task for t in new_block.block]
noop_block.always = [noop_task for t in new_block.always] noop_block.always = [noop_task for t in new_block.always]
noop_block.rescue = [noop_task for t in new_block.rescue] noop_block.rescue = [noop_task for t in new_block.rescue]
for host in hosts_left: for host in hosts_left:
if host in included_file._hosts: if host in included_file._hosts:
task_vars = self._variable_manager.get_vars(loader=self._loader,
play=iterator._play, host=host, task=included_file._task)
final_block = new_block.filter_tagged_tasks(play_context, task_vars)
all_blocks[host].append(final_block) all_blocks[host].append(final_block)
else: else:
all_blocks[host].append(noop_block) all_blocks[host].append(noop_block)
display.debug("done iterating over new_blocks loaded from include file")
except AnsibleError as e: except AnsibleError as e:
for host in included_file._hosts: for host in included_file._hosts:
@ -299,9 +312,14 @@ class StrategyModule(StrategyBase):
# finally go through all of the hosts and append the # finally go through all of the hosts and append the
# accumulated blocks to their list of tasks # accumulated blocks to their list of tasks
display.debug("extending task lists for all hosts with included blocks")
for host in hosts_left: for host in hosts_left:
iterator.add_tasks(host, all_blocks[host]) iterator.add_tasks(host, all_blocks[host])
display.debug("done extending task lists")
display.debug("done processing included files")
display.debug("results queue empty") display.debug("results queue empty")
except (IOError, EOFError) as e: except (IOError, EOFError) as e:
display.debug("got IOError/EOFError in task loop: %s" % e) display.debug("got IOError/EOFError in task loop: %s" % e)