mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 13:04:00 -07:00 
			
		
		
		
	add support of nested groups in group_by
This commit is contained in:
		
					parent
					
						
							
								7351ee9a76
							
						
					
				
			
			
				commit
				
					
						0fb64214a4
					
				
			
		
					 4 changed files with 46 additions and 6 deletions
				
			
		|  | @ -33,6 +33,12 @@ options: | ||||||
|     description: |     description: | ||||||
|     - The variables whose values will be used as groups |     - The variables whose values will be used as groups | ||||||
|     required: true |     required: true | ||||||
|  |   parents: | ||||||
|  |     description: | ||||||
|  |     - The list of the parent groups | ||||||
|  |     required: false | ||||||
|  |     default: "all" | ||||||
|  |     version_added: "2.4" | ||||||
| author: "Jeroen Hoekx (@jhoekx)" | author: "Jeroen Hoekx (@jhoekx)" | ||||||
| notes: | notes: | ||||||
|   - Spaces in group names are converted to dashes '-'. |   - Spaces in group names are converted to dashes '-'. | ||||||
|  | @ -47,4 +53,11 @@ EXAMPLES = ''' | ||||||
| # Create groups like 'kvm-host' | # Create groups like 'kvm-host' | ||||||
| - group_by: | - group_by: | ||||||
|     key: virt_{{ ansible_virtualization_type }}_{{ ansible_virtualization_role }} |     key: virt_{{ ansible_virtualization_type }}_{{ ansible_virtualization_role }} | ||||||
|  | 
 | ||||||
|  | # Create nested groups | ||||||
|  | - group_by: | ||||||
|  |     key: el{{ ansible_distribution_major_version }}-{{ ansible_architecture }} | ||||||
|  |     parents: | ||||||
|  |       - el{{ ansible_distribution_major_version }} | ||||||
|  | 
 | ||||||
| ''' | ''' | ||||||
|  |  | ||||||
|  | @ -18,6 +18,7 @@ from __future__ import (absolute_import, division, print_function) | ||||||
| __metaclass__ = type | __metaclass__ = type | ||||||
| 
 | 
 | ||||||
| from ansible.plugins.action import ActionBase | from ansible.plugins.action import ActionBase | ||||||
|  | from ansible.module_utils.six import string_types | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class ActionModule(ActionBase): | class ActionModule(ActionBase): | ||||||
|  | @ -38,8 +39,11 @@ class ActionModule(ActionBase): | ||||||
|             return result |             return result | ||||||
| 
 | 
 | ||||||
|         group_name = self._task.args.get('key') |         group_name = self._task.args.get('key') | ||||||
|         group_name = group_name.replace(' ', '-') |         parent_groups = self._task.args.get('parents', ['all']) | ||||||
|  |         if isinstance(parent_groups, string_types): | ||||||
|  |             parent_groups = [parent_groups] | ||||||
| 
 | 
 | ||||||
|         result['changed'] = False |         result['changed'] = False | ||||||
|         result['add_group'] = group_name |         result['add_group'] = group_name.replace(' ', '-') | ||||||
|  |         result['parent_groups'] = [name.replace(' ', '-') for name in parent_groups] | ||||||
|         return result |         return result | ||||||
|  |  | ||||||
|  | @ -632,12 +632,17 @@ class StrategyBase: | ||||||
|         # host object from the master inventory |         # host object from the master inventory | ||||||
|         real_host = self._inventory.hosts[host.name] |         real_host = self._inventory.hosts[host.name] | ||||||
|         group_name = result_item.get('add_group') |         group_name = result_item.get('add_group') | ||||||
|  |         parent_group_names = result_item.get('parent_groups', []) | ||||||
| 
 | 
 | ||||||
|         if group_name not in self._inventory.groups: |         for name in [group_name] + parent_group_names: | ||||||
|             # create the new group and add it to inventory |             if name not in self._inventory.groups: | ||||||
|             self._inventory.add_group(group_name) |                 # create the new group and add it to inventory | ||||||
|             changed = True |                 self._inventory.add_group(name) | ||||||
|  |                 changed = True | ||||||
|         group = self._inventory.groups[group_name] |         group = self._inventory.groups[group_name] | ||||||
|  |         for parent_group_name in parent_group_names: | ||||||
|  |             parent_group = self._inventory.groups[parent_group_name] | ||||||
|  |             parent_group.add_child_group(group) | ||||||
| 
 | 
 | ||||||
|         if real_host.name not in group.get_hosts(): |         if real_host.name not in group.get_hosts(): | ||||||
|             group.add_host(real_host) |             group.add_host(real_host) | ||||||
|  |  | ||||||
|  | @ -185,3 +185,21 @@ | ||||||
|   tasks: |   tasks: | ||||||
|     - name: check group_vars variable overrides for camelus |     - name: check group_vars variable overrides for camelus | ||||||
|       assert: { that: ["uno == 1", "dos == 'two'", "tres == 3"] } |       assert: { that: ["uno == 1", "dos == 'two'", "tres == 3"] } | ||||||
|  | 
 | ||||||
|  | - name: Nested group validation | ||||||
|  |   hosts: lama | ||||||
|  |   gather_facts: false | ||||||
|  |   tasks: | ||||||
|  |     - name: group by genus with parent | ||||||
|  |       group_by: key=vicugna-{{ genus }} parents=vicugna | ||||||
|  |     - name: check group_vars variable overrides for vicugna-lama | ||||||
|  |       assert: { that: ["uno == 1", "dos == 2", "tres == 'three'"] } | ||||||
|  | 
 | ||||||
|  |     - name: group by genus with nonexistent parent | ||||||
|  |       group_by: | ||||||
|  |         key: "{{ genus }}" | ||||||
|  |         parents: | ||||||
|  |           - oxydactylus | ||||||
|  |           - stenomylus | ||||||
|  |     - name: check parent groups | ||||||
|  |       assert: { that: ["'oxydactylus' in group_names", "'stenomylus' in group_names"] } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue