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 18from ansible_collections.f5networks.f5_modules.plugins.modules.bigip_asm_policy_import import ( 19 ApiParameters, ModuleParameters, ModuleManager, ArgumentSpec 20) 21from ansible_collections.f5networks.f5_modules.tests.unit.modules.utils import set_module_args 22from ansible_collections.f5networks.f5_modules.tests.unit.compat import unittest 23from ansible_collections.f5networks.f5_modules.tests.unit.compat.mock import ( 24 Mock, patch 25) 26 27 28fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures') 29fixture_data = {} 30 31 32def load_fixture(name): 33 path = os.path.join(fixture_path, name) 34 35 if path in fixture_data: 36 return fixture_data[path] 37 38 with open(path) as f: 39 data = f.read() 40 41 try: 42 data = json.loads(data) 43 except Exception: 44 pass 45 46 fixture_data[path] = data 47 return data 48 49 50class TestParameters(unittest.TestCase): 51 def test_module_parameters(self): 52 args = dict( 53 name='fake_policy', 54 state='present', 55 source='/var/fake/fake.xml' 56 ) 57 58 p = ModuleParameters(params=args) 59 assert p.name == 'fake_policy' 60 assert p.source == '/var/fake/fake.xml' 61 62 63class TestManager(unittest.TestCase): 64 def setUp(self): 65 self.spec = ArgumentSpec() 66 self.policy = os.path.join(fixture_path, 'fake_policy.xml') 67 self.patcher1 = patch('time.sleep') 68 self.patcher1.start() 69 self.p1 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_asm_policy_import.module_provisioned') 70 self.m1 = self.p1.start() 71 self.m1.return_value = True 72 self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_asm_policy_import.tmos_version') 73 self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_asm_policy_import.send_teem') 74 self.m2 = self.p2.start() 75 self.m2.return_value = '14.1.0' 76 self.m3 = self.p3.start() 77 self.m3.return_value = True 78 79 def tearDown(self): 80 self.patcher1.stop() 81 self.p1.stop() 82 self.p2.stop() 83 self.p3.stop() 84 85 def test_import_from_file(self, *args): 86 set_module_args(dict( 87 name='fake_policy', 88 source=self.policy, 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 mutually_exclusive=self.spec.mutually_exclusive, 100 ) 101 102 # Override methods to force specific logic in the module to happen 103 mm = ModuleManager(module=module) 104 mm.exists = Mock(return_value=False) 105 mm.import_file_to_device = Mock(return_value=True) 106 mm.remove_temp_policy_from_device = Mock(return_value=True) 107 108 results = mm.exec_module() 109 110 assert results['changed'] is True 111 assert results['name'] == 'fake_policy' 112 assert results['source'] == self.policy 113