diff --git a/bin/ansible b/bin/ansible index af669e099ed..f8c72234c82 100755 --- a/bin/ansible +++ b/bin/ansible @@ -159,7 +159,7 @@ if __name__ == '__main__': if 'failed' in result or result.get('rc', 0) != 0: sys.exit(2) if results['dark']: - sys.exit(2) + sys.exit(3) except errors.AnsibleError, e: # Generic handler for ansible specific errors callbacks.display("ERROR: %s" % str(e), stderr=True, color='red') diff --git a/bin/ansible-playbook b/bin/ansible-playbook index ac25ee30f26..27274227fbb 100755 --- a/bin/ansible-playbook +++ b/bin/ansible-playbook @@ -201,6 +201,7 @@ def main(args): return 0 failed_hosts = [] + unreachable_hosts = [] try: @@ -212,11 +213,15 @@ def main(args): for h in hosts: t = pb.stats.summarize(h) - if t['unreachable'] > 0 or t['failures'] > 0: + if t['failures'] > 0: failed_hosts.append(h) + if t['unreachable'] > 0: + unreachable_hosts.append(h) - if len(failed_hosts) > 0: - filename = pb.generate_retry_inventory(failed_hosts) + retries = failed_hosts + unreachable_hosts + + if len(retries) > 0: + filename = pb.generate_retry_inventory(retries) if filename: display(" to retry, use: --limit @%s\n" % filename) @@ -245,6 +250,8 @@ def main(args): print "" if len(failed_hosts) > 0: return 2 + if len(unreachable_hosts) > 0: + return 3 except errors.AnsibleError, e: display("ERROR: %s" % e, color='red')