Adds bigip_device_auth module (#44373)

This module can be used to configure auth settings to the mgmt
interface on a BIG-IP.
This commit is contained in:
Tim Rupp 2018-08-19 17:32:19 -04:00 committed by GitHub
commit 359d97f01b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 936 additions and 0 deletions

View file

@ -0,0 +1,131 @@
# -*- coding: utf-8 -*-
#
# Copyright: (c) 2018, F5 Networks Inc.
# 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
import os
import json
import pytest
import sys
from nose.plugins.skip import SkipTest
if sys.version_info < (2, 7):
raise SkipTest("F5 Ansible modules require Python >= 2.7")
from ansible.compat.tests import unittest
from ansible.compat.tests.mock import Mock
from ansible.compat.tests.mock import patch
from ansible.module_utils.basic import AnsibleModule
try:
from library.modules.bigip_device_auth import TacacsApiParameters
from library.modules.bigip_device_auth import TacacsModuleParameters
from library.modules.bigip_device_auth import TacacsManager
from library.modules.bigip_device_auth import ModuleManager
from library.modules.bigip_device_auth import ArgumentSpec
from library.module_utils.network.f5.common import F5ModuleError
from test.unit.modules.utils import set_module_args
except ImportError:
try:
from ansible.modules.network.f5.bigip_sys_auth import TacacsApiParameters
from ansible.modules.network.f5.bigip_sys_auth import TacacsModuleParameters
from ansible.modules.network.f5.bigip_sys_auth import TacacsManager
from ansible.modules.network.f5.bigip_sys_auth import ModuleManager
from ansible.modules.network.f5.bigip_sys_auth import ArgumentSpec
from ansible.module_utils.network.f5.common import F5ModuleError
from units.modules.utils import set_module_args
except ImportError:
raise SkipTest("F5 Ansible modules require the f5-sdk Python library")
fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
fixture_data = {}
def load_fixture(name):
path = os.path.join(fixture_path, name)
if path in fixture_data:
return fixture_data[path]
with open(path) as f:
data = f.read()
try:
data = json.loads(data)
except Exception:
pass
fixture_data[path] = data
return data
class TestParameters(unittest.TestCase):
def test_module_parameters(self):
args = dict(
type="tacacs",
authentication="use-all-servers",
protocol_name="ip",
secret="$XXXXXXXXXXXXXXXXXXXX==",
servers=['10.10.10.10', '10.10.10.11'],
service_name="ppp",
use_for_auth=True,
update_secret="on_create",
)
p = TacacsModuleParameters(params=args)
assert p.type == 'tacacs'
assert p.authentication == 'use-all-servers'
def test_api_parameters(self):
args = load_fixture('load_tm_auth_tacacs_1.json')
p = TacacsApiParameters(params=args)
assert p.authentication == 'use-first-server'
assert p.protocol_name == 'ftp'
assert p.secret == 'secret'
assert p.servers == ['11.11.11.11']
assert p.service_name == 'ppp'
@patch('ansible.module_utils.f5_utils.AnsibleF5Client._get_mgmt_root',
return_value=True)
class TestManager(unittest.TestCase):
def setUp(self):
self.spec = ArgumentSpec()
def test_create(self, *args):
set_module_args(dict(
type="tacacs",
authentication="use-all-servers",
protocol_name="ip",
secret="secret",
servers=['10.10.10.10', '10.10.10.11'],
service_name="ppp",
use_for_auth=True,
update_secret="on_create",
state='present',
provider=dict(
password='admin',
server='localhost',
user='admin'
)
))
module = AnsibleModule(
argument_spec=self.spec.argument_spec,
supports_check_mode=self.spec.supports_check_mode
)
# Override methods to force specific logic in the module to happen
m1 = TacacsManager(module=module)
m1.exists = Mock(return_value=False)
m1.create_on_device = Mock(return_value=True)
m1.update_auth_source_on_device = Mock(return_value=True)
mm = ModuleManager(module=module)
mm.get_manager = Mock(return_value=m1)
results = mm.exec_module()
assert results['changed'] is True