2020-03-09 10:11:07 +01:00
|
|
|
# Copyright: (c) 2019, Ansible Project
|
|
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
|
|
|
|
|
|
|
from ansible_collections.community.general.tests.unit.compat.mock import patch
|
|
|
|
from ansible_collections.community.general.plugins.modules.network.icx import icx_user
|
|
|
|
from ansible_collections.community.general.tests.unit.modules.utils import set_module_args
|
2020-03-24 09:27:28 +01:00
|
|
|
from .icx_module import TestICXModule, load_fixture
|
2020-03-09 10:11:07 +01:00
|
|
|
|
|
|
|
|
|
|
|
class TestICXSCPModule(TestICXModule):
|
|
|
|
|
|
|
|
module = icx_user
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
super(TestICXSCPModule, self).setUp()
|
|
|
|
self.mock_get_config = patch('ansible_collections.community.general.plugins.modules.network.icx.icx_user.get_config')
|
|
|
|
self.get_config = self.mock_get_config.start()
|
|
|
|
self.mock_load_config = patch('ansible_collections.community.general.plugins.modules.network.icx.icx_user.load_config')
|
|
|
|
self.load_config = self.mock_load_config.start()
|
|
|
|
self.mock_exec_command = patch('ansible_collections.community.general.plugins.modules.network.icx.icx_user.exec_command')
|
|
|
|
self.exec_command = self.mock_exec_command.start()
|
|
|
|
self.set_running_config()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
super(TestICXSCPModule, self).tearDown()
|
|
|
|
self.mock_get_config.stop()
|
|
|
|
self.mock_load_config.stop()
|
|
|
|
self.mock_exec_command.stop()
|
|
|
|
|
|
|
|
def load_fixtures(self, commands=None):
|
|
|
|
compares = None
|
|
|
|
|
|
|
|
def load_file(*args, **kwargs):
|
|
|
|
module = args
|
|
|
|
for arg in args:
|
|
|
|
if arg.params['check_running_config'] is True:
|
|
|
|
return load_fixture('show_running-config_include_username.txt').strip()
|
|
|
|
else:
|
|
|
|
return ''
|
|
|
|
self.get_config.side_effect = load_file
|
|
|
|
self.load_config.return_value = None
|
|
|
|
|
|
|
|
def test_icx_user_create_new_with_password(self):
|
|
|
|
set_module_args(dict(name='ale6', configured_password='alethea123'))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = ['username ale6 password alethea123']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = ['username ale6 password alethea123']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_create_new_with_password_and_privilege(self):
|
|
|
|
set_module_args(dict(name='ale6', privilege="5", configured_password='alethea123'))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = ['username ale6 privilege 5 password alethea123']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = ['username ale6 privilege 5 password alethea123']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_update_privilege(self):
|
|
|
|
set_module_args(dict(name='ale1', privilege="0", configured_password='alethea123'))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = ['username ale1 privilege 0 password alethea123']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = ['username ale1 privilege 0 password alethea123']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_update_password(self):
|
|
|
|
set_module_args(dict(name='ale1', configured_password='alethea123'))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = ['username ale1 password alethea123'] # previous privilage will be added
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = ['username ale1 privilege 5 password alethea123'] # previous privilage will be added
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_update_password_compare(self):
|
|
|
|
set_module_args(dict(name='ale1', configured_password='alethea123', check_running_config=True))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = ['username ale1 privilege 5 password alethea123'] # previous privilage will be added
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = ['username ale1 privilege 5 password alethea123'] # previous privilage will be added
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_delete_user(self):
|
|
|
|
set_module_args(dict(name='ale1', state="absent"))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = ['no username ale1']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = ['no username ale1']
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_agregate(self):
|
|
|
|
set_module_args(dict(aggregate=[
|
|
|
|
{
|
|
|
|
"name": 'ale6',
|
|
|
|
"configured_password": 'alethea123'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": 'ale7',
|
|
|
|
"configured_password": 'alethea123'
|
|
|
|
}
|
|
|
|
]))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = [
|
|
|
|
'username ale6 password alethea123',
|
|
|
|
'username ale7 password alethea123'
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = [
|
|
|
|
'username ale6 password alethea123',
|
|
|
|
'username ale7 password alethea123'
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_not_update_old_user_password(self):
|
|
|
|
set_module_args(dict(aggregate=[
|
|
|
|
{
|
|
|
|
"name": 'ale6',
|
|
|
|
"configured_password": 'alethea123'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": 'ale1',
|
|
|
|
"configured_password": 'alethea123',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
update_password='on_create'
|
|
|
|
))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = [
|
|
|
|
'username ale1 password alethea123',
|
|
|
|
'username ale6 password alethea123',
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = [
|
|
|
|
'username ale6 password alethea123',
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_only_update_changed_settings(self):
|
|
|
|
set_module_args(dict(aggregate=[
|
|
|
|
{
|
|
|
|
"name": 'ale1'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": 'ale2',
|
|
|
|
"privilege": 5,
|
|
|
|
"configured_password": "ale123"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": 'ale3',
|
|
|
|
"privilege": 4,
|
|
|
|
"configured_password": "ale123"
|
|
|
|
}
|
|
|
|
],
|
|
|
|
update_password="on_create"
|
|
|
|
))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = [
|
|
|
|
'username ale2 privilege 5 password ale123',
|
|
|
|
'username ale3 privilege 4 password ale123'
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
else:
|
|
|
|
commands = [
|
|
|
|
'username ale3 privilege 4 password ale123'
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|
|
|
|
|
|
|
|
def test_icx_user_purge(self):
|
|
|
|
set_module_args(dict(aggregate=[
|
|
|
|
{
|
|
|
|
"name": 'ale1'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
purge=True
|
|
|
|
))
|
|
|
|
if not self.ENV_ICX_USE_DIFF:
|
|
|
|
commands = [
|
|
|
|
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=False)
|
|
|
|
else:
|
|
|
|
commands = [
|
|
|
|
'no username ale2',
|
|
|
|
'no username ale3',
|
|
|
|
'no username ale4'
|
|
|
|
]
|
|
|
|
self.execute_module(commands=commands, changed=True)
|