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_ssl_csr 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 name='ssl_csr_1', 53 common_name='ssl_csr_1', 54 key_name='ssl_key_1', 55 dest='/tmp/ssl_csr_1' 56 ) 57 58 p = ModuleParameters(params=args) 59 assert p.name == 'ssl_csr_1' 60 assert p.common_name == 'ssl_csr_1' 61 assert p.key_name == 'ssl_key_1' 62 assert p.dest == '/tmp/ssl_csr_1' 63 64 def test_api_parameters(self): 65 args = load_fixture('load_sys_crypto_csr.json') 66 p = ApiParameters(params=args) 67 assert p.name == 'ssl_csr_1' 68 assert p.common_name == 'ssl_csr_1' 69 70 71class TestManager(unittest.TestCase): 72 def setUp(self): 73 self.spec = ArgumentSpec() 74 self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_ssl_csr.tmos_version') 75 self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_ssl_csr.send_teem') 76 self.m2 = self.p2.start() 77 self.m2.return_value = '14.1.0' 78 self.m3 = self.p3.start() 79 self.m3.return_value = True 80 81 def tearDown(self): 82 self.p2.stop() 83 self.p3.stop() 84 85 def test_create(self, *args): 86 set_module_args(dict( 87 name='ssl_csr_1', 88 common_name='ssl_csr_1', 89 key_name='ssl_key_1', 90 dest='/tmp/ssl_csr_1', 91 force=True, 92 state='present', 93 provider=dict( 94 server='localhost', 95 password='password', 96 user='admin' 97 ) 98 )) 99 100 module = AnsibleModule( 101 argument_spec=self.spec.argument_spec, 102 supports_check_mode=self.spec.supports_check_mode 103 ) 104 105 # Override methods in the specific type of manager 106 mm = ModuleManager(module=module) 107 mm.version_is_less_than_14 = Mock(return_value=False) 108 mm.exists = Mock(return_value=False) 109 mm.file_exists = Mock(return_value=False) 110 mm.create_on_device = Mock(return_value=True) 111 mm._move_csr_to_download = Mock(return_value=True) 112 mm._delete_csr = Mock(return_value=True) 113 mm._download_file = Mock(return_value=True) 114 mm.remove_from_device = Mock(return_value=True) 115 116 with patch('os.path.exists') as mo: 117 mo.return_value = True 118 results = mm.exec_module() 119 120 assert results['changed'] is True 121