From f649777072e4093125a9548e3d7dbbd9afdd0e69 Mon Sep 17 00:00:00 2001 From: Seth Vidal Date: Wed, 30 Jan 2013 11:56:04 -0500 Subject: [PATCH] - make extra-vars override all other vars and facts in playbooks --- lib/ansible/playbook/__init__.py | 4 +++- lib/ansible/playbook/play.py | 3 +++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/lib/ansible/playbook/__init__.py b/lib/ansible/playbook/__init__.py index c572e55fdc3897..88c35aca5b049f 100644 --- a/lib/ansible/playbook/__init__.py +++ b/lib/ansible/playbook/__init__.py @@ -315,6 +315,8 @@ def _run_task(self, play, task, is_handler): continue facts = result.get('ansible_facts', {}) self.SETUP_CACHE[host].update(facts) + # extra vars need to always trump - so update again following the facts + self.SETUP_CACHE[host].update(self.extra_vars) if task.register: if 'stdout' in result: result['stdout_lines'] = result['stdout'].splitlines() @@ -390,7 +392,7 @@ def _run_play(self, play): ''' run a list of tasks for a given pattern, in order ''' self.callbacks.on_play_start(play.name) - + self.SETUP_CACHE.update(play.vars) # if no hosts matches this play, drop out if not self.inventory.list_hosts(play.hosts): self.callbacks.on_no_hosts_matched() diff --git a/lib/ansible/playbook/play.py b/lib/ansible/playbook/play.py index f414ec55536dea..95d3932394458a 100644 --- a/lib/ansible/playbook/play.py +++ b/lib/ansible/playbook/play.py @@ -186,6 +186,9 @@ def _get_vars(self): else: vars.update(self.vars) + if type(self.playbook.extra_vars) == dict: + vars.update(self.playbook.extra_vars) + if type(self.vars_prompt) == list: for var in self.vars_prompt: if not 'name' in var: