mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 21:44:00 -07:00 
			
		
		
		
	Warn if empty string is present in synchronize's rsync_opts
This commit is contained in:
		
					parent
					
						
							
								caa6ed3c66
							
						
					
				
			
			
				commit
				
					
						a8fbfe1844
					
				
			
		
					 2 changed files with 13 additions and 3 deletions
				
			
		
							
								
								
									
										4
									
								
								changelogs/fragments/synchronize-warning.yaml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								changelogs/fragments/synchronize-warning.yaml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | |||
| --- | ||||
| minor_changes: | ||||
| - synchronize module - Warn when the empty string is present in rsync_opts as it is likely | ||||
|   unexpected that it will transfer the current working directory. | ||||
|  | @ -132,7 +132,8 @@ options: | |||
|     version_added: "2.0" | ||||
|   rsync_opts: | ||||
|     description: | ||||
|       - Specify additional rsync options by passing in an array. | ||||
|       - Specify additional rsync options by passing in an array.  Note that an empty string in | ||||
|         C(rsync_opts) will end up transfer the current working directory. | ||||
|     default: | ||||
|     version_added: "1.6" | ||||
|   partial: | ||||
|  | @ -519,6 +520,11 @@ def main(): | |||
|         cmd.append('--rsync-path=%s' % rsync_path) | ||||
| 
 | ||||
|     if rsync_opts: | ||||
|         if '' in rsync_opts: | ||||
|             module.warn('The empty string is present in rsync_opts which will cause rsync to' | ||||
|                         ' transfer the current working directory. If this is intended, use "."' | ||||
|                         ' instead to get rid of this warning. If this is unintended, check for' | ||||
|                         ' problems in your playbook leading to empty string in rsync_opts.') | ||||
|         cmd.extend(rsync_opts) | ||||
| 
 | ||||
|     if partial: | ||||
|  | @ -559,10 +565,10 @@ def main(): | |||
|                 # Ignore broken pipe errors if the sshpass process has exited. | ||||
|                 if exc.errno != errno.EPIPE or proc.poll() is None: | ||||
|                     raise | ||||
| 
 | ||||
|         (rc, out, err) = module.run_command( | ||||
|             cmd, pass_fds=_sshpass_pipe, | ||||
|             before_communicate_callback=_write_password_to_pipe | ||||
|         ) | ||||
|             before_communicate_callback=_write_password_to_pipe) | ||||
|     else: | ||||
|         (rc, out, err) = module.run_command(cmd) | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue