1# -*- coding: utf-8 -*-
2#
3# Copyright: (c) 2018, 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_auth_ldap import (
20    ApiParameters, 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            servers=['10.10.10.10', '10.10.10.11'],
53            port=389,
54            remote_directory_tree='foo',
55            scope='base',
56            bind_dn='bar',
57            bind_password='secret',
58            user_template='alice',
59            check_member_attr=False,
60            ssl='no',
61            ca_cert='default.crt',
62            client_key='default.key',
63            client_cert='default1.crt',
64            validate_certs=True,
65            login_ldap_attr='bob',
66            fallback_to_local=True,
67            update_password='on_create',
68        )
69        p = ApiParameters(params=args)
70        assert p.port == 389
71        assert p.servers == ['10.10.10.10', '10.10.10.11']
72        assert p.remote_directory_tree == 'foo'
73        assert p.scope == 'base'
74        assert p.bind_dn == 'bar'
75        assert p.bind_password == 'secret'
76        assert p.user_template == 'alice'
77        assert p.check_member_attr == 'no'
78        assert p.ssl == 'no'
79        assert p.ca_cert == '/Common/default.crt'
80        assert p.client_key == '/Common/default.key'
81        assert p.client_cert == '/Common/default1.crt'
82        assert p.validate_certs == 'yes'
83        assert p.login_ldap_attr == 'bob'
84        assert p.fallback_to_local == 'yes'
85        assert p.update_password == 'on_create'
86
87
88class TestManager(unittest.TestCase):
89
90    def setUp(self):
91        self.spec = ArgumentSpec()
92        self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_device_auth_ldap.tmos_version')
93        self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_device_auth_ldap.send_teem')
94        self.m2 = self.p2.start()
95        self.m2.return_value = '14.1.0'
96        self.m3 = self.p3.start()
97        self.m3.return_value = True
98
99    def tearDown(self):
100        self.p2.stop()
101        self.p3.stop()
102
103    def test_create(self, *args):
104        set_module_args(dict(
105            servers=['10.10.10.10', '10.10.10.11'],
106            update_password='on_create',
107            state='present',
108            provider=dict(
109                password='admin',
110                server='localhost',
111                user='admin'
112            )
113        ))
114
115        module = AnsibleModule(
116            argument_spec=self.spec.argument_spec,
117            supports_check_mode=self.spec.supports_check_mode
118        )
119
120        # Override methods to force specific logic in the module to happen
121        mm = ModuleManager(module=module)
122        mm.exists = Mock(return_value=False)
123        mm.create_on_device = Mock(return_value=True)
124        mm.update_auth_source_on_device = Mock(return_value=True)
125
126        results = mm.exec_module()
127        assert results['changed'] is True
128