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