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