diff --git a/bin/ansible-playbook b/bin/ansible-playbook index 6f13ffea91..111a753a29 100755 --- a/bin/ansible-playbook +++ b/bin/ansible-playbook @@ -26,69 +26,12 @@ import ansible.playbook import ansible.constants as C from ansible import errors from ansible import utils - -####################################################### - -class PlaybookCallbacks(object): - - def __init__(self): - pass - - def set_playbook(self, playbook): - self.playbook = playbook - - def on_start(self): - print "\n" - - def on_task_start(self, name, is_conditional): - print utils.task_start_msg(name, is_conditional) - - def on_setup_primary(self): - print "SETUP PHASE ****************************\n" - - def on_setup_secondary(self): - print "\nVARIABLE IMPORT PHASE ******************\n" - - def on_unreachable(self, host, msg): - print "unreachable: [%s] => %s" % (host, msg) - - def on_failed(self, host, results): - invocation = results.get('invocation',None) - if not invocation or invocation.startswith('setup ') or invocation.startswith('async_status '): - print "failed: [%s] => %s\n" % (host, utils.smjson(results)) - else: - print "failed: [%s] => %s => %s\n" % (host, invocation, utils.smjson(results)) - - def on_ok(self, host, host_result): - invocation = host_result.get('invocation',None) - if not invocation or invocation.startswith('setup ') or invocation.startswith('async_status '): - print "ok: [%s]\n" % (host) - else: - print "ok: [%s] => %s\n" % (host, invocation) - - def on_import_for_host(self, host, imported_file): - print "%s: importing %s" % (host, imported_file) - - def on_not_import_for_host(self, host, missing_file): - print "%s: not importing file: %s" % (host, missing_file) - - def on_play_start(self, pattern): - print "PLAY [%s] ****************************\n" % pattern - - def on_async_confused(self, msg): - print msg - - def on_async_poll(self, jid, host, clock, host_result): - print utils.async_poll_status(jid, host, clock, host_result) - - def on_dark_host(self, host, msg): - print "exception: [%s] => %s" % (host, msg) +from ansible import callbacks def summarize(results): ''' print out per host statistics ''' print "PLAY RECAP ******************************\n" - hosts = sorted(results.keys()) for host in hosts: print "%s : %s" % (host, utils.smjson(results[host])) @@ -129,7 +72,7 @@ def main(args): forks=options.forks, verbose=True, remote_pass=sshpass, - callbacks=PlaybookCallbacks(), + callbacks=callbacks.PlaybookCallbacks(), timeout=options.timeout ) try: diff --git a/lib/ansible/callbacks.py b/lib/ansible/callbacks.py new file mode 100755 index 0000000000..6e0c877dbf --- /dev/null +++ b/lib/ansible/callbacks.py @@ -0,0 +1,80 @@ +#!/usr/bin/python -tt +# (C) 2012, Michael DeHaan, + +# This file is part of Ansible +# +# Ansible is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Ansible is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Ansible. If not, see . + +####################################################### + +import sys +import utils + +####################################################### + +class PlaybookCallbacks(object): + + def __init__(self): + pass + + def set_playbook(self, playbook): + self.playbook = playbook + + def on_start(self): + print "\n" + + def on_task_start(self, name, is_conditional): + print utils.task_start_msg(name, is_conditional) + + def on_setup_primary(self): + print "SETUP PHASE ****************************\n" + + def on_setup_secondary(self): + print "\nVARIABLE IMPORT PHASE ******************\n" + + def on_unreachable(self, host, msg): + print "unreachable: [%s] => %s" % (host, msg) + + def on_failed(self, host, results): + invocation = results.get('invocation',None) + if not invocation or invocation.startswith('setup ') or invocation.startswith('async_status '): + print "failed: [%s] => %s\n" % (host, utils.smjson(results)) + else: + print "failed: [%s] => %s => %s\n" % (host, invocation, utils.smjson(results)) + + def on_ok(self, host, host_result): + invocation = host_result.get('invocation',None) + if not invocation or invocation.startswith('setup ') or invocation.startswith('async_status '): + print "ok: [%s]\n" % (host) + else: + print "ok: [%s] => %s\n" % (host, invocation) + + def on_import_for_host(self, host, imported_file): + print "%s: importing %s" % (host, imported_file) + + def on_not_import_for_host(self, host, missing_file): + print "%s: not importing file: %s" % (host, missing_file) + + def on_play_start(self, pattern): + print "PLAY [%s] ****************************\n" % pattern + + def on_async_confused(self, msg): + print msg + + def on_async_poll(self, jid, host, clock, host_result): + print utils.async_poll_status(jid, host, clock, host_result) + + def on_dark_host(self, host, msg): + print "exception: [%s] => %s" % (host, msg) + diff --git a/lib/ansible/runner.py b/lib/ansible/runner.py index 938b25b4cd..41469da5ec 100755 --- a/lib/ansible/runner.py +++ b/lib/ansible/runner.py @@ -301,7 +301,7 @@ class Runner(object): # needed for the setup module args = " ".join([ "\"%s\"" % str(x) for x in module_args ]) else: - args = " ".join([ str(x) for x in module_args ]) + args = " ".join([ str(x) for x in module_args ]) # by default the args to substitute in the action line are those from the setup cache inject_vars = self.setup_cache.get(conn.host,{})