mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	fix pim rp_address issues (#35248)
This commit is contained in:
		
					parent
					
						
							
								7fac5cd7d2
							
						
					
				
			
			
				commit
				
					
						0b30c42902
					
				
			
		
					 2 changed files with 200 additions and 66 deletions
				
			
		|  | @ -94,7 +94,7 @@ from ansible.module_utils.basic import AnsibleModule | ||||||
| from ansible.module_utils.network.common.config import CustomNetworkConfig | from ansible.module_utils.network.common.config import CustomNetworkConfig | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def get_existing(module, args): | def get_existing(module, args, gl): | ||||||
|     existing = {} |     existing = {} | ||||||
|     config = str(get_config(module)) |     config = str(get_config(module)) | ||||||
|     address = module.params['rp_address'] |     address = module.params['rp_address'] | ||||||
|  | @ -105,6 +105,11 @@ def get_existing(module, args): | ||||||
|         values = line.split() |         values = line.split() | ||||||
|         if values[0] != address: |         if values[0] != address: | ||||||
|             continue |             continue | ||||||
|  |         if gl and 'group-list' not in line: | ||||||
|  |             continue | ||||||
|  |         elif not gl and 'group-list' in line: | ||||||
|  |             if '224.0.0.0/4' not in line:  # ignore default group-list | ||||||
|  |                 continue | ||||||
| 
 | 
 | ||||||
|         existing['bidir'] = existing.get('bidir') or 'bidir' in line |         existing['bidir'] = existing.get('bidir') or 'bidir' in line | ||||||
|         if len(values) > 2: |         if len(values) > 2: | ||||||
|  | @ -114,7 +119,8 @@ def get_existing(module, args): | ||||||
|             elif values[1] == 'prefix-list': |             elif values[1] == 'prefix-list': | ||||||
|                 existing['prefix_list'] = value |                 existing['prefix_list'] = value | ||||||
|             elif values[1] == 'group-list': |             elif values[1] == 'group-list': | ||||||
|                 existing['group_list'] = value |                 if value != '224.0.0.0/4':  # ignore default group-list | ||||||
|  |                     existing['group_list'] = value | ||||||
| 
 | 
 | ||||||
|     return existing |     return existing | ||||||
| 
 | 
 | ||||||
|  | @ -122,6 +128,14 @@ def get_existing(module, args): | ||||||
| def state_present(module, existing, proposed, candidate): | def state_present(module, existing, proposed, candidate): | ||||||
|     address = module.params['rp_address'] |     address = module.params['rp_address'] | ||||||
|     command = 'ip pim rp-address {0}'.format(address) |     command = 'ip pim rp-address {0}'.format(address) | ||||||
|  |     if module.params['group_list'] and not proposed.get('group_list'): | ||||||
|  |         command += ' group-list ' + module.params['group_list'] | ||||||
|  |     if module.params['prefix_list']: | ||||||
|  |         if not proposed.get('prefix_list'): | ||||||
|  |             command += ' prefix-list ' + module.params['prefix_list'] | ||||||
|  |     if module.params['route_map']: | ||||||
|  |         if not proposed.get('route_map'): | ||||||
|  |             command += ' route-map ' + module.params['route_map'] | ||||||
|     commands = build_command(proposed, command) |     commands = build_command(proposed, command) | ||||||
|     if commands: |     if commands: | ||||||
|         candidate.add(commands, parents=[]) |         candidate.add(commands, parents=[]) | ||||||
|  | @ -140,13 +154,31 @@ def build_command(param_dict, command): | ||||||
| def state_absent(module, existing, candidate): | def state_absent(module, existing, candidate): | ||||||
|     address = module.params['rp_address'] |     address = module.params['rp_address'] | ||||||
| 
 | 
 | ||||||
|  |     commands = [] | ||||||
|     command = 'no ip pim rp-address {0}'.format(address) |     command = 'no ip pim rp-address {0}'.format(address) | ||||||
|     if existing.get('group_list'): |     if module.params['group_list'] == existing.get('group_list'): | ||||||
|         commands = build_command(existing, command) |         commands = build_command(existing, command) | ||||||
|     else: |     elif not module.params['group_list']: | ||||||
|         commands = [command] |         commands = [command] | ||||||
| 
 | 
 | ||||||
|     candidate.add(commands, parents=[]) |     if commands: | ||||||
|  |         candidate.add(commands, parents=[]) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def get_proposed(pargs, existing): | ||||||
|  |     proposed = {} | ||||||
|  | 
 | ||||||
|  |     for key, value in pargs.items(): | ||||||
|  |         if key != 'rp_address': | ||||||
|  |             if str(value).lower() == 'true': | ||||||
|  |                 value = True | ||||||
|  |             elif str(value).lower() == 'false': | ||||||
|  |                 value = False | ||||||
|  | 
 | ||||||
|  |             if existing.get(key) != value: | ||||||
|  |                 proposed[key] = value | ||||||
|  | 
 | ||||||
|  |     return proposed | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def main(): | def main(): | ||||||
|  | @ -180,20 +212,16 @@ def main(): | ||||||
|         'bidir' |         'bidir' | ||||||
|     ] |     ] | ||||||
| 
 | 
 | ||||||
|     existing = get_existing(module, args) |  | ||||||
|     proposed_args = dict((k, v) for k, v in module.params.items() |     proposed_args = dict((k, v) for k, v in module.params.items() | ||||||
|                          if v is not None and k in args) |                          if v is not None and k in args) | ||||||
| 
 | 
 | ||||||
|     proposed = {} |     if module.params['group_list']: | ||||||
|     for key, value in proposed_args.items(): |         existing = get_existing(module, args, True) | ||||||
|         if key != 'rp_address': |         proposed = get_proposed(proposed_args, existing) | ||||||
|             if str(value).lower() == 'true': |  | ||||||
|                 value = True |  | ||||||
|             elif str(value).lower() == 'false': |  | ||||||
|                 value = False |  | ||||||
| 
 | 
 | ||||||
|             if existing.get(key) != value: |     else: | ||||||
|                 proposed[key] = value |         existing = get_existing(module, args, False) | ||||||
|  |         proposed = get_proposed(proposed_args, existing) | ||||||
| 
 | 
 | ||||||
|     candidate = CustomNetworkConfig(indent=3) |     candidate = CustomNetworkConfig(indent=3) | ||||||
|     if state == 'present' and (proposed or not existing): |     if state == 'present' and (proposed or not existing): | ||||||
|  | @ -205,7 +233,19 @@ def main(): | ||||||
|         candidate = candidate.items_text() |         candidate = candidate.items_text() | ||||||
|         result['commands'] = candidate |         result['commands'] = candidate | ||||||
|         result['changed'] = True |         result['changed'] = True | ||||||
|         load_config(module, candidate) |         msgs = load_config(module, candidate, True) | ||||||
|  |         if msgs: | ||||||
|  |             for item in msgs: | ||||||
|  |                 if item: | ||||||
|  |                     if isinstance(item, dict): | ||||||
|  |                         err_str = item['clierror'] | ||||||
|  |                     else: | ||||||
|  |                         err_str = item | ||||||
|  |                     if 'No policy was configured' in err_str: | ||||||
|  |                         if state == 'absent': | ||||||
|  |                             addr = module.params['rp_address'] | ||||||
|  |                             new_cmd = 'no ip pim rp-address {0}'.format(addr) | ||||||
|  |                             load_config(module, new_cmd) | ||||||
| 
 | 
 | ||||||
|     module.exit_json(**result) |     module.exit_json(**result) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,13 +3,6 @@ | ||||||
| - debug: msg="Using provider={{ connection.transport }}" | - debug: msg="Using provider={{ connection.transport }}" | ||||||
|   when: ansible_connection == "local" |   when: ansible_connection == "local" | ||||||
| 
 | 
 | ||||||
| - set_fact: bidir="false"  |  | ||||||
|   when: platform is search('N3K') |  | ||||||
| 
 |  | ||||||
| - set_fact: bidircfg='bidir' |  | ||||||
| - set_fact: bidircfg='' |  | ||||||
|   when: platform is search('N3K') |  | ||||||
| 
 |  | ||||||
| - block: | - block: | ||||||
|   - name: "Disable feature PIM" |   - name: "Disable feature PIM" | ||||||
|     nxos_feature: &disable_feature |     nxos_feature: &disable_feature | ||||||
|  | @ -27,7 +20,7 @@ | ||||||
|     nxos_pim_rp_address: &configgl |     nxos_pim_rp_address: &configgl | ||||||
|       rp_address: "10.1.1.20" |       rp_address: "10.1.1.20" | ||||||
|       group_list: "224.0.0.0/8" |       group_list: "224.0.0.0/8" | ||||||
|       bidir: "{{bidir|default('true')}}" |       bidir: True | ||||||
|       state: present |       state: present | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     register: result |     register: result | ||||||
|  | @ -44,33 +37,108 @@ | ||||||
|       that: |       that: | ||||||
|         - "result.changed == false" |         - "result.changed == false" | ||||||
| 
 | 
 | ||||||
|   - name: Remove rp_address + group_list using long config |   - name: Configure rp_address + group_list remove bidir | ||||||
|     #FIXME: Config deletion shall be fixed in 2.5 for platform dependencies. |     nxos_pim_rp_address: &configglnb | ||||||
|      |       rp_address: "10.1.1.20" | ||||||
|     # Note: For 2.4 - Use platform specific config delete command as shown below. |       group_list: "224.0.0.0/8" | ||||||
|     # Possible options: Identify and use the command that is supported  |       bidir: False | ||||||
|     # by your platform under test. |       state: present | ||||||
| 
 |  | ||||||
|     # no ip pim rp-address <ip address> <group-list|prefix-list|route-map> bidir |  | ||||||
|     # no ip pim rp-address <ip address> |  | ||||||
|     # no ip pim rp-address <ip address> <group-list|prefix-list|route-map> |  | ||||||
| 
 |  | ||||||
|     nxos_config: |  | ||||||
|       lines: "no ip pim rp-address 10.1.1.20 group-list 224.0.0.0/8 {{ bidircfg }}"  |  | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     ignore_errors: yes |     register: result | ||||||
| 
 | 
 | ||||||
|   - name: Remove rp_address + group_list using short config |   - assert: *true | ||||||
|     nxos_config: | 
 | ||||||
|       lines: no ip pim rp-address 10.1.1.20 |   - name: Check idempotence rp_address + group_list remove bidir | ||||||
|  |     nxos_pim_rp_address: *configglnb | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Configure rp_address + bidir  | ||||||
|  |     nxos_pim_rp_address: &configbi | ||||||
|  |       rp_address: "10.1.1.20" | ||||||
|  |       bidir: True | ||||||
|  |       state: present | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     ignore_errors: yes |     register: result | ||||||
| 
 | 
 | ||||||
|   - name: Configure rp_address + prefix_list  |   - assert: *true | ||||||
|  | 
 | ||||||
|  |   - name: Check idempotence rp_address + bidir | ||||||
|  |     nxos_pim_rp_address: *configbi | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Configure rp_address remove bidir  | ||||||
|  |     nxos_pim_rp_address: &confignbi | ||||||
|  |       rp_address: "10.1.1.20" | ||||||
|  |       bidir: False | ||||||
|  |       state: present | ||||||
|  |       provider: "{{ connection }}" | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *true | ||||||
|  | 
 | ||||||
|  |   - name: Check idempotence rp_address remove bidir | ||||||
|  |     nxos_pim_rp_address: *confignbi | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Remove rp_address + group_list  | ||||||
|  |     nxos_pim_rp_address: &configglr | ||||||
|  |       rp_address: "10.1.1.20" | ||||||
|  |       group_list: "224.0.0.0/8" | ||||||
|  |       state: absent | ||||||
|  |       provider: "{{ connection }}" | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *true | ||||||
|  | 
 | ||||||
|  |   - name: Check remove idempotence rp_address + group_list | ||||||
|  |     nxos_pim_rp_address: *configglr | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Remove rp_address | ||||||
|  |     nxos_pim_rp_address: &configbir | ||||||
|  |       rp_address: "10.1.1.20" | ||||||
|  |       state: absent | ||||||
|  |       provider: "{{ connection }}" | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *true | ||||||
|  | 
 | ||||||
|  |   - name: Check remove idempotence rp_address | ||||||
|  |     nxos_pim_rp_address: *configbir | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Configure rp_address + prefix_list + bidir | ||||||
|     nxos_pim_rp_address: &configpl |     nxos_pim_rp_address: &configpl | ||||||
|       rp_address: "10.1.1.20" |       rp_address: "10.1.1.20" | ||||||
|       prefix_list: "pim_prefix_list" |       prefix_list: "pim_prefix_list" | ||||||
|       bidir: "{{bidir|default('true')}}" |       bidir: True | ||||||
|  |       state: present | ||||||
|  |       provider: "{{ connection }}" | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *true | ||||||
|  | 
 | ||||||
|  |   - name: Check idempotence rp_address + prefix_list + bidir | ||||||
|  |     nxos_pim_rp_address: *configpl | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Configure rp_address + prefix_list | ||||||
|  |     nxos_pim_rp_address: &configplnbi | ||||||
|  |       rp_address: "10.1.1.20" | ||||||
|  |       prefix_list: "pim_prefix_list" | ||||||
|  |       bidir: False | ||||||
|       state: present |       state: present | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     register: result |     register: result | ||||||
|  | @ -78,28 +146,50 @@ | ||||||
|   - assert: *true |   - assert: *true | ||||||
| 
 | 
 | ||||||
|   - name: Check idempotence rp_address + prefix_list |   - name: Check idempotence rp_address + prefix_list | ||||||
|     nxos_pim_rp_address: *configpl |     nxos_pim_rp_address: *configplnbi | ||||||
|     register: result |     register: result | ||||||
| 
 | 
 | ||||||
|   - assert: *false |   - assert: *false | ||||||
| 
 | 
 | ||||||
|   - name: Remove rp_address + prefix_list using long config |   - name: Remove rp_address + prefix_list  | ||||||
|     nxos_config: |     nxos_pim_rp_address: &configplr | ||||||
|       lines: "no ip pim rp-address 10.1.1.20 prefix-list pim_prefix_list {{ bidircfg }}" |       rp_address: "10.1.1.20" | ||||||
|  |       prefix_list: "pim_prefix_list" | ||||||
|  |       bidir: False | ||||||
|  |       state: absent | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     ignore_errors: yes |     register: result | ||||||
| 
 | 
 | ||||||
|   - name: Remove rp_address + prefix_list using short config |   - assert: *true | ||||||
|     nxos_config: |  | ||||||
|       lines: no ip pim rp-address 10.1.1.20 |  | ||||||
|       provider: "{{ connection }}" |  | ||||||
|     ignore_errors: yes |  | ||||||
| 
 | 
 | ||||||
|   - name: Configure rp_address + route_map  |   - name: Check remove idempotence rp_address + prefix_list | ||||||
|  |     nxos_pim_rp_address: *configplr | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Configure rp_address + route_map + bidir | ||||||
|     nxos_pim_rp_address: &configrm |     nxos_pim_rp_address: &configrm | ||||||
|       rp_address: "10.1.1.20" |       rp_address: "10.1.1.20" | ||||||
|       route_map: "pim_routemap" |       route_map: "pim_routemap" | ||||||
|       bidir: "{{bidir|default('true')}}" |       bidir: True | ||||||
|  |       state: present | ||||||
|  |       provider: "{{ connection }}" | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *true | ||||||
|  | 
 | ||||||
|  |   - name: Check idempotence rp_address + route_map + bidir | ||||||
|  |     nxos_pim_rp_address: *configrm | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
|  | 
 | ||||||
|  |   - name: Configure rp_address + route_map  | ||||||
|  |     nxos_pim_rp_address: &configrmnbi | ||||||
|  |       rp_address: "10.1.1.20" | ||||||
|  |       route_map: "pim_routemap" | ||||||
|  |       bidir: False | ||||||
|       state: present |       state: present | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     register: result |     register: result | ||||||
|  | @ -107,23 +197,27 @@ | ||||||
|   - assert: *true |   - assert: *true | ||||||
| 
 | 
 | ||||||
|   - name: Check idempotence rp_address + route_map |   - name: Check idempotence rp_address + route_map | ||||||
|     nxos_pim_rp_address: *configrm |     nxos_pim_rp_address: *configrmnbi | ||||||
|     register: result |     register: result | ||||||
| 
 | 
 | ||||||
|   - assert: *false |   - assert: *false | ||||||
| 
 | 
 | ||||||
|   - name: Remove rp_address + route_map using long config |   - name: Remove rp_address + route_map  | ||||||
|     nxos_config: |     nxos_pim_rp_address: &configrmr | ||||||
|       lines: "no ip pim rp-address 10.1.1.20 route-map pim_routemap {{ bidircfg }}" |       rp_address: "10.1.1.20" | ||||||
|  |       route_map: "pim_routemap" | ||||||
|  |       bidir: False | ||||||
|  |       state: absent | ||||||
|       provider: "{{ connection }}" |       provider: "{{ connection }}" | ||||||
|     ignore_errors: yes |     register: result | ||||||
| 
 | 
 | ||||||
|   - name: Remove rp_address + route_map using short config |   - assert: *true | ||||||
|     nxos_config: |  | ||||||
|       lines: no ip pim rp-address 10.1.1.20 |  | ||||||
|       provider: "{{ connection }}" |  | ||||||
|     ignore_errors: yes |  | ||||||
| 
 | 
 | ||||||
|  |   - name: Check remove idempotence rp_address + route_map | ||||||
|  |     nxos_pim_rp_address: *configrmr | ||||||
|  |     register: result | ||||||
|  | 
 | ||||||
|  |   - assert: *false | ||||||
| 
 | 
 | ||||||
|   always: |   always: | ||||||
|     - name: "Disable feature PIM" |     - name: "Disable feature PIM" | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue