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_password_policy import (
20    ApiParameters, ModuleParameters, 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            expiration_warning=7,
53            max_duration=99999,
54            max_login_failures=0,
55            min_duration=0,
56            min_length=6,
57            password_memory=0,
58            policy_enforcement=False,
59            required_lowercase=0,
60            required_numeric=0,
61            required_special=0,
62            required_uppercase=0,
63        )
64
65        p = ModuleParameters(params=args)
66        assert p.expiration_warning == 7
67        assert p.max_duration == 99999
68        assert p.max_login_failures == 0
69        assert p.min_duration == 0
70        assert p.password_memory == 0
71        assert p.policy_enforcement == 'no'
72        assert p.required_lowercase == 0
73        assert p.required_numeric == 0
74        assert p.required_special == 0
75        assert p.required_uppercase == 0
76
77    def test_api_parameters(self):
78        args = load_fixture('load_tm_auth_password_policy_1.json')
79
80        p = ApiParameters(params=args)
81        assert p.expiration_warning == 7
82        assert p.max_duration == 99999
83        assert p.max_login_failures == 0
84        assert p.min_duration == 0
85        assert p.password_memory == 0
86        assert p.policy_enforcement == 'no'
87        assert p.required_lowercase == 0
88        assert p.required_numeric == 0
89        assert p.required_special == 0
90        assert p.required_uppercase == 0
91
92
93class TestManager(unittest.TestCase):
94    def setUp(self):
95        self.spec = ArgumentSpec()
96        self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_password_policy.tmos_version')
97        self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_password_policy.send_teem')
98        self.m2 = self.p2.start()
99        self.m2.return_value = '14.1.0'
100        self.m3 = self.p3.start()
101        self.m3.return_value = True
102
103    def tearDown(self):
104        self.p2.stop()
105        self.p3.stop()
106
107    def test_create_partition(self, *args):
108        set_module_args(dict(
109            expiration_warning=7,
110            max_duration=9999,
111            max_login_failures=0,
112            min_duration=0,
113            min_length=6,
114            password_memory=0,
115            policy_enforcement='no',
116            required_lowercase=0,
117            required_numeric=0,
118            required_special=0,
119            required_uppercase=0,
120            provider=dict(
121                server='localhost',
122                password='password',
123                user='admin'
124            )
125        ))
126
127        current = ApiParameters(params=load_fixture('load_tm_auth_password_policy_1.json'))
128        module = AnsibleModule(
129            argument_spec=self.spec.argument_spec,
130            supports_check_mode=self.spec.supports_check_mode
131        )
132
133        # Override methods in the specific type of manager
134        mm = ModuleManager(module=module)
135        mm.exists = Mock(side_effect=[False, True])
136        mm.update_on_device = Mock(return_value=True)
137        mm.read_current_from_device = Mock(return_value=current)
138
139        results = mm.exec_module()
140
141        assert results['changed'] is True
142