Allow include statements from plays to specify tags (see tags.yml example file).

Also be smart and don't run a play at all if no tasks in the play match any of the tags specified.  This includes not running the setup actions!
This commit is contained in:
Michael DeHaan 2012-07-11 20:30:30 -04:00
parent 83f23ef861
commit 969c3feb13
4 changed files with 28 additions and 11 deletions

View file

@ -3,27 +3,27 @@
#
# assume: ansible-playbook tags.yml --tags foo
#
# only tags with the given tags will be run when --tags is specified
# try this with:
# --tags foo
# --tags bar
#
# (an include statement will also be able to set tags on all included
# tasks at some point in the future)
# note the include syntax to tag all tasks included below
# it is a short hand over adding "tag:" to each task entry
- name: example play
- name: example play one
hosts: all
user: root
tasks:
- name: hi
tags: foo
action: shell echo "first play ran"
action: shell echo "first task ran"
- name: example play
- name: example play two
hosts: all
user: root
tasks:
- name: hi
tags: bar
action: shell echo "second play ran"
action: shell echo "second task ran"
- include: tasks/base.yml tags=base

View file

@ -282,6 +282,9 @@ class PlayBook(object):
def _run_play(self, play):
''' run a list of tasks for a given pattern, in order '''
if not play.should_run(self.only_tags):
return
self.callbacks.on_play_start(play.name)
# push any variables down to the system # and get facts/ohai/other data back up

View file

@ -79,6 +79,7 @@ class Play(object):
task_vars = self.vars.copy()
if 'include' in x:
tokens = shlex.split(x['include'])
for t in tokens[1:]:
(k,v) = t.split("=", 1)
task_vars[k]=v
@ -151,6 +152,16 @@ class Play(object):
# *************************************************
def should_run(self, tags):
''' does the play match any of the tags? '''
for task in self._tasks:
for task_tag in task.tags:
if task_tag in tags:
return True
return False
# *************************************************
def _update_vars_files_for_host(self, host):
if not host in self.playbook.SETUP_CACHE:

View file

@ -62,6 +62,9 @@ class Task(object):
if len(tokens) > 1:
self.module_args = tokens[1]
import_tags = []
if 'tags' in self.module_vars:
import_tags = self.module_vars['tags'].split(",")
self.name = utils.template(self.name, self.module_vars)
self.action = utils.template(self.name, self.module_vars)
@ -78,7 +81,7 @@ class Task(object):
self.tags.append(apply_tags)
elif type(apply_tags) == list:
self.tags.extend(apply_tags)
self.tags.extend(import_tags)