1# -*- coding: utf-8 -*- 2# 3# Copyright (c) 2017 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_key import ( 20 ArgumentSpec, ModuleParameters, ModuleManager 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_key(self): 51 key_content = load_fixture('create_insecure_key1.key') 52 args = dict( 53 content=key_content, 54 name="cert1", 55 partition="Common", 56 state="present", 57 password='password', 58 server='localhost', 59 user='admin' 60 ) 61 p = ModuleParameters(params=args) 62 assert p.name == 'cert1' 63 assert p.key_filename == 'cert1.key' 64 assert '-----BEGIN RSA PRIVATE KEY-----' in p.content 65 assert '-----END RSA PRIVATE KEY-----' in p.content 66 assert p.key_checksum == '91bdddcf0077e2bb2a0258aae2ae3117be392e83' 67 assert p.state == 'present' 68 69 70class TestModuleManager(unittest.TestCase): 71 def setUp(self): 72 self.spec = ArgumentSpec() 73 self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_ssl_key.tmos_version') 74 self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_ssl_key.send_teem') 75 self.m2 = self.p2.start() 76 self.m2.return_value = '14.1.0' 77 self.m3 = self.p3.start() 78 self.m3.return_value = True 79 80 def tearDown(self): 81 self.p2.stop() 82 self.p3.stop() 83 84 def test_import_key_no_key_passphrase(self, *args): 85 set_module_args(dict( 86 name='foo', 87 content=load_fixture('cert1.key'), 88 state='present', 89 provider=dict( 90 server='localhost', 91 password='password', 92 user='admin' 93 ) 94 )) 95 96 module = AnsibleModule( 97 argument_spec=self.spec.argument_spec, 98 supports_check_mode=self.spec.supports_check_mode 99 ) 100 101 # Override methods in the specific type of manager 102 cm = ModuleManager(module=module) 103 cm.exists = Mock(side_effect=[False, True]) 104 cm.create_on_device = Mock(return_value=True) 105 cm.remove_uploaded_file_from_device = Mock(return_value=True) 106 107 results = cm.exec_module() 108 109 assert results['changed'] is True 110