Пример #1
0
 def v2_runner_retry(self, result):
     msg = "FAILED - RETRYING: %s (%d retries left)." % (result._task, result._result['retries'] - result._result['attempts'])
     if (self._display.verbosity > 2 or '_ansible_verbose_always' in result._result) and not '_ansible_verbose_override' in result._result:
         msg += "Result was: %s" % self._dump_results(result._result)
     
     redisPublishMessage(msg+"\n")
     self._display.display(msg, color=C.COLOR_DEBUG)
Пример #2
0
    def v2_playbook_on_stats(self, stats):
        redisPublishMessage("PLAY RECAP"+"\n")
        self._display.banner("PLAY RECAP")

        hosts = sorted(stats.processed.keys())
        for h in hosts:
            t = stats.summarize(h)

            self._display.display(u"%s : %s %s %s %s" % (
                hostcolor(h, t),
                colorize(u'ok', t['ok'], C.COLOR_OK),
                colorize(u'changed', t['changed'], C.COLOR_CHANGED),
                colorize(u'unreachable', t['unreachable'], C.COLOR_UNREACHABLE),
                colorize(u'failed', t['failures'], C.COLOR_ERROR)),
                screen_only=True
            )

            self._display.display(u"%s : %s %s %s %s" % (
                hostcolor(h, t, False),
                colorize(u'ok', t['ok'], None),
                colorize(u'changed', t['changed'], None),
                colorize(u'unreachable', t['unreachable'], None),
                colorize(u'failed', t['failures'], None)),
                log_only=True
            )

        self._display.display("", screen_only=True)
Пример #3
0
    def v2_runner_on_ok(self, result):

        self._clean_results(result._result, result._task.action)
        delegated_vars = result._result.get('_ansible_delegated_vars', None)
        if result._task.action == 'include':
            return
        elif result._result.get('changed', False):
            if delegated_vars:
                msg = "changed: [%s -> %s]" % (result._host.get_name(), delegated_vars['ansible_host'])
            else:
                msg = "changed: [%s]" % result._host.get_name()
            color = C.COLOR_CHANGED
        else:
            if delegated_vars:
                msg = "ok: [%s -> %s]" % (result._host.get_name(), delegated_vars['ansible_host'])
            else:
                msg = "ok: [%s]" % result._host.get_name()
            color = C.COLOR_OK

        if result._task.loop and 'results' in result._result:
            self._process_items(result)
        else:

            if (self._display.verbosity > 0 or '_ansible_verbose_always' in result._result) and not '_ansible_verbose_override' in result._result:
                msg += " => %s" % (self._dump_results(result._result),)
            redisPublishMessage(msg+"\n")
            self._display.display(msg, color=color)

        self._handle_warnings(result._result)
Пример #4
0
    def v2_runner_item_on_failed(self, result):
        redisPublishMessage("Tarea Fallida"+"\n")
        delegated_vars = result._result.get('_ansible_delegated_vars', None)
        if 'exception' in result._result:
            if self._display.verbosity < 3:
                # extract just the actual error message from the exception text
                error = result._result['exception'].strip().split('\n')[-1]
                msg = "An exception occurred during task execution. To see the full traceback, use -vvv. The error was: %s" % error
            else:
                msg = "An exception occurred during task execution. The full traceback is:\n" + result._result['exception']

            redisPublishMessage(msg+"\n")
            self._display.display(msg, color=C.COLOR_ERROR)

            # finally, remove the exception from the result so it's not shown every time
            del result._result['exception']

        msg = "failed: "
        if delegated_vars:
            msg += "[%s -> %s]" % (result._host.get_name(), delegated_vars['ansible_host'])
            redisPublishMessage(msg+"\n")
        else:
            msg += "[%s]" % (result._host.get_name())
            redisPublishMessage(msg+"\n")

        redisPublishMessage(msg + " (item=%s) => %s" % (self._get_item(result._result), self._dump_results(result._result))+"\n")
        self._display.display(msg + " (item=%s) => %s" % (self._get_item(result._result), self._dump_results(result._result)), color=C.COLOR_ERROR)
        self._handle_warnings(result._result)
Пример #5
0
 def v2_runner_on_unreachable(self, result):
     delegated_vars = result._result.get('_ansible_delegated_vars', None)
     if delegated_vars:
         redisPublishMessage("fatal: [%s -> %s]: UNREACHABLE! => %s" % (result._host.get_name(), delegated_vars['ansible_host'], self._dump_results(result._result))+"\n")
         self._display.display("fatal: [%s -> %s]: UNREACHABLE! => %s" % (result._host.get_name(), delegated_vars['ansible_host'], self._dump_results(result._result)), color=C.COLOR_UNREACHABLE)
     else:
         redisPublishMessage("fatal: [%s]: UNREACHABLE! => %s" % (result._host.get_name(), self._dump_results(result._result))+"\n")
         self._display.display("fatal: [%s]: UNREACHABLE! => %s" % (result._host.get_name(), self._dump_results(result._result)), color=C.COLOR_UNREACHABLE)
Пример #6
0
    def v2_playbook_on_play_start(self, play):
        name = play.get_name().strip()
        if not name:
            msg = "PLAY"
        else:
            msg = "PLAY [%s]" % name

        redisPublishMessage(msg+"\n")
        self._display.banner(msg)
Пример #7
0
 def v2_runner_on_skipped(self, result):
     if C.DISPLAY_SKIPPED_HOSTS:
         if result._task.loop and 'results' in result._result:
             self._process_items(result)
         else:
             msg = "skipping: [%s]" % result._host.get_name()
             if (self._display.verbosity > 0 or '_ansible_verbose_always' in result._result) and not '_ansible_verbose_override' in result._result:
                 msg += " => %s" % self._dump_results(result._result)
             redisPublishMessage(msg+"\n")
             self._display.display(msg, color=C.COLOR_SKIP)
Пример #8
0
 def v2_on_file_diff(self, result):
     if result._task.loop and 'results' in result._result:
         for res in result._result['results']:
             if 'diff' in res and res['diff'] and res.get('changed', False):
                 diff = self._get_diff(res['diff'])
                 if diff:
                     self._display.display(diff)
     elif 'diff' in result._result and result._result['diff'] and result._result.get('changed', False):
         diff = self._get_diff(result._result['diff'])
         if diff:
             redisPublishMessage(diff+ "\n")
             self._display.display(diff)
Пример #9
0
    def v2_playbook_on_start(self, playbook):
        if self._display.verbosity > 1:
            from os.path import basename
            redisPublishMessage("PLAYBOOK: %s" % basename(playbook._file_name)+"\n")
            self._display.banner("PLAYBOOK: %s" % basename(playbook._file_name))

        if self._display.verbosity > 3:
            if self._options is not None:
                for option in dir(self._options):
                    if option.startswith('_') or option in ['read_file', 'ensure_value', 'read_module']:
                        continue
                    val =  getattr(self._options,option)
                    if val:
                        self._display.vvvv('%s: %s' % (option,val))
Пример #10
0
    def v2_runner_on_failed(self, result, ignore_errors=False):
        delegated_vars = result._result.get('_ansible_delegated_vars', None)
        if 'exception' in result._result:
            if self._display.verbosity < 3:
                # extract just the actual error message from the exception text
                error = result._result['exception'].strip().split('\n')[-1]
                msg = "An exception occurred during task execution. To see the full traceback, use -vvv. The error was: %s" % error
            else:
                msg = "An exception occurred during task execution. The full traceback is:\n" + result._result['exception']

            redisPublishMessage(msg+"\n")
            self._display.display(msg, color=C.COLOR_ERROR)

            # finally, remove the exception from the result so it's not shown every time
            del result._result['exception']

        if result._task.loop and 'results' in result._result:
            self._process_items(result)

        else:
            if delegated_vars:
                redisPublishMessage("fatal: [%s -> %s]: FAILED! => %s" % (result._host.get_name(), delegated_vars['ansible_host'], self._dump_results(result._result))+"\n")
                self._display.display("fatal: [%s -> %s]: FAILED! => %s" % (result._host.get_name(), delegated_vars['ansible_host'], self._dump_results(result._result)), color=C.COLOR_ERROR)
            else:
                redisPublishMessage("fatal: [%s]: FAILED! => %s" % (result._host.get_name(), self._dump_results(result._result))+"\n")
                self._display.display("fatal: [%s]: FAILED! => %s" % (result._host.get_name(), self._dump_results(result._result)), color=C.COLOR_ERROR)

        if result._task.ignore_errors:
            redisPublishMessage("...ignoring"+"\n")
            self._display.display("...ignoring", color=C.COLOR_SKIP)
Пример #11
0
def TailLog(path_log, path_name):

		log = open(path_log + path_name,'r')

		line = ''

		while line != 'Finnish':
		    where = log.tell()
		    line = log.readline()
		    if not line:
		        time.sleep(1)
		        log.seek(where)
		    else:
		        redisPublishMessage(line), 

		return 'Finnish'
Пример #12
0
    def v2_playbook_on_task_start(self, task, is_conditional):
        args = ''
        # args can be specified as no_log in several places: in the task or in
        # the argument spec.  We can check whether the task is no_log but the
        # argument spec can't be because that is only run on the target
        # machine and we haven't run it thereyet at this time.
        #
        # So we give people a config option to affect display of the args so
        # that they can secure this if they feel that their stdout is insecure
        # (shoulder surfing, logging stdout straight to a file, etc).
        if not task.no_log and C.DISPLAY_ARGS_TO_STDOUT:
            args = ', '.join(('%s=%s' % a for a in task.args.items()))
            args = ' %s' % args

        redisPublishMessage("TASK [%s%s]" % (task.get_name().strip(), args) + "\n")
        self._display.banner("TASK [%s%s]" % (task.get_name().strip(), args))
        if self._display.verbosity >= 2:
            path = task.get_path()
            if path:
                redisPublishMessage("task path: %s" % path + "\n")
                self._display.display("task path: %s" % path, color=C.COLOR_DEBUG)
Пример #13
0
    def v2_runner_item_on_ok(self, result):
        delegated_vars = result._result.get('_ansible_delegated_vars', None)
        if result._task.action == 'include':
            return
        elif result._result.get('changed', False):
            msg = 'changed'
            color = C.COLOR_CHANGED
        else:
            msg = 'ok'
            color = C.COLOR_OK

        if delegated_vars:
            msg += ": [%s -> %s]" % (result._host.get_name(), delegated_vars['ansible_host'])
        else:
            msg += ": [%s]" % result._host.get_name()

        msg += " => (item=%s)" % (self._get_item(result._result),)

        if (self._display.verbosity > 0 or '_ansible_verbose_always' in result._result) and not '_ansible_verbose_override' in result._result:
            msg += " => %s" % self._dump_results(result._result)

        redisPublishMessage(msg+"\n")
        self._display.display(msg, color=color)
Пример #14
0
    def v2_runner_item_on_skipped(self, result):
        if C.DISPLAY_SKIPPED_HOSTS:
            msg = "skipping: [%s] => (item=%s) " % (result._host.get_name(), self._get_item(result._result))
            redisPublishMessage(msg+"\n")
            if (self._display.verbosity > 0 or '_ansible_verbose_always' in result._result) and not '_ansible_verbose_override' in result._result:
                msg += " => %s" % self._dump_results(result._result)
                redisPublishMessage(msg+"\n")

            redisPublishMessage(msg+"\n")
            self._display.display(msg, color=C.COLOR_SKIP)
Пример #15
0
 def v2_playbook_on_no_hosts_matched(self):
     redisPublishMessage("skipping: no hosts matched"+"\n")
     self._display.display("skipping: no hosts matched", color=C.COLOR_SKIP)
Пример #16
0
 def v2_playbook_on_no_hosts_remaining(self):
     redisPublishMessage("NO MORE HOSTS LEFT"+"\n")
     self._display.banner("NO MORE HOSTS LEFT")
Пример #17
0
 def v2_playbook_on_cleanup_task_start(self, task):
     redisPublishMessage("CLEANUP TASK [%s]" % task.get_name().strip()+ "\n")
     self._display.banner("CLEANUP TASK [%s]" % task.get_name().strip())
Пример #18
0
 def v2_playbook_on_handler_task_start(self, task):
     redisPublishMessage("RUNNING HANDLER [%s]" % task.get_name().strip()+ "\n")
     self._display.banner("RUNNING HANDLER [%s]" % task.get_name().strip())
Пример #19
0
 def v2_playbook_on_include(self, included_file):
     msg = 'included: %s for %s' % (included_file._filename, ", ".join([h.name for h in included_file._hosts]))
     redisPublishMessage(msg+"\n")
     self._display.display(msg, color=C.COLOR_SKIP)