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