mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 13:34:01 -07:00 
			
		
		
		
	Two fixes to action plugins
* Fix the task_vars parameter to not default to a mutable type (dict) * Implement invocation in the base class's run() method have each action module call the run() method's implemention in the base class. * Return values from the action plugins' run() method takes the return value from the base class run() method into account so that invocation makes its way to the output. Fixes #12869
This commit is contained in:
		
					parent
					
						
							
								75cff7129c
							
						
					
				
			
			
				commit
				
					
						2e87c1f74e
					
				
			
		
					 27 changed files with 387 additions and 179 deletions
				
			
		|  | @ -21,14 +21,19 @@ from ansible.errors import AnsibleError | |||
| from ansible.playbook.conditional import Conditional | ||||
| from ansible.plugins.action import ActionBase | ||||
| 
 | ||||
| 
 | ||||
| class ActionModule(ActionBase): | ||||
|     ''' Fail with custom message ''' | ||||
| 
 | ||||
|     TRANSFERS_FILES = False | ||||
| 
 | ||||
|     def run(self, tmp=None, task_vars=dict()): | ||||
|     def run(self, tmp=None, task_vars=None): | ||||
|         if task_vars is None: | ||||
|             task_vars = dict() | ||||
| 
 | ||||
|         if not 'that' in self._task.args: | ||||
|         result = super(ActionModule, self).run(tmp, task_vars) | ||||
| 
 | ||||
|         if 'that' not in self._task.args: | ||||
|             raise AnsibleError('conditional required in "that" string') | ||||
| 
 | ||||
|         msg = None | ||||
|  | @ -38,7 +43,7 @@ class ActionModule(ActionBase): | |||
|         # make sure the 'that' items are a list | ||||
|         thats = self._task.args['that'] | ||||
|         if not isinstance(thats, list): | ||||
|             thats = [ thats ] | ||||
|             thats = [thats] | ||||
| 
 | ||||
|         # Now we iterate over the that items, temporarily assigning them | ||||
|         # to the task's when value so we can evaluate the conditional using | ||||
|  | @ -47,19 +52,18 @@ class ActionModule(ActionBase): | |||
|         # that value now | ||||
|         cond = Conditional(loader=self._loader) | ||||
|         for that in thats: | ||||
|             cond.when = [ that ] | ||||
|             cond.when = [that] | ||||
|             test_result = cond.evaluate_conditional(templar=self._templar, all_vars=task_vars) | ||||
|             if not test_result: | ||||
|                 result = dict( | ||||
|                    failed       = True, | ||||
|                    evaluated_to = test_result, | ||||
|                    assertion    = that, | ||||
|                 ) | ||||
|                 result['failed'] = True | ||||
|                 result['evaluated_to'] = test_result | ||||
|                 result['assertion'] = that | ||||
| 
 | ||||
|                 if msg: | ||||
|                     result['msg'] = msg | ||||
| 
 | ||||
|                 return result | ||||
| 
 | ||||
|         return dict(changed=False, msg='all assertions passed') | ||||
| 
 | ||||
|         result['changed'] = False | ||||
|         result['msg'] = 'all assertions passed' | ||||
|         return result | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue