1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

moved mandatory back to filters as it does not always return a boolean, it does an exception on failure

This commit is contained in:
Brian Coca 2015-08-21 09:54:56 -04:00
parent 01708cc824
commit f150fe2c23
2 changed files with 10 additions and 11 deletions

View file

@ -223,6 +223,14 @@ def get_encrypted_password(password, hashtype='sha512', salt=None):
def to_uuid(string):
return str(uuid.uuid5(UUID_NAMESPACE_ANSIBLE, str(string)))
def mandatory(a):
from jinja2.runtime import Undefined
''' Make a variable mandatory '''
if isinstance(a, Undefined):
raise errors.AnsibleFilterError('Mandatory variable not defined.')
return a
class FilterModule(object):
''' Ansible core jinja2 filters '''
@ -290,4 +298,6 @@ class FilterModule(object):
# random stuff
'random': rand,
'shuffle': randomize_list,
# undefined
'mandatory': mandatory,
}

View file

@ -79,14 +79,6 @@ def search(value, pattern='', ignorecase=False):
''' Perform a `re.search` returning a boolean '''
return regex(value, pattern, ignorecase, 'search')
def mandatory(a):
from jinja2.runtime import Undefined
''' Make a variable mandatory '''
if isinstance(a, Undefined):
raise errors.AnsibleFilterError('Mandatory variable not defined.')
return a
class TestModule(object):
''' Ansible core jinja2 tests '''
@ -102,9 +94,6 @@ class TestModule(object):
# skip testing
'skipped' : skipped,
# variable existence
'mandatory': mandatory,
# regex
'match': match,
'search': search,