From 34e258422049caa391b9e8c979237592b75bc248 Mon Sep 17 00:00:00 2001 From: Derek Carter Date: Fri, 20 Jul 2012 14:01:54 -0400 Subject: [PATCH] improved output in with_items fixes: #627 --- lib/ansible/callbacks.py | 35 ++++++++++++++++++++++++++++------ lib/ansible/runner/__init__.py | 1 + 2 files changed, 30 insertions(+), 6 deletions(-) diff --git a/lib/ansible/callbacks.py b/lib/ansible/callbacks.py index b393158dd1..dc6c875027 100644 --- a/lib/ansible/callbacks.py +++ b/lib/ansible/callbacks.py @@ -248,27 +248,50 @@ class PlaybookRunnerCallbacks(DefaultRunnerCallbacks): def on_unreachable(self, host, msg): - print "fatal: [%s] => %s" % (host, msg) + item = msg.get('item', None) + + if item: + print "fatal: [%s] => (item=%s) => %s" % (host, item, msg) + else: + print "fatal: [%s] => %s" % (host, msg) def on_failed(self, host, results): - print "failed: [%s] => %s" % (host, utils.jsonify(results)) + item = results.get('item', None) + + if item: + print "failed: [%s] => (item=%s) => %s" % (host, item, utils.jsonify(results)) + else: + print "failed: [%s] => %s" % (host, utils.jsonify(results)) def on_ok(self, host, host_result): + item = host_result.get('item', None) + # show verbose output for non-setup module results if --verbose is used if not self.verbose or host_result.get("verbose_override",None) is not None: - print "ok: [%s]" % (host) + if item: + print "ok: [%s] => (item=%s)" % (host,item) + else: + print "ok: [%s]" % (host) else: - print "ok: [%s] => %s" % (host, utils.jsonify(host_result)) + if item: + print "ok: [%s] => (item=%s) => %s" % (host, item, utils.jsonify(host_result)) + else: + print "ok: [%s] => %s" % (host, utils.jsonify(host_result)) def on_error(self, host, err): - print >>sys.stderr, "err: [%s] => %s" % (host, err) + item = err.get('item', None) + + if item: + print >>sys.stderr, "err: [%s] => (item=%s) => %s" % (host, item, err) + else: + print >>sys.stderr, "err: [%s] => %s" % (host, err) def on_skipped(self, host): - print "skipping: [%s]" % host + print "skipping: [%s]" % host def on_no_hosts(self): diff --git a/lib/ansible/runner/__init__.py b/lib/ansible/runner/__init__.py index 27889c1ccc..905ead5b0a 100644 --- a/lib/ansible/runner/__init__.py +++ b/lib/ansible/runner/__init__.py @@ -645,6 +645,7 @@ class Runner(object): self.callbacks.on_unreachable(host, result.result) else: data = result.result + result.result['item'] = inject.get('item', None) if 'skipped' in data: self.callbacks.on_skipped(result.host) elif not result.is_successful():