mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 21:44:00 -07:00 
			
		
		
		
	Fix issue with vNIC redundancy templates (#36608)
* Fix bug with redundancy templates and add integration tests for redundancy templates. * vlan_list absent state support and fix for vlans as strings in vlan_list
This commit is contained in:
		
					parent
					
						
							
								f28cf6e8e9
							
						
					
				
			
			
				commit
				
					
						f8f22f77ed
					
				
			
		
					 2 changed files with 172 additions and 25 deletions
				
			
		|  | @ -93,6 +93,11 @@ options: | |||
|     - "  Designates the VLAN as a native VLAN.  Only one VLAN in the list can be a native VLAN." | ||||
|     - "  [choices: 'no', 'yes']" | ||||
|     - "  [Default: 'no']" | ||||
|     - "- state" | ||||
|     - "  If present, will verify VLAN is present on template." | ||||
|     - "  If absent, will verify VLAN is absent on template." | ||||
|     - "  choices: [present, absent]" | ||||
|     - "  default: present" | ||||
|   cdn_source: | ||||
|     description: | ||||
|     - CDN Source field. | ||||
|  | @ -161,7 +166,7 @@ EXAMPLES = r''' | |||
|     vlans_list: | ||||
|     - name: default | ||||
|       native: 'yes' | ||||
|     - name: finance | ||||
|       state: present | ||||
| 
 | ||||
| - name: Remove vNIC template | ||||
|   ucs_vnic_template: | ||||
|  | @ -178,6 +183,18 @@ EXAMPLES = r''' | |||
|     password: password | ||||
|     name: vNIC-A-B | ||||
|     state: absent | ||||
| 
 | ||||
| - name: Remove VLAN from template | ||||
|   ucs_vnic_template: | ||||
|     hostname: 172.16.143.150 | ||||
|     username: admin | ||||
|     password: password | ||||
|     name: vNIC-A-B | ||||
|     fabric: A-B | ||||
|     vlans_list: | ||||
|     - name: default | ||||
|       native: 'yes' | ||||
|       state: absent | ||||
| ''' | ||||
| 
 | ||||
| RETURN = r''' | ||||
|  | @ -250,6 +267,8 @@ def main(): | |||
|                 for vlan in module.params['vlans_list']: | ||||
|                     if not vlan.get('native'): | ||||
|                         vlan['native'] = 'no' | ||||
|                     if not vlan.get('state'): | ||||
|                         vlan['state'] = 'present' | ||||
|             # for target 'adapter', change to internal UCS Manager spelling 'adaptor' | ||||
|             if module.params['target'] == 'adapter': | ||||
|                 module.params['target'] = 'adaptor' | ||||
|  | @ -271,19 +290,27 @@ def main(): | |||
|                     kwargs['nw_ctrl_policy_name'] = module.params['network_control_policy'] | ||||
|                     kwargs['pin_to_group_name'] = module.params['pin_group'] | ||||
|                     kwargs['stats_policy_name'] = module.params['stats_policy'] | ||||
|                 if (mo.check_prop_match(**kwargs)): | ||||
|                 if mo.check_prop_match(**kwargs): | ||||
|                     # top-level props match, check next level mo/props | ||||
|                     if not module.params.get('vlans_list'): | ||||
|                         props_match = True | ||||
|                     else: | ||||
|                         # check vlan props | ||||
|                         for vlan in module.params['vlans_list']: | ||||
|                             child_dn = dn + '/if-' + vlan['name'] | ||||
|                             child_dn = dn + '/if-' + str(vlan['name']) | ||||
|                             mo_1 = ucs.login_handle.query_dn(child_dn) | ||||
|                             if mo_1: | ||||
|                                 kwargs = dict(default_net=vlan['native']) | ||||
|                                 if (mo_1.check_prop_match(**kwargs)): | ||||
|                                     props_match = True | ||||
|                             if vlan['state'] == 'absent': | ||||
|                                 if mo_1: | ||||
|                                     props_match = False | ||||
|                                     break | ||||
|                             else: | ||||
|                                 if mo_1: | ||||
|                                     kwargs = dict(default_net=vlan['native']) | ||||
|                                     if mo_1.check_prop_match(**kwargs): | ||||
|                                         props_match = True | ||||
|                                 else: | ||||
|                                     props_match = False | ||||
|                                     break | ||||
| 
 | ||||
|             if not props_match: | ||||
|                 if not module.check_mode: | ||||
|  | @ -306,7 +333,7 @@ def main(): | |||
|                             descr=module.params['description'], | ||||
|                             switch_id=module.params['fabric'], | ||||
|                             redundancy_pair_type=module.params['redundancy_type'], | ||||
|                             peer_redundancy_templ_name=module.params['peer_redundancy_templ'], | ||||
|                             peer_redundancy_templ_name=module.params['peer_redundancy_template'], | ||||
|                             target=module.params['target'], | ||||
|                             templ_type=module.params['template_type'], | ||||
|                             cdn_source=module.params['cdn_source'], | ||||
|  | @ -321,11 +348,16 @@ def main(): | |||
| 
 | ||||
|                     if module.params.get('vlans_list'): | ||||
|                         for vlan in module.params['vlans_list']: | ||||
|                             mo_1 = VnicEtherIf( | ||||
|                                 parent_mo_or_dn=mo, | ||||
|                                 name=vlan['name'], | ||||
|                                 default_net=vlan['native'], | ||||
|                             ) | ||||
|                             if vlan['state'] == 'absent': | ||||
|                                 child_dn = dn + '/if-' + str(vlan['name']) | ||||
|                                 mo_1 = ucs.login_handle.query_dn(child_dn) | ||||
|                                 ucs.login_handle.remove_mo(mo_1) | ||||
|                             else: | ||||
|                                 mo_1 = VnicEtherIf( | ||||
|                                     parent_mo_or_dn=mo, | ||||
|                                     name=str(vlan['name']), | ||||
|                                     default_net=vlan['native'], | ||||
|                                 ) | ||||
| 
 | ||||
|                     ucs.login_handle.add_mo(mo, True) | ||||
|                     ucs.login_handle.commit() | ||||
|  |  | |||
|  | @ -19,6 +19,18 @@ | |||
|     name: vNIC-A-B | ||||
|     state: absent | ||||
| 
 | ||||
| - name: vNIC primary template absent | ||||
|   ucs_vnic_template: &vnic_primary_templates_absent | ||||
|     <<: *login_info | ||||
|     name: vNIC-A | ||||
|     state: absent | ||||
| 
 | ||||
| - name: vNIC secondary template absent | ||||
|   ucs_vnic_template: &vnic_secondary_templates_absent | ||||
|     <<: *login_info | ||||
|     name: vNIC-B | ||||
|     state: absent | ||||
| 
 | ||||
| 
 | ||||
| # Test present (check_mode) | ||||
| - name: vNIC template present (check_mode) | ||||
|  | @ -29,16 +41,53 @@ | |||
|     vlans_list: | ||||
|     - name: default | ||||
|       native: 'yes' | ||||
|     - name: finance | ||||
|     - name: 10 | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_templates_present | ||||
| 
 | ||||
| - name: vNIC primary template present (check_mode) | ||||
|   ucs_vnic_template: &vnic_primary_templates_present | ||||
|     <<: *login_info | ||||
|     name: vNIC-A | ||||
|     fabric: A | ||||
|     redundancy_type: primary | ||||
|     peer_redundancy_templ: vNIC-B | ||||
|     template_type: updating-template | ||||
|     mtu: '9000' | ||||
|     mac_pool: MAC-Pool-A | ||||
|     network_control_policy: Enable-CDP-LLDP | ||||
|     vlans_list: | ||||
|     - name: default | ||||
|       native: 'yes' | ||||
|     - name: finance | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_primary_templates_present | ||||
| 
 | ||||
| - name: vNIC secondary template present (check_mode) | ||||
|   ucs_vnic_template: &vnic_secondary_templates_present | ||||
|     <<: *login_info | ||||
|     name: vNIC-B | ||||
|     fabric: B | ||||
|     redundancy_type: secondary | ||||
|     peer_redundancy_templ: vNIC-A | ||||
|     mac_pool: MAC-Pool-B | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_secondary_templates_present | ||||
| 
 | ||||
| 
 | ||||
| # Present (normal mode) | ||||
| - name: vNIC template present (normal mode) | ||||
|   ucs_vnic_template: *vnic_templates_present | ||||
|   register: nm_vnic_templates_present | ||||
| 
 | ||||
| - name: vNIC primary template present (normal mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_present | ||||
|   register: nm_vnic_primary_templates_present | ||||
| 
 | ||||
| - name: vNIC secondary template present (normal mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_present | ||||
|   register: nm_vnic_secondary_templates_present | ||||
| 
 | ||||
| 
 | ||||
| # Test present again (idempotent) | ||||
| - name: vNIC template present again (check_mode) | ||||
|  | @ -46,12 +95,30 @@ | |||
|   check_mode: yes | ||||
|   register: cm_vnic_templates_present_again | ||||
| 
 | ||||
| - name: vNIC primary template present again (check_mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_present | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_primary_templates_present_again | ||||
| 
 | ||||
| - name: vNIC secondary template present again (check_mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_present | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_secondary_templates_present_again | ||||
| 
 | ||||
| 
 | ||||
| # Present again (normal mode) | ||||
| - name: vNIC template present again (normal mode) | ||||
|   ucs_vnic_template: *vnic_templates_present | ||||
|   register: nm_vnic_templates_present_again | ||||
| 
 | ||||
| - name: vNIC primary template present again (normal mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_present | ||||
|   register: nm_vnic_primary_templates_present_again | ||||
| 
 | ||||
| - name: vNIC secondary template present again (normal mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_present | ||||
|   register: nm_vnic_secondary_templates_present_again | ||||
| 
 | ||||
| 
 | ||||
| # Verfiy present | ||||
| - name: Verify vNIC template present results | ||||
|  | @ -59,42 +126,50 @@ | |||
|     that: | ||||
|     - cm_vnic_templates_present.changed == nm_vnic_templates_present.changed == true | ||||
|     - cm_vnic_templates_present_again.changed == nm_vnic_templates_present_again.changed == false | ||||
|     - cm_vnic_primary_templates_present.changed == nm_vnic_primary_templates_present.changed == true | ||||
|     - cm_vnic_primary_templates_present_again.changed == nm_vnic_primary_templates_present_again.changed == false | ||||
|     - cm_vnic_secondary_templates_present.changed == nm_vnic_secondary_templates_present.changed == true | ||||
|     - cm_vnic_secondary_templates_present_again.changed == nm_vnic_secondary_templates_present_again.changed == false | ||||
| 
 | ||||
| 
 | ||||
| # Test change (check_mode) | ||||
| - name: vNIC template description change (check_mode) | ||||
| - name: vNIC template change (check_mode) | ||||
|   ucs_vnic_template: &vnic_templates_change | ||||
|     <<: *vnic_templates_present | ||||
|     descr: Testing Ansible | ||||
|     vlans_list: | ||||
|     - name: default | ||||
|       native: 'yes' | ||||
|     - name: 10 | ||||
|       state: absent | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_templates_descr_change | ||||
|   register: cm_vnic_templates_change | ||||
| 
 | ||||
| 
 | ||||
| # Change (normal mode) | ||||
| - name: vNIC template description change (normal mode) | ||||
| - name: vNIC template change (normal mode) | ||||
|   ucs_vnic_template: *vnic_templates_change | ||||
|   register: nm_vnic_templates_descr_change | ||||
|   register: nm_vnic_templates_change | ||||
| 
 | ||||
| 
 | ||||
| # Test change again (idempotent) | ||||
| - name: vNIC template description again (check_mode) | ||||
| - name: vNIC template change again (check_mode) | ||||
|   ucs_vnic_template: *vnic_templates_change | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_templates_descr_change_again | ||||
|   register: cm_vnic_templates_change_again | ||||
| 
 | ||||
| 
 | ||||
| # Change again (normal mode) | ||||
| - name: vNIC template description change again (normal mode) | ||||
| - name: vNIC template change again (normal mode) | ||||
|   ucs_vnic_template: *vnic_templates_change | ||||
|   register: nm_vnic_templates_descr_change_again | ||||
|   register: nm_vnic_templates_change_again | ||||
| 
 | ||||
| 
 | ||||
| # Verfiy change | ||||
| - name: Verify vNIC template change results | ||||
|   assert: | ||||
|     that: | ||||
|     - cm_vnic_templates_descr_change.changed == nm_vnic_templates_descr_change.changed == true | ||||
|     - cm_vnic_templates_descr_change_again.changed == nm_vnic_templates_descr_change_again.changed == false | ||||
|     - cm_vnic_templates_change.changed == nm_vnic_templates_change.changed == true | ||||
|     - cm_vnic_templates_change_again.changed == nm_vnic_templates_change_again.changed == false | ||||
| 
 | ||||
| 
 | ||||
| # Teardown (clean environment) | ||||
|  | @ -103,12 +178,30 @@ | |||
|   check_mode: yes | ||||
|   register: cm_vnic_templates_absent | ||||
| 
 | ||||
| - name: vNIC primary template absent (check_mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_absent | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_primary_templates_absent | ||||
| 
 | ||||
| - name: vNIC secondary template absent (check_mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_absent | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_secondary_templates_absent | ||||
| 
 | ||||
| 
 | ||||
| # Absent (normal mode) | ||||
| - name: vNIC template absent (normal mode) | ||||
|   ucs_vnic_template: *vnic_templates_absent | ||||
|   register: nm_vnic_templates_absent | ||||
| 
 | ||||
| - name: vNIC primary template absent (normal mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_absent | ||||
|   register: nm_vnic_primary_templates_absent | ||||
| 
 | ||||
| - name: vNIC secondary template absent (normal mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_absent | ||||
|   register: nm_vnic_secondary_templates_absent | ||||
| 
 | ||||
| 
 | ||||
| # Test absent again (idempotent) | ||||
| - name: vNIC template absent again (check_mode) | ||||
|  | @ -116,12 +209,30 @@ | |||
|   check_mode: yes | ||||
|   register: cm_vnic_templates_absent_again | ||||
| 
 | ||||
| - name: vNIC primary template absent again (check_mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_absent | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_primary_templates_absent_again | ||||
| 
 | ||||
| - name: vNIC secondary template absent again (check_mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_absent | ||||
|   check_mode: yes | ||||
|   register: cm_vnic_secondary_templates_absent_again | ||||
| 
 | ||||
| 
 | ||||
| # Absent again (normal mode) | ||||
| - name: vNIC template absent again (normal mode) | ||||
|   ucs_vnic_template: *vnic_templates_absent | ||||
|   register: nm_vnic_templates_absent_again | ||||
| 
 | ||||
| - name: vNIC primary template absent again (normal mode) | ||||
|   ucs_vnic_template: *vnic_primary_templates_absent | ||||
|   register: nm_vnic_primary_templates_absent_again | ||||
| 
 | ||||
| - name: vNIC secondary template absent again (normal mode) | ||||
|   ucs_vnic_template: *vnic_secondary_templates_absent | ||||
|   register: nm_vnic_secondary_templates_absent_again | ||||
| 
 | ||||
| 
 | ||||
| # Verfiy absent | ||||
| - name: Verify vNIC template absent results | ||||
|  | @ -129,3 +240,7 @@ | |||
|     that: | ||||
|     - cm_vnic_templates_absent.changed == nm_vnic_templates_absent.changed == true | ||||
|     - cm_vnic_templates_absent_again.changed == nm_vnic_templates_absent_again.changed == false | ||||
|     - cm_vnic_primary_templates_absent.changed == nm_vnic_primary_templates_absent.changed == true | ||||
|     - cm_vnic_primary_templates_absent_again.changed == nm_vnic_primary_templates_absent_again.changed == false | ||||
|     - cm_vnic_secondary_templates_absent.changed == nm_vnic_secondary_templates_absent.changed == true | ||||
|     - cm_vnic_secondary_templates_absent_again.changed == nm_vnic_secondary_templates_absent_again.changed == false | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue