From e655e2f0513fb4d682777fc029283878e5524c8a Mon Sep 17 00:00:00 2001 From: Daniel Hokka Zakrisson Date: Fri, 28 Sep 2012 12:21:01 +0200 Subject: [PATCH] Raise AnsibleError if $FILE() or $PIPE() fail --- lib/ansible/utils.py | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/lib/ansible/utils.py b/lib/ansible/utils.py index a980e49ef4f..64e8ee247bb 100644 --- a/lib/ansible/utils.py +++ b/lib/ansible/utils.py @@ -334,19 +334,22 @@ def varReplaceFilesAndPipes(basedir, raw): # Determine replacement value (if unknown variable then preserve # original) + replacement = m.group() if m.group(1) == "FILE": + path = path_dwim(baesdir, m.group(2)) try: - f = open(path_dwim(basedir, m.group(2)), "r") + f = open(path, "r") + replacement = f.read() + f.close() except IOError: - raise VarNotFoundException() - replacement = f.read() - f.close() + raise errors.AnsibleError("$FILE(%s) failed" % path) elif m.group(1) == "PIPE": p = subprocess.Popen(m.group(2), shell=True, stdout=subprocess.PIPE) (stdout, stderr) = p.communicate() - if p.returncode != 0: - raise VarNotFoundException() - replacement = stdout + if p.returncode == 0: + replacement = stdout + else: + raise errors.AnsibleError("$PIPE(%s) returned %d" % (m.group(2), p.returncode)) start, end = m.span() done.append(raw[:start]) # Keep stuff leading up to token