1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
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
if sys.version_info < (2, 7):
pytestmark = pytest.mark.skip("F5 Ansible modules require Python >= 2.7")
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
# In Ansible 2.8, Ansible changed import paths.
from test.units.compat import unittest
from test.units.compat.mock import Mock
from test.units.modules.utils import set_module_args
except ImportError:
from ansible.modules.network.f5.bigip_device_auth import TacacsApiParameters
from ansible.modules.network.f5.bigip_device_auth import TacacsModuleParameters
from ansible.modules.network.f5.bigip_device_auth import TacacsManager
from ansible.modules.network.f5.bigip_device_auth import ModuleManager
from ansible.modules.network.f5.bigip_device_auth import ArgumentSpec
# Ansible 2.8 imports
from units.compat import unittest
from units.compat.mock import Mock
from units.modules.utils import set_module_args
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'
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
|