Prevent vars premature templating (#56117)

Avoid premature vars templating
  * added tests
  * avoid 'is template' warning in vars, since we want them for latter templating

(cherry picked from commit 1da47bfa8c)
This commit is contained in:
Brian Coca 2019-05-23 09:42:19 -04:00 committed by Toshio Kuratomi
parent 206087e342
commit 53cfa05568
6 changed files with 38 additions and 2 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- we don't really need to template vars on definition as we do this on demand in templating.

View file

@ -353,7 +353,9 @@ class FieldAttributeBase(with_metaclass(BaseMeta, object)):
if attribute.static:
value = getattr(self, name)
if templar.is_template(value):
# we don't template 'vars' but allow template as values for later use
if name not in ('vars',) and templar.is_template(value):
display.warning('"%s" is not templatable, but we found: %s, '
'it will not be templated and will be used "as is".' % (name, value))
continue
@ -597,7 +599,7 @@ class Base(FieldAttributeBase):
_remote_user = FieldAttribute(isa='string', default=context.cliargs_deferred_get('remote_user'))
# variables
_vars = FieldAttribute(isa='dict', priority=100, inherit=False)
_vars = FieldAttribute(isa='dict', priority=100, inherit=False, static=True)
# module default params
_module_defaults = FieldAttribute(isa='list', extend=True, prepend=True)

View file

@ -0,0 +1 @@
shippable/posix/group3

View file

@ -0,0 +1,12 @@
#!/usr/bin/env bash
set -eux
# this should succeed since we override the undefined variable
ansible-playbook undefined.yml -i inventory -v "$@" -e '{"mytest": False}'
# this should still work, just show that var is undefined in debug
ansible-playbook undefined.yml -i inventory -v "$@"
# this should work since we dont use the variable
ansible-playbook undall.yml -i inventory -v "$@"

View file

@ -0,0 +1,6 @@
- hosts: localhost
gather_facts: false
tasks:
- debug:
vars:
mytest: '{{ und }}'

View file

@ -0,0 +1,13 @@
- hosts: localhost
gather_facts: false
tasks:
- name: show defined/undefined var
debug: var=mytest
vars:
mytest: '{{ und }}'
register: var_undefined
- name: ensure either mytest is defined or debug finds it to be undefined
assert:
that:
- mytest is defined or 'VARIABLE IS NOT DEFINED!' in var_undefined['mytest']