mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
The module fails on switchport. Check added to fix. (#54970)
This commit is contained in:
parent
e3c79979c2
commit
f5d97205a0
3 changed files with 52 additions and 0 deletions
|
@ -137,6 +137,35 @@ def search_obj_in_list(name, lst):
|
||||||
return o
|
return o
|
||||||
|
|
||||||
|
|
||||||
|
def get_interface_type(interface):
|
||||||
|
intf_type = 'unknown'
|
||||||
|
if interface.upper()[:2] in ('ET', 'GI', 'FA', 'TE', 'FO', 'HU', 'TWE'):
|
||||||
|
intf_type = 'ethernet'
|
||||||
|
elif interface.upper().startswith('VL'):
|
||||||
|
intf_type = 'svi'
|
||||||
|
elif interface.upper().startswith('LO'):
|
||||||
|
intf_type = 'loopback'
|
||||||
|
elif interface.upper()[:2] in ('MG', 'MA'):
|
||||||
|
intf_type = 'management'
|
||||||
|
elif interface.upper().startswith('PO'):
|
||||||
|
intf_type = 'portchannel'
|
||||||
|
elif interface.upper().startswith('NV'):
|
||||||
|
intf_type = 'nve'
|
||||||
|
|
||||||
|
return intf_type
|
||||||
|
|
||||||
|
|
||||||
|
def is_switchport(name, module):
|
||||||
|
intf_type = get_interface_type(name)
|
||||||
|
|
||||||
|
if intf_type in ('ethernet', 'portchannel'):
|
||||||
|
config = run_commands(module,
|
||||||
|
['show interface {0} switchport'.format(name)])[0]
|
||||||
|
match = re.search(r'Switchport : enabled', config)
|
||||||
|
return bool(match)
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def map_obj_to_commands(updates, module):
|
def map_obj_to_commands(updates, module):
|
||||||
commands = list()
|
commands = list()
|
||||||
want, have = updates
|
want, have = updates
|
||||||
|
@ -317,6 +346,13 @@ def main():
|
||||||
result['warnings'] = warnings
|
result['warnings'] = warnings
|
||||||
|
|
||||||
want = map_params_to_obj(module)
|
want = map_params_to_obj(module)
|
||||||
|
for w in want:
|
||||||
|
name = w['name']
|
||||||
|
name = name.lower()
|
||||||
|
if is_switchport(name, module):
|
||||||
|
module.fail_json(msg='Ensure interface is configured to be a L3'
|
||||||
|
'\nport first before using this module. You can use'
|
||||||
|
'\nthe cnos_interface module for this.')
|
||||||
have = map_config_to_obj(module)
|
have = map_config_to_obj(module)
|
||||||
|
|
||||||
commands = map_obj_to_commands((want, have), module)
|
commands = map_obj_to_commands((want, have), module)
|
||||||
|
|
|
@ -12,6 +12,15 @@
|
||||||
- test4
|
- test4
|
||||||
- test5
|
- test5
|
||||||
|
|
||||||
|
- name: Setup - Ensure interfaces are not switchport
|
||||||
|
cnos_config:
|
||||||
|
lines:
|
||||||
|
- no shutdown
|
||||||
|
- no switchport
|
||||||
|
- no logging monitor
|
||||||
|
parents:
|
||||||
|
- "interface ethernet1/33"
|
||||||
|
|
||||||
- name: Create vrf
|
- name: Create vrf
|
||||||
cnos_vrf:
|
cnos_vrf:
|
||||||
name: test
|
name: test
|
||||||
|
|
|
@ -38,15 +38,22 @@ class TestCnosVrfModule(TestCnosModule):
|
||||||
self.mock_run_commands = patch('ansible.modules.network.cnos.cnos_vrf.run_commands')
|
self.mock_run_commands = patch('ansible.modules.network.cnos.cnos_vrf.run_commands')
|
||||||
self.run_commands = self.mock_run_commands.start()
|
self.run_commands = self.mock_run_commands.start()
|
||||||
|
|
||||||
|
self._patch_is_switchport = patch(
|
||||||
|
'ansible.modules.network.cnos.cnos_vrf.is_switchport'
|
||||||
|
)
|
||||||
|
self._is_switchport = self._patch_is_switchport.start()
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
super(TestCnosVrfModule, self).tearDown()
|
super(TestCnosVrfModule, self).tearDown()
|
||||||
self.mock_load_config.stop()
|
self.mock_load_config.stop()
|
||||||
self.mock_run_commands.stop()
|
self.mock_run_commands.stop()
|
||||||
|
self._patch_is_switchport.stop()
|
||||||
|
|
||||||
def load_fixtures(self, commands=None):
|
def load_fixtures(self, commands=None):
|
||||||
config_file = 'cnos_vrf_config.cfg'
|
config_file = 'cnos_vrf_config.cfg'
|
||||||
self.load_config.return_value = load_fixture(config_file)
|
self.load_config.return_value = load_fixture(config_file)
|
||||||
self.run_commands.return_value = load_fixture(config_file)
|
self.run_commands.return_value = load_fixture(config_file)
|
||||||
|
self._is_switchport.return_value = False
|
||||||
|
|
||||||
def test_cnos_vrf_present(self):
|
def test_cnos_vrf_present(self):
|
||||||
set_module_args(dict(name='test1', state='present'))
|
set_module_args(dict(name='test1', state='present'))
|
||||||
|
|
Loading…
Reference in a new issue