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
|
||||
|
||||
|
||||
def get_existing(module, args):
|
||||
def get_existing(module, args, gl):
|
||||
existing = {}
|
||||
config = str(get_config(module))
|
||||
address = module.params['rp_address']
|
||||
|
@ -105,6 +105,11 @@ def get_existing(module, args):
|
|||
values = line.split()
|
||||
if values[0] != address:
|
||||
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
|
||||
if len(values) > 2:
|
||||
|
@ -114,6 +119,7 @@ def get_existing(module, args):
|
|||
elif values[1] == 'prefix-list':
|
||||
existing['prefix_list'] = value
|
||||
elif values[1] == 'group-list':
|
||||
if value != '224.0.0.0/4': # ignore default group-list
|
||||
existing['group_list'] = value
|
||||
|
||||
return existing
|
||||
|
@ -122,6 +128,14 @@ def get_existing(module, args):
|
|||
def state_present(module, existing, proposed, candidate):
|
||||
address = module.params['rp_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)
|
||||
if commands:
|
||||
candidate.add(commands, parents=[])
|
||||
|
@ -140,15 +154,33 @@ def build_command(param_dict, command):
|
|||
def state_absent(module, existing, candidate):
|
||||
address = module.params['rp_address']
|
||||
|
||||
commands = []
|
||||
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)
|
||||
else:
|
||||
elif not module.params['group_list']:
|
||||
commands = [command]
|
||||
|
||||
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():
|
||||
argument_spec = dict(
|
||||
rp_address=dict(required=True, type='str'),
|
||||
|
@ -180,20 +212,16 @@ def main():
|
|||
'bidir'
|
||||
]
|
||||
|
||||
existing = get_existing(module, args)
|
||||
proposed_args = dict((k, v) for k, v in module.params.items()
|
||||
if v is not None and k in args)
|
||||
|
||||
proposed = {}
|
||||
for key, value in proposed_args.items():
|
||||
if key != 'rp_address':
|
||||
if str(value).lower() == 'true':
|
||||
value = True
|
||||
elif str(value).lower() == 'false':
|
||||
value = False
|
||||
if module.params['group_list']:
|
||||
existing = get_existing(module, args, True)
|
||||
proposed = get_proposed(proposed_args, existing)
|
||||
|
||||
if existing.get(key) != value:
|
||||
proposed[key] = value
|
||||
else:
|
||||
existing = get_existing(module, args, False)
|
||||
proposed = get_proposed(proposed_args, existing)
|
||||
|
||||
candidate = CustomNetworkConfig(indent=3)
|
||||
if state == 'present' and (proposed or not existing):
|
||||
|
@ -205,7 +233,19 @@ def main():
|
|||
candidate = candidate.items_text()
|
||||
result['commands'] = candidate
|
||||
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)
|
||||
|
||||
|
|
|
@ -3,13 +3,6 @@
|
|||
- debug: msg="Using provider={{ connection.transport }}"
|
||||
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:
|
||||
- name: "Disable feature PIM"
|
||||
nxos_feature: &disable_feature
|
||||
|
@ -27,7 +20,7 @@
|
|||
nxos_pim_rp_address: &configgl
|
||||
rp_address: "10.1.1.20"
|
||||
group_list: "224.0.0.0/8"
|
||||
bidir: "{{bidir|default('true')}}"
|
||||
bidir: True
|
||||
state: present
|
||||
provider: "{{ connection }}"
|
||||
register: result
|
||||
|
@ -44,33 +37,108 @@
|
|||
that:
|
||||
- "result.changed == false"
|
||||
|
||||
- name: Remove rp_address + group_list using long config
|
||||
#FIXME: Config deletion shall be fixed in 2.5 for platform dependencies.
|
||||
|
||||
# Note: For 2.4 - Use platform specific config delete command as shown below.
|
||||
# Possible options: Identify and use the command that is supported
|
||||
# by your platform under test.
|
||||
|
||||
# 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 }}"
|
||||
- name: Configure rp_address + group_list remove bidir
|
||||
nxos_pim_rp_address: &configglnb
|
||||
rp_address: "10.1.1.20"
|
||||
group_list: "224.0.0.0/8"
|
||||
bidir: False
|
||||
state: present
|
||||
provider: "{{ connection }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- name: Remove rp_address + group_list using short config
|
||||
nxos_config:
|
||||
lines: no ip pim rp-address 10.1.1.20
|
||||
- assert: *true
|
||||
|
||||
- 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 }}"
|
||||
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
|
||||
rp_address: "10.1.1.20"
|
||||
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
|
||||
provider: "{{ connection }}"
|
||||
register: result
|
||||
|
@ -78,28 +146,50 @@
|
|||
- assert: *true
|
||||
|
||||
- name: Check idempotence rp_address + prefix_list
|
||||
nxos_pim_rp_address: *configpl
|
||||
nxos_pim_rp_address: *configplnbi
|
||||
register: result
|
||||
|
||||
- assert: *false
|
||||
|
||||
- name: Remove rp_address + prefix_list using long config
|
||||
nxos_config:
|
||||
lines: "no ip pim rp-address 10.1.1.20 prefix-list pim_prefix_list {{ bidircfg }}"
|
||||
- name: Remove rp_address + prefix_list
|
||||
nxos_pim_rp_address: &configplr
|
||||
rp_address: "10.1.1.20"
|
||||
prefix_list: "pim_prefix_list"
|
||||
bidir: False
|
||||
state: absent
|
||||
provider: "{{ connection }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- name: Remove rp_address + prefix_list using short config
|
||||
nxos_config:
|
||||
lines: no ip pim rp-address 10.1.1.20
|
||||
provider: "{{ connection }}"
|
||||
ignore_errors: yes
|
||||
- assert: *true
|
||||
|
||||
- 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
|
||||
rp_address: "10.1.1.20"
|
||||
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
|
||||
provider: "{{ connection }}"
|
||||
register: result
|
||||
|
@ -107,23 +197,27 @@
|
|||
- assert: *true
|
||||
|
||||
- name: Check idempotence rp_address + route_map
|
||||
nxos_pim_rp_address: *configrm
|
||||
nxos_pim_rp_address: *configrmnbi
|
||||
register: result
|
||||
|
||||
- assert: *false
|
||||
|
||||
- name: Remove rp_address + route_map using long config
|
||||
nxos_config:
|
||||
lines: "no ip pim rp-address 10.1.1.20 route-map pim_routemap {{ bidircfg }}"
|
||||
- name: Remove rp_address + route_map
|
||||
nxos_pim_rp_address: &configrmr
|
||||
rp_address: "10.1.1.20"
|
||||
route_map: "pim_routemap"
|
||||
bidir: False
|
||||
state: absent
|
||||
provider: "{{ connection }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- name: Remove rp_address + route_map using short config
|
||||
nxos_config:
|
||||
lines: no ip pim rp-address 10.1.1.20
|
||||
provider: "{{ connection }}"
|
||||
ignore_errors: yes
|
||||
- assert: *true
|
||||
|
||||
- name: Check remove idempotence rp_address + route_map
|
||||
nxos_pim_rp_address: *configrmr
|
||||
register: result
|
||||
|
||||
- assert: *false
|
||||
|
||||
always:
|
||||
- name: "Disable feature PIM"
|
||||
|
|
Loading…
Reference in a new issue