1# -*- coding: utf-8 -*-
2#
3# Copyright (c) 2017 F5 Networks Inc.
4# GNU General Public License v3.0 (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
5
6from __future__ import (absolute_import, division, print_function)
7__metaclass__ = type
8
9import os
10import json
11import pytest
12import sys
13
14if sys.version_info < (2, 7):
15    pytestmark = pytest.mark.skip("F5 Ansible modules require Python >= 2.7")
16
17from ansible.module_utils.basic import AnsibleModule
18
19from ansible_collections.f5networks.f5_modules.plugins.modules.bigip_device_trust import (
20    Parameters, ModuleManager, ArgumentSpec
21)
22from ansible_collections.f5networks.f5_modules.tests.unit.compat import unittest
23from ansible_collections.f5networks.f5_modules.tests.unit.compat.mock import Mock, patch
24from ansible_collections.f5networks.f5_modules.tests.unit.modules.utils import set_module_args
25
26
27fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
28fixture_data = {}
29
30
31def load_fixture(name):
32    path = os.path.join(fixture_path, name)
33
34    if path in fixture_data:
35        return fixture_data[path]
36
37    with open(path) as f:
38        data = f.read()
39
40    try:
41        data = json.loads(data)
42    except Exception:
43        pass
44
45    fixture_data[path] = data
46    return data
47
48
49class TestParameters(unittest.TestCase):
50    def test_module_parameters(self):
51        args = dict(
52            peer_server='10.10.10.10',
53            peer_hostname='foo.bar.baz',
54            peer_user='admin',
55            peer_password='secret'
56        )
57
58        p = Parameters(params=args)
59        assert p.peer_server == '10.10.10.10'
60        assert p.peer_hostname == 'foo.bar.baz'
61        assert p.peer_user == 'admin'
62        assert p.peer_password == 'secret'
63
64    def test_module_parameters_with_peer_type(self):
65        args = dict(
66            peer_server='10.10.10.10',
67            peer_hostname='foo.bar.baz',
68            peer_user='admin',
69            peer_password='secret',
70            type='peer'
71        )
72
73        p = Parameters(params=args)
74        assert p.peer_server == '10.10.10.10'
75        assert p.peer_hostname == 'foo.bar.baz'
76        assert p.peer_user == 'admin'
77        assert p.peer_password == 'secret'
78        assert p.type is True
79
80    def test_module_parameters_with_subordinate_type(self):
81        args = dict(
82            peer_server='10.10.10.10',
83            peer_hostname='foo.bar.baz',
84            peer_user='admin',
85            peer_password='secret',
86            type='subordinate'
87        )
88
89        p = Parameters(params=args)
90        assert p.peer_server == '10.10.10.10'
91        assert p.peer_hostname == 'foo.bar.baz'
92        assert p.peer_user == 'admin'
93        assert p.peer_password == 'secret'
94        assert p.type is False
95
96    def test_hyphenated_peer_hostname(self):
97        args = dict(
98            peer_hostname='hn---hyphen____underscore.hmatsuda.local',
99        )
100
101        p = Parameters(params=args)
102        assert p.peer_hostname == 'hn---hyphen____underscore.hmatsuda.local'
103
104    def test_numbered_peer_hostname(self):
105        args = dict(
106            peer_hostname='BIG-IP_12x_ans2.example.local',
107        )
108
109        p = Parameters(params=args)
110        assert p.peer_hostname == 'BIG-IP_12x_ans2.example.local'
111
112
113class TestManager(unittest.TestCase):
114
115    def setUp(self):
116        self.spec = ArgumentSpec()
117        self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_device_trust.tmos_version')
118        self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_device_trust.send_teem')
119        self.m2 = self.p2.start()
120        self.m2.return_value = '14.1.0'
121        self.m3 = self.p3.start()
122        self.m3.return_value = True
123
124    def tearDown(self):
125        self.p2.stop()
126        self.p3.stop()
127
128    def test_create_device_trust(self, *args):
129        set_module_args(dict(
130            peer_server='10.10.10.10',
131            peer_hostname='foo.bar.baz',
132            peer_user='admin',
133            peer_password='secret',
134            provider=dict(
135                server='localhost',
136                password='password',
137                user='admin'
138            )
139        ))
140
141        module = AnsibleModule(
142            argument_spec=self.spec.argument_spec,
143            supports_check_mode=self.spec.supports_check_mode
144        )
145
146        # Override methods in the specific type of manager
147        mm = ModuleManager(module=module)
148        mm.exists = Mock(return_value=False)
149        mm.create_on_device = Mock(return_value=True)
150
151        results = mm.exec_module()
152
153        assert results['changed'] is True
154
155    def test_create_device_trust_idempotent(self, *args):
156        set_module_args(dict(
157            peer_server='10.10.10.10',
158            peer_hostname='foo.bar.baz',
159            peer_user='admin',
160            peer_password='secret',
161            provider=dict(
162                server='localhost',
163                password='password',
164                user='admin'
165            )
166        ))
167
168        module = AnsibleModule(
169            argument_spec=self.spec.argument_spec,
170            supports_check_mode=self.spec.supports_check_mode
171        )
172
173        # Override methods in the specific type of manager
174        mm = ModuleManager(module=module)
175        mm.exists = Mock(return_value=True)
176
177        results = mm.exec_module()
178
179        assert results['changed'] is False
180