1# -*- coding: utf-8 -*-
2#
3# Copyright: (c) 2018, 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_apm_policy_import import (
20    ModuleParameters, ModuleManager, ArgumentSpec
21)
22from ansible_collections.f5networks.f5_modules.tests.unit.modules.utils import set_module_args
23from ansible_collections.f5networks.f5_modules.tests.unit.compat import unittest
24from ansible_collections.f5networks.f5_modules.tests.unit.compat.mock import (
25    Mock, patch
26)
27
28
29fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
30fixture_data = {}
31
32
33def load_fixture(name):
34    path = os.path.join(fixture_path, name)
35
36    if path in fixture_data:
37        return fixture_data[path]
38
39    with open(path) as f:
40        data = f.read()
41
42    try:
43        data = json.loads(data)
44    except Exception:
45        pass
46
47    fixture_data[path] = data
48    return data
49
50
51class TestParameters(unittest.TestCase):
52    def test_module_parameters(self):
53        args = dict(
54            name='fake_policy',
55            type='access_policy',
56            source='/var/fake/fake.tar.gz'
57        )
58
59        p = ModuleParameters(params=args)
60        assert p.name == 'fake_policy'
61        assert p.source == '/var/fake/fake.tar.gz'
62        assert p.type == 'access_policy'
63
64
65class TestManager(unittest.TestCase):
66    def setUp(self):
67        self.spec = ArgumentSpec()
68        self.policy = os.path.join(fixture_path, 'fake_policy.tar.gz')
69        self.patcher1 = patch('time.sleep')
70        self.patcher1.start()
71        self.p1 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_apm_policy_import.module_provisioned')
72        self.m1 = self.p1.start()
73        self.m1.return_value = True
74        self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_apm_policy_import.tmos_version')
75        self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_apm_policy_import.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.patcher1.stop()
83        self.p1.stop()
84        self.p2.stop()
85        self.p3.stop()
86
87    def test_import_from_file(self, *args):
88        set_module_args(dict(
89            name='fake_policy',
90            source=self.policy,
91            type='access_policy',
92            provider=dict(
93                server='localhost',
94                password='password',
95                user='admin'
96            ),
97        ))
98
99        module = AnsibleModule(
100            argument_spec=self.spec.argument_spec,
101            supports_check_mode=self.spec.supports_check_mode
102        )
103
104        # Override methods to force specific logic in the module to happen
105        mm = ModuleManager(module=module)
106        mm.version_less_than_14 = Mock(return_value=False)
107        mm.exists = Mock(return_value=False)
108        mm.import_file_to_device = Mock(return_value=True)
109        mm.remove_temp_file_from_device = Mock(return_value=True)
110
111        results = mm.exec_module()
112
113        assert results['changed'] is True
114        assert results['name'] == 'fake_policy'
115        assert results['source'] == self.policy
116