1# -*- coding: utf-8 -*- 2# 3# Copyright: (c) 2019, 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_remote_user 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 default_partition='Common', 53 default_role='admin', 54 console_access='yes', 55 description='this is a role' 56 57 ) 58 59 p = ModuleParameters(params=args) 60 assert p.default_partition == 'Common' 61 assert p.default_role == 'admin' 62 assert p.console_access == 'tmsh' 63 assert p.description == 'this is a role' 64 65 def test_api_parameters(self): 66 args = load_fixture('load_remote_user_settings.json') 67 p = ApiParameters(params=args) 68 assert p.default_partition == 'all' 69 assert p.default_role == 'no-access' 70 assert p.console_access == 'disabled' 71 assert p.description is None 72 73 74class TestManager(unittest.TestCase): 75 def setUp(self): 76 self.spec = ArgumentSpec() 77 self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_remote_user.tmos_version') 78 self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_remote_user.send_teem') 79 self.m2 = self.p2.start() 80 self.m2.return_value = '14.1.0' 81 self.m3 = self.p3.start() 82 self.m3.return_value = True 83 84 def tearDown(self): 85 self.p2.stop() 86 self.p3.stop() 87 88 def test_create_remote_syslog(self, *args): 89 set_module_args(dict( 90 default_partition='Foobar', 91 default_role='auditor', 92 console_access='yes', 93 description='this is a role', 94 provider=dict( 95 server='localhost', 96 password='password', 97 user='admin' 98 ) 99 )) 100 101 current = ApiParameters(params=load_fixture('load_remote_user_settings.json')) 102 103 module = AnsibleModule( 104 argument_spec=self.spec.argument_spec, 105 supports_check_mode=self.spec.supports_check_mode 106 ) 107 108 # Override methods in the specific type of manager 109 mm = ModuleManager(module=module) 110 mm.update_on_device = Mock(return_value=True) 111 mm.read_current_from_device = Mock(return_value=current) 112 113 results = mm.exec_module() 114 115 assert results['changed'] is True 116 assert results['description'] == 'this is a role' 117 assert results['default_partition'] == 'Foobar' 118 assert results['default_role'] == 'auditor' 119 assert results['console_access'] == 'yes' 120