diff --git a/v2/ansible/executor/playbook_executor.py b/v2/ansible/executor/playbook_executor.py index 97232cefe8..bab6ea4e05 100644 --- a/v2/ansible/executor/playbook_executor.py +++ b/v2/ansible/executor/playbook_executor.py @@ -162,10 +162,11 @@ class PlaybookExecutor: return serialized_batches - def listhosts(self): + def list_hosts_per_play(self): playlist = [] try: + i = 1 for playbook_path in self._playbooks: pb = Playbook.load(playbook_path, variable_manager=self._variable_manager, loader=self._loader) for play in pb.get_entries(): @@ -175,10 +176,21 @@ class PlaybookExecutor: new_play = play.copy() new_play.post_validate(all_vars, fail_on_undefined=False) - playlist.append(set(self._inventory.get_hosts(new_play.hosts))) + pname = play.get_name().strip() + if pname == 'PLAY: ': + pname = 'play #%d' % i + + playlist.append( { + 'name': pname, + 'pattern': play.hosts, + 'hosts': set(self._inventory.get_hosts(new_play.hosts)), + } ) + i = i + 1 + except AnsibleError: raise except Exception, e: + #TODO: log exception raise AnsibleParserError("Failed to process plays: %s" % str(e)) return playlist diff --git a/v2/bin/ansible-playbook b/v2/bin/ansible-playbook index c1ee70d059..4dc6d6bad9 100755 --- a/v2/bin/ansible-playbook +++ b/v2/bin/ansible-playbook @@ -135,12 +135,10 @@ def main(args): pbex = PlaybookExecutor(playbooks=args, inventory=inventory, variable_manager=variable_manager, loader=loader, display=display, options=options) if options.listhosts: - i = 1 - for play in pbex.listhosts(): - print("\nplay #%d" % i) - for host in sorted(play): + for p in pbex.list_hosts_per_play(): + print("\n %s (%s): host count=%d" % (p['name'], p['pattern'], len(p['hosts']))) + for host in p['hosts']: print(" %s" % host) - i = i + 1 sys.exit(0) elif options.listtasks: print('TODO: implement')