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
19try:
20    from library.modules.bigip_password_policy import ApiParameters
21    from library.modules.bigip_password_policy import ModuleParameters
22    from library.modules.bigip_password_policy import ModuleManager
23    from library.modules.bigip_password_policy import ArgumentSpec
24
25    # In Ansible 2.8, Ansible changed import paths.
26    from test.units.compat import unittest
27    from test.units.compat.mock import Mock
28    from test.units.compat.mock import patch
29
30    from test.units.modules.utils import set_module_args
31except ImportError:
32    from ansible.modules.network.f5.bigip_password_policy import ApiParameters
33    from ansible.modules.network.f5.bigip_password_policy import ModuleParameters
34    from ansible.modules.network.f5.bigip_password_policy import ModuleManager
35    from ansible.modules.network.f5.bigip_password_policy import ArgumentSpec
36
37    # Ansible 2.8 imports
38    from units.compat import unittest
39    from units.compat.mock import Mock
40    from units.compat.mock import patch
41
42    from units.modules.utils import set_module_args
43
44
45fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
46fixture_data = {}
47
48
49def load_fixture(name):
50    path = os.path.join(fixture_path, name)
51
52    if path in fixture_data:
53        return fixture_data[path]
54
55    with open(path) as f:
56        data = f.read()
57
58    try:
59        data = json.loads(data)
60    except Exception:
61        pass
62
63    fixture_data[path] = data
64    return data
65
66
67class TestParameters(unittest.TestCase):
68    def test_module_parameters(self):
69        args = dict(
70            expiration_warning=7,
71            max_duration=99999,
72            max_login_failures=0,
73            min_duration=0,
74            min_length=6,
75            password_memory=0,
76            policy_enforcement=False,
77            required_lowercase=0,
78            required_numeric=0,
79            required_special=0,
80            required_uppercase=0,
81        )
82
83        p = ModuleParameters(params=args)
84        assert p.expiration_warning == 7
85        assert p.max_duration == 99999
86        assert p.max_login_failures == 0
87        assert p.min_duration == 0
88        assert p.password_memory == 0
89        assert p.policy_enforcement == 'no'
90        assert p.required_lowercase == 0
91        assert p.required_numeric == 0
92        assert p.required_special == 0
93        assert p.required_uppercase == 0
94
95    def test_api_parameters(self):
96        args = load_fixture('load_tm_auth_password_policy_1.json')
97
98        p = ApiParameters(params=args)
99        assert p.expiration_warning == 7
100        assert p.max_duration == 99999
101        assert p.max_login_failures == 0
102        assert p.min_duration == 0
103        assert p.password_memory == 0
104        assert p.policy_enforcement == 'no'
105        assert p.required_lowercase == 0
106        assert p.required_numeric == 0
107        assert p.required_special == 0
108        assert p.required_uppercase == 0
109
110
111@patch('ansible.module_utils.f5_utils.AnsibleF5Client._get_mgmt_root',
112       return_value=True)
113class TestManager(unittest.TestCase):
114
115    def setUp(self):
116        self.spec = ArgumentSpec()
117
118    def test_create_partition(self, *args):
119        set_module_args(dict(
120            expiration_warning=7,
121            max_duration=9999,
122            max_login_failures=0,
123            min_duration=0,
124            min_length=6,
125            password_memory=0,
126            policy_enforcement='no',
127            required_lowercase=0,
128            required_numeric=0,
129            required_special=0,
130            required_uppercase=0,
131            provider=dict(
132                server='localhost',
133                password='password',
134                user='admin'
135            )
136        ))
137
138        current = ApiParameters(params=load_fixture('load_tm_auth_password_policy_1.json'))
139        module = AnsibleModule(
140            argument_spec=self.spec.argument_spec,
141            supports_check_mode=self.spec.supports_check_mode
142        )
143
144        # Override methods in the specific type of manager
145        mm = ModuleManager(module=module)
146        mm.exists = Mock(side_effect=[False, True])
147        mm.update_on_device = Mock(return_value=True)
148        mm.read_current_from_device = Mock(return_value=current)
149
150        results = mm.exec_module()
151
152        assert results['changed'] is True
153