1c9bffe248
* pip: add test: an error occurs when pip not found * pip: fix TypeError exception when pip executable isn't found
143 lines
6 KiB
Python
143 lines
6 KiB
Python
import json
|
|
|
|
from ansible.compat.tests import unittest
|
|
from ansible.compat.tests.mock import patch
|
|
from ansible.module_utils import basic
|
|
from ansible.module_utils.six.moves import xmlrpc_client
|
|
from ansible.module_utils._text import to_bytes
|
|
from ansible.modules.packaging.os import rhn_channel
|
|
|
|
from ..utils import (set_module_args, AnsibleExitJson, AnsibleFailJson,
|
|
exit_json, fail_json, get_method_name, mock_request)
|
|
|
|
|
|
class TestRhnChannel(unittest.TestCase):
|
|
|
|
def setUp(self):
|
|
self.module = rhn_channel
|
|
self.module.HAS_UP2DATE_CLIENT = True
|
|
|
|
self.mock_exit_fail = patch.multiple(basic.AnsibleModule, exit_json=exit_json, fail_json=fail_json)
|
|
self.mock_exit_fail.start()
|
|
self.addCleanup(self.mock_exit_fail.stop)
|
|
|
|
def tearDown(self):
|
|
pass
|
|
|
|
def test_without_required_parameters(self):
|
|
"""Failure must occurs when all parameters are missing"""
|
|
with self.assertRaises(AnsibleFailJson):
|
|
set_module_args({})
|
|
self.module.main()
|
|
|
|
def test_channel_already_here(self):
|
|
"""Check that result isn't changed"""
|
|
set_module_args({
|
|
'name': 'rhel-x86_64-server-6',
|
|
'sysname': 'server01',
|
|
'url': 'https://rhn.redhat.com/rpc/api',
|
|
'user': 'user',
|
|
'password': 'pass',
|
|
})
|
|
|
|
responses = [
|
|
('auth.login', ['X' * 43]),
|
|
('system.listUserSystems',
|
|
[[{'last_checkin': '2017-08-06 19:49:52.0', 'id': '0123456789', 'name': 'server01'}]]),
|
|
('channel.software.listSystemChannels',
|
|
[[{'channel_name': 'Red Hat Enterprise Linux Server (v. 6 for 64-bit x86_64)', 'channel_label': 'rhel-x86_64-server-6'}]]),
|
|
('auth.logout', [1]),
|
|
]
|
|
|
|
with mock_request(responses, self.module.__name__):
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertFalse(result.exception.args[0]['changed'])
|
|
self.assertFalse(responses) # all responses should have been consumed
|
|
|
|
def test_add_channel(self):
|
|
"""Add another channel: check that result is changed"""
|
|
set_module_args({
|
|
'name': 'rhel-x86_64-server-6-debuginfo',
|
|
'sysname': 'server01',
|
|
'url': 'https://rhn.redhat.com/rpc/api',
|
|
'user': 'user',
|
|
'password': 'pass',
|
|
})
|
|
|
|
responses = [
|
|
('auth.login', ['X' * 43]),
|
|
('system.listUserSystems',
|
|
[[{'last_checkin': '2017-08-06 19:49:52.0', 'id': '0123456789', 'name': 'server01'}]]),
|
|
('channel.software.listSystemChannels',
|
|
[[{'channel_name': 'Red Hat Enterprise Linux Server (v. 6 for 64-bit x86_64)', 'channel_label': 'rhel-x86_64-server-6'}]]),
|
|
('channel.software.listSystemChannels',
|
|
[[{'channel_name': 'Red Hat Enterprise Linux Server (v. 6 for 64-bit x86_64)', 'channel_label': 'rhel-x86_64-server-6'}]]),
|
|
('system.setChildChannels', [1]),
|
|
('auth.logout', [1]),
|
|
]
|
|
|
|
with mock_request(responses, self.module.__name__):
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertTrue(result.exception.args[0]['changed'])
|
|
self.assertFalse(responses) # all responses should have been consumed
|
|
|
|
def test_remove_inexistent_channel(self):
|
|
"""Check that result isn't changed"""
|
|
set_module_args({
|
|
'name': 'rhel-x86_64-server-6-debuginfo',
|
|
'state': 'absent',
|
|
'sysname': 'server01',
|
|
'url': 'https://rhn.redhat.com/rpc/api',
|
|
'user': 'user',
|
|
'password': 'pass',
|
|
})
|
|
|
|
responses = [
|
|
('auth.login', ['X' * 43]),
|
|
('system.listUserSystems',
|
|
[[{'last_checkin': '2017-08-06 19:49:52.0', 'id': '0123456789', 'name': 'server01'}]]),
|
|
('channel.software.listSystemChannels',
|
|
[[{'channel_name': 'Red Hat Enterprise Linux Server (v. 6 for 64-bit x86_64)', 'channel_label': 'rhel-x86_64-server-6'}]]),
|
|
('auth.logout', [1]),
|
|
]
|
|
|
|
with mock_request(responses, self.module.__name__):
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertFalse(result.exception.args[0]['changed'])
|
|
self.assertFalse(responses) # all responses should have been consumed
|
|
|
|
def test_remove_channel(self):
|
|
"""Check that result isn't changed"""
|
|
set_module_args({
|
|
'name': 'rhel-x86_64-server-6-debuginfo',
|
|
'state': 'absent',
|
|
'sysname': 'server01',
|
|
'url': 'https://rhn.redhat.com/rpc/api',
|
|
'user': 'user',
|
|
'password': 'pass',
|
|
})
|
|
|
|
responses = [
|
|
('auth.login', ['X' * 43]),
|
|
('system.listUserSystems',
|
|
[[{'last_checkin': '2017-08-06 19:49:52.0', 'id': '0123456789', 'name': 'server01'}]]),
|
|
('channel.software.listSystemChannels', [[
|
|
{'channel_name': 'RHEL Server Debuginfo (v.6 for x86_64)', 'channel_label': 'rhel-x86_64-server-6-debuginfo'},
|
|
{'channel_name': 'Red Hat Enterprise Linux Server (v. 6 for 64-bit x86_64)', 'channel_label': 'rhel-x86_64-server-6'}
|
|
]]),
|
|
('channel.software.listSystemChannels', [[
|
|
{'channel_name': 'RHEL Server Debuginfo (v.6 for x86_64)', 'channel_label': 'rhel-x86_64-server-6-debuginfo'},
|
|
{'channel_name': 'Red Hat Enterprise Linux Server (v. 6 for 64-bit x86_64)', 'channel_label': 'rhel-x86_64-server-6'}
|
|
]]),
|
|
('system.setChildChannels', [1]),
|
|
('auth.logout', [1]),
|
|
]
|
|
|
|
with mock_request(responses, self.module.__name__):
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertTrue(result.exception.args[0]['changed'])
|
|
self.assertFalse(responses) # all responses should have been consumed
|