fix pim rp_address issues (#35248)

pull/35267/head
saichint 7 years ago committed by Trishna Guha
parent 7fac5cd7d2
commit 0b30c42902

@ -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,6 +119,7 @@ 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':
if value != '224.0.0.0/4': # ignore default group-list
existing['group_list'] = value 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,15 +154,33 @@ 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]
if commands:
candidate.add(commands, parents=[]) 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():
argument_spec = dict( argument_spec = dict(
rp_address=dict(required=True, type='str'), rp_address=dict(required=True, type='str'),
@ -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,86 +37,187 @@
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"
group_list: "224.0.0.0/8"
bidir: False
state: present
provider: "{{ connection }}"
register: result
- assert: *true
# Note: For 2.4 - Use platform specific config delete command as shown below. - name: Check idempotence rp_address + group_list remove bidir
# Possible options: Identify and use the command that is supported nxos_pim_rp_address: *configglnb
# by your platform under test. register: result
# no ip pim rp-address <ip address> <group-list|prefix-list|route-map> bidir - assert: *false
# no ip pim rp-address <ip address>
# no ip pim rp-address <ip address> <group-list|prefix-list|route-map>
nxos_config: - name: Configure rp_address + bidir
lines: "no ip pim rp-address 10.1.1.20 group-list 224.0.0.0/8 {{ bidircfg }}" nxos_pim_rp_address: &configbi
rp_address: "10.1.1.20"
bidir: True
state: present
provider: "{{ connection }}" provider: "{{ connection }}"
ignore_errors: yes register: result
- assert: *true
- name: Check idempotence rp_address + bidir
nxos_pim_rp_address: *configbi
register: result
- name: Remove rp_address + group_list using short config - assert: *false
nxos_config:
lines: no ip pim rp-address 10.1.1.20 - name: Configure rp_address remove bidir
nxos_pim_rp_address: &confignbi
rp_address: "10.1.1.20"
bidir: False
state: present
provider: "{{ connection }}" provider: "{{ connection }}"
ignore_errors: yes register: result
- name: Configure rp_address + prefix_list - 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 state: present
provider: "{{ connection }}" provider: "{{ connection }}"
register: result register: result
- assert: *true - assert: *true
- name: Check idempotence rp_address + prefix_list - name: Check idempotence rp_address + prefix_list + bidir
nxos_pim_rp_address: *configpl nxos_pim_rp_address: *configpl
register: result register: result
- assert: *false - assert: *false
- name: Remove rp_address + prefix_list using long config - name: Configure rp_address + prefix_list
nxos_config: nxos_pim_rp_address: &configplnbi
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: present
provider: "{{ connection }}" provider: "{{ connection }}"
ignore_errors: yes register: result
- assert: *true
- name: Check idempotence rp_address + prefix_list
nxos_pim_rp_address: *configplnbi
register: result
- assert: *false
- name: Remove rp_address + prefix_list using short config - name: Remove rp_address + prefix_list
nxos_config: nxos_pim_rp_address: &configplr
lines: no ip pim rp-address 10.1.1.20 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: Configure rp_address + route_map - assert: *true
- 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 state: present
provider: "{{ connection }}" provider: "{{ connection }}"
register: result register: result
- assert: *true - assert: *true
- name: Check idempotence rp_address + route_map - name: Check idempotence rp_address + route_map + bidir
nxos_pim_rp_address: *configrm nxos_pim_rp_address: *configrm
register: result register: result
- assert: *false - assert: *false
- name: Remove rp_address + route_map using long config - name: Configure rp_address + route_map
nxos_config: nxos_pim_rp_address: &configrmnbi
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: present
provider: "{{ connection }}" provider: "{{ connection }}"
ignore_errors: yes register: result
- assert: *true
- name: Remove rp_address + route_map using short config - name: Check idempotence rp_address + route_map
nxos_config: nxos_pim_rp_address: *configrmnbi
lines: no ip pim rp-address 10.1.1.20 register: result
- assert: *false
- 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 }}" provider: "{{ connection }}"
ignore_errors: yes register: result
- assert: *true
- 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…
Cancel
Save