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