mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-24 04:54:00 -07:00
Some checks failed
EOL CI / EOL Sanity (Ⓐ2.15) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.15+py2.7) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.15+py3.10) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.15+py3.5) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+alpine3+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+alpine3+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+alpine3+py:azp/posix/3/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/3/) (push) Has been cancelled
import-galaxy / Test to import built collection artifact with Galaxy importer (push) Has been cancelled
Verify REUSE / check (push) Has been cancelled
* Replace compat with equivalent from community.internal_test_tools. * Replace mock with equivalent from community.internal_test_tools.
71 lines
3.4 KiB
Python
71 lines
3.4 KiB
Python
# Copyright (c) Ansible project
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
from ansible.module_utils import basic
|
|
from ansible_collections.community.internal_test_tools.tests.unit.compat.mock import patch
|
|
from ansible_collections.community.internal_test_tools.tests.unit.plugins.modules.utils import set_module_args, AnsibleExitJson, AnsibleFailJson, ModuleTestCase
|
|
from ansible_collections.community.general.plugins.modules import sysupgrade
|
|
|
|
|
|
class TestSysupgradeModule(ModuleTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestSysupgradeModule, self).setUp()
|
|
self.module = sysupgrade
|
|
self.mock_get_bin_path = (patch('ansible.module_utils.basic.AnsibleModule.get_bin_path'))
|
|
self.get_bin_path = self.mock_get_bin_path.start()
|
|
|
|
def tearDown(self):
|
|
super(TestSysupgradeModule, self).tearDown()
|
|
self.mock_get_bin_path.stop()
|
|
|
|
def test_upgrade_success(self):
|
|
""" Upgrade was successful """
|
|
|
|
rc = 0
|
|
stdout = """
|
|
SHA256.sig 100% |*************************************| 2141 00:00
|
|
Signature Verified
|
|
INSTALL.amd64 100% |************************************| 43512 00:00
|
|
base67.tgz 100% |*************************************| 238 MB 02:16
|
|
bsd 100% |*************************************| 18117 KB 00:24
|
|
bsd.mp 100% |*************************************| 18195 KB 00:17
|
|
bsd.rd 100% |*************************************| 10109 KB 00:14
|
|
comp67.tgz 100% |*************************************| 74451 KB 00:53
|
|
game67.tgz 100% |*************************************| 2745 KB 00:03
|
|
man67.tgz 100% |*************************************| 7464 KB 00:04
|
|
xbase67.tgz 100% |*************************************| 22912 KB 00:30
|
|
xfont67.tgz 100% |*************************************| 39342 KB 00:28
|
|
xserv67.tgz 100% |*************************************| 16767 KB 00:24
|
|
xshare67.tgz 100% |*************************************| 4499 KB 00:06
|
|
Verifying sets.
|
|
Fetching updated firmware.
|
|
Will upgrade on next reboot
|
|
"""
|
|
stderr = ""
|
|
|
|
with set_module_args({}):
|
|
with patch.object(basic.AnsibleModule, "run_command") as run_command:
|
|
run_command.return_value = (rc, stdout, stderr)
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertTrue(result.exception.args[0]['changed'])
|
|
|
|
def test_upgrade_failed(self):
|
|
""" Upgrade failed """
|
|
|
|
rc = 1
|
|
stdout = ""
|
|
stderr = "sysupgrade: need root privileges"
|
|
|
|
with set_module_args({}):
|
|
with patch.object(basic.AnsibleModule, "run_command") as run_command_mock:
|
|
run_command_mock.return_value = (rc, stdout, stderr)
|
|
with self.assertRaises(AnsibleFailJson) as result:
|
|
self.module.main()
|
|
self.assertTrue(result.exception.args[0]['failed'])
|
|
self.assertIn('need root', result.exception.args[0]['msg'])
|