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_monitor_mysql 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
26fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
27fixture_data = {}
28
29
30def load_fixture(name):
31    path = os.path.join(fixture_path, name)
32
33    if path in fixture_data:
34        return fixture_data[path]
35
36    with open(path) as f:
37        data = f.read()
38
39    try:
40        data = json.loads(data)
41    except Exception:
42        pass
43
44    fixture_data[path] = data
45    return data
46
47
48class TestParameters(unittest.TestCase):
49    def test_module_parameters(self):
50        args = dict(
51            parent='/Common/mysql',
52            interval=5,
53            timeout=120,
54            time_until_up=20,
55            target_username='foobar',
56            send='SELECT * from v$instance1',
57            database='instance1',
58            recv='OPEN',
59            recv_column='1',
60            recv_row='1',
61            count=10,
62            manual_resume=True,
63            debug=True
64        )
65        p = ModuleParameters(params=args)
66        assert p.parent == '/Common/mysql'
67        assert p.interval == 5
68        assert p.timeout == 120
69        assert p.time_until_up == 20
70        assert p.target_username == 'foobar'
71        assert p.send == 'SELECT * from v$instance1'
72        assert p.recv == 'OPEN'
73        assert p.count == 10
74        assert p.recv_column == '1'
75        assert p.recv_row == '1'
76        assert p.manual_resume == 'enabled'
77        assert p.debug == 'yes'
78
79    def test_api_parameters(self):
80        args = load_fixture('load_bigip_monitor_mysql.json')
81        p = ApiParameters(params=args)
82        assert p.parent == '/Common/mysql'
83        assert p.ip == '1.1.1.1'
84        assert p.port == '30025'
85        assert p.time_until_up == 0
86        assert p.up_interval == 0
87        assert p.manual_resume == 'disabled'
88        assert p.target_username == 'some_user'
89        assert p.timeout == 60
90        assert p.count == 0
91        assert p.send == 'this is send string'
92        assert p.recv == 'this is recv string'
93        assert p.recv_column == '1'
94        assert p.recv_row == '2'
95
96
97class TestManager(unittest.TestCase):
98    def setUp(self):
99        self.spec = ArgumentSpec()
100        self.p2 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_monitor_mysql.tmos_version')
101        self.p3 = patch('ansible_collections.f5networks.f5_modules.plugins.modules.bigip_monitor_mysql.send_teem')
102        self.m2 = self.p2.start()
103        self.m2.return_value = '14.1.0'
104        self.m3 = self.p3.start()
105        self.m3.return_value = True
106
107    def tearDown(self):
108        self.p2.stop()
109        self.p3.stop()
110
111    def test_create(self, *args):
112        set_module_args(dict(
113            name='mysqdb',
114            parent='/Common/mysql',
115            interval=10,
116            timeout=30,
117            time_until_up=5,
118            target_username='foobar',
119            send='SELECT * from v$instance1',
120            database='instance1',
121            recv='OPEN',
122            recv_column='1',
123            recv_row='1',
124            count=10,
125            manual_resume=True,
126            debug=True,
127            provider=dict(
128                server='localhost',
129                password='password',
130                user='admin'
131            )
132        ))
133
134        module = AnsibleModule(
135            argument_spec=self.spec.argument_spec,
136            supports_check_mode=self.spec.supports_check_mode
137        )
138
139        # Override methods in the specific type of manager
140        mm = ModuleManager(module=module)
141        mm.exists = Mock(side_effect=[False, True])
142        mm.create_on_device = Mock(return_value=True)
143
144        results = mm.exec_module()
145
146        assert results['changed'] is True
147