mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-24 04:54:00 -07:00
* introduce bootc functionality Signed-off-by: Ryan Cook <rcook@redhat.com> Co-authored-by: Alexei Znamensky <103110+russoz@users.noreply.github.com> * fix of test Signed-off-by: Ryan Cook <rcook@redhat.com> * switch stdout var Signed-off-by: Ryan Cook <rcook@redhat.com> * Feedback on NOTE format Co-authored-by: Felix Fontein <felix@fontein.de> * addition of trailing comma Co-authored-by: Felix Fontein <felix@fontein.de> * addition of trailing comma Co-authored-by: Felix Fontein <felix@fontein.de> * incorporating feedback from russoz Signed-off-by: Ryan Cook <rcook@redhat.com> * error in stdout Signed-off-by: Ryan Cook <rcook@redhat.com> * proper rc checking and status Signed-off-by: Ryan Cook <rcook@redhat.com> * linting Signed-off-by: Ryan Cook <rcook@redhat.com> * Update version Co-authored-by: Felix Fontein <felix@fontein.de> --------- Signed-off-by: Ryan Cook <rcook@redhat.com> Co-authored-by: Alexei Znamensky <103110+russoz@users.noreply.github.com> Co-authored-by: Felix Fontein <felix@fontein.de>
72 lines
3.6 KiB
Python
72 lines
3.6 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_collections.community.general.tests.unit.compat.mock import patch
|
|
from ansible_collections.community.general.plugins.modules import bootc_manage
|
|
from ansible_collections.community.general.tests.unit.plugins.modules.utils import AnsibleExitJson, AnsibleFailJson, ModuleTestCase, set_module_args
|
|
|
|
|
|
class TestBootcManageModule(ModuleTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestBootcManageModule, self).setUp()
|
|
self.module = bootc_manage
|
|
|
|
def tearDown(self):
|
|
super(TestBootcManageModule, self).tearDown()
|
|
|
|
def test_switch_without_image(self):
|
|
"""Failure if state is 'switch' but no image provided"""
|
|
set_module_args({'state': 'switch'})
|
|
with self.assertRaises(AnsibleFailJson) as result:
|
|
self.module.main()
|
|
self.assertEqual(result.exception.args[0]['msg'], "state is switch but all of the following are missing: image")
|
|
|
|
def test_switch_with_image(self):
|
|
"""Test successful switch with image provided"""
|
|
set_module_args({'state': 'switch', 'image': 'example.com/image:latest'})
|
|
with patch('ansible.module_utils.basic.AnsibleModule.run_command') as run_command_mock:
|
|
run_command_mock.return_value = (0, 'Queued for next boot: ', '')
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertTrue(result.exception.args[0]['changed'])
|
|
|
|
def test_latest_state(self):
|
|
"""Test successful upgrade to the latest state"""
|
|
set_module_args({'state': 'latest'})
|
|
with patch('ansible.module_utils.basic.AnsibleModule.run_command') as run_command_mock:
|
|
run_command_mock.return_value = (0, 'Queued for next boot: ', '')
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertTrue(result.exception.args[0]['changed'])
|
|
|
|
def test_latest_state_no_change(self):
|
|
"""Test no change for latest state"""
|
|
set_module_args({'state': 'latest'})
|
|
with patch('ansible.module_utils.basic.AnsibleModule.run_command') as run_command_mock:
|
|
run_command_mock.return_value = (0, 'No changes in ', '')
|
|
with self.assertRaises(AnsibleExitJson) as result:
|
|
self.module.main()
|
|
self.assertFalse(result.exception.args[0]['changed'])
|
|
|
|
def test_switch_image_failure(self):
|
|
"""Test failure during image switch"""
|
|
set_module_args({'state': 'switch', 'image': 'example.com/image:latest'})
|
|
with patch('ansible.module_utils.basic.AnsibleModule.run_command') as run_command_mock:
|
|
run_command_mock.return_value = (1, '', 'ERROR')
|
|
with self.assertRaises(AnsibleFailJson) as result:
|
|
self.module.main()
|
|
self.assertEqual(result.exception.args[0]['msg'], 'ERROR: Command execution failed.')
|
|
|
|
def test_latest_state_failure(self):
|
|
"""Test failure during upgrade"""
|
|
set_module_args({'state': 'latest'})
|
|
with patch('ansible.module_utils.basic.AnsibleModule.run_command') as run_command_mock:
|
|
run_command_mock.return_value = (1, '', 'ERROR')
|
|
with self.assertRaises(AnsibleFailJson) as result:
|
|
self.module.main()
|
|
self.assertEqual(result.exception.args[0]['msg'], 'ERROR: Command execution failed.')
|