mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2024-09-14 20:13:21 +02:00 
			
		
		
		
	implement --start-at-task option to hop to a specific task before starting running them
This commit is contained in:
		
							parent
							
								
									586ee923a6
								
							
						
					
					
						commit
						690738ea32
					
				
					 2 changed files with 13 additions and 1 deletions
				
			
		|  | @ -74,6 +74,8 @@ def main(args): | |||
|         help="do list all tasks that would be executed") | ||||
|     parser.add_option('--step', dest='step', action='store_true', | ||||
|         help="one-step-at-a-time: confirm each task before running") | ||||
|     parser.add_option('--start-at-task', dest='start_at',  | ||||
|         help="start the playbook with a task matching this name") | ||||
| 
 | ||||
|     options, args = parser.parse_args(args) | ||||
| 
 | ||||
|  | @ -115,6 +117,8 @@ def main(args): | |||
|         playbook_cb = callbacks.PlaybookCallbacks(verbose=utils.VERBOSITY) | ||||
|         if options.step: | ||||
|             playbook_cb.step = options.step | ||||
|         if options.start_at: | ||||
|             playbook_cb.start_at = options.start_at | ||||
|         runner_cb = callbacks.PlaybookRunnerCallbacks(stats, verbose=utils.VERBOSITY) | ||||
| 
 | ||||
|         pb = ansible.playbook.PlayBook( | ||||
|  |  | |||
|  | @ -21,6 +21,7 @@ import getpass | |||
| import os | ||||
| import subprocess | ||||
| import random | ||||
| import fnmatch | ||||
| from ansible.color import stringc | ||||
| 
 | ||||
| cowsay = None | ||||
|  | @ -460,8 +461,15 @@ class PlaybookCallbacks(object): | |||
|         msg = "TASK: [%s]" % name | ||||
|         if is_conditional: | ||||
|             msg = "NOTIFIED: [%s]" % name | ||||
|          | ||||
|         if hasattr(self, 'start_at'): | ||||
|             if name == self.start_at or fnmatch.fnmatch(name, self.start_at): | ||||
|                 # we found out match, we can get rid of this now | ||||
|                 del self.start_at | ||||
| 
 | ||||
|         if hasattr(self, 'step') and self.step: | ||||
|         if hasattr(self, 'start_at'): # we still have start_at so skip the task | ||||
|             self.skip_task = True | ||||
|         elif hasattr(self, 'step') and self.step: | ||||
|             resp = raw_input('Perform task: %s (y/n/c): ' % name) | ||||
|             if resp.lower() in ['y','yes']: | ||||
|                 self.skip_task = False | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue