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