diff --git a/lib/ansible/playbook/task.py b/lib/ansible/playbook/task.py index ac9972fc59..7a34601c7e 100644 --- a/lib/ansible/playbook/task.py +++ b/lib/ansible/playbook/task.py @@ -230,5 +230,6 @@ class Task(object): self.only_if = utils.compile_when_to_only_if(self.when) if additional_conditions: - self.only_if = '(' + self.only_if + ') and (' + ' ) and ('.join(additional_conditions) + ')' + self.only_if = [ self.only_if ] + self.only_if.extend(additional_conditions) diff --git a/lib/ansible/runner/__init__.py b/lib/ansible/runner/__init__.py index 259c18b82b..e1d8cc8c2a 100644 --- a/lib/ansible/runner/__init__.py +++ b/lib/ansible/runner/__init__.py @@ -504,12 +504,15 @@ class Runner(object): else: handler = utils.plugins.action_loader.get('async', self) - conditional = template.template(self.basedir, self.conditional, inject, expand_lists=False) + if type(self.conditional) != list: + self.conditional = [ self.conditional ] - if not utils.check_conditional(conditional): - result = utils.jsonify(dict(changed=False, skipped=True)) - self.callbacks.on_skipped(host, inject.get('item',None)) - return ReturnData(host=host, result=result) + for cond in self.conditional: + cond = template.template(self.basedir, cond, inject, expand_lists=False) + if not utils.check_conditional(cond): + result = utils.jsonify(dict(changed=False, skipped=True)) + self.callbacks.on_skipped(host, inject.get('item',None)) + return ReturnData(host=host, result=result) conn = None actual_host = inject.get('ansible_ssh_host', host)