From 923effef4f3c4e10dd75bd7717268b4a7d770002 Mon Sep 17 00:00:00 2001 From: Shubham Ganar <67952129+shubhamsg199@users.noreply.github.com> Date: Wed, 19 Jun 2024 14:56:06 +0530 Subject: [PATCH] Add OS Parameters to end to end test (#15412) Signed-off-by: Shubham Ganar (cherry picked from commit b5e459d2ba5079aecd3b498e927aff1e32b75959) --- tests/foreman/api/test_operatingsystem.py | 52 +++++++++-------------- 1 file changed, 19 insertions(+), 33 deletions(-) diff --git a/tests/foreman/api/test_operatingsystem.py b/tests/foreman/api/test_operatingsystem.py index 92356158054..0906af66629 100644 --- a/tests/foreman/api/test_operatingsystem.py +++ b/tests/foreman/api/test_operatingsystem.py @@ -12,7 +12,6 @@ """ -from http.client import NOT_FOUND import random from fauxfactory import gen_string @@ -27,38 +26,6 @@ ) -class TestOperatingSystemParameter: - """Tests for operating system parameters.""" - - @pytest.mark.tier1 - @pytest.mark.upgrade - def test_verify_bugzilla_1114640(self, target_sat): - """Create a parameter for operating system 1. - - :id: e817ae43-226c-44e3-b559-62b8d394047b - - :expectedresults: A parameter is created and can be read afterwards. - - :CaseImportance: Critical - """ - # Check whether OS 1 exists. - os1 = target_sat.api.OperatingSystem(id=1).read_raw() - if os1.status_code == NOT_FOUND and target_sat.api.OperatingSystem().create().id != 1: - pytest.skip('Cannot execute test, as operating system 1 is not available.') - - # Create and read a parameter for operating system 1. The purpose of - # this test is to make sure an HTTP 422 is not returned, but we're also - # going to verify the name and value of the parameter, just for good - # measure. - name = gen_string('utf8') - value = gen_string('utf8') - os_param = target_sat.api.OperatingSystemParameter( - name=name, operatingsystem=1, value=value - ).create() - assert os_param.name == name - assert os_param.value == value - - class TestOperatingSystem: """Tests for operating systems.""" @@ -88,6 +55,7 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch minor_version = gen_string('numeric') major_version = gen_string('numeric', 5) pass_hash = 'SHA256' + os_parameters = [{'name': gen_string('alpha'), 'value': gen_string('alpha')}] ptable = module_target_sat.api.PartitionTable().create() medium = module_target_sat.api.Media(organization=[module_org]).create() template = module_target_sat.api.ProvisioningTemplate( @@ -105,6 +73,7 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch provisioning_template=[template], ptable=[ptable], medium=[medium], + os_parameters_attributes=os_parameters, ).create() assert os.name == name assert os.family == os_family @@ -116,6 +85,8 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch assert os.ptable[0].id == ptable.id assert os.provisioning_template[0].id == template.id assert os.medium[0].id == medium.id + assert os.os_parameters_attributes[0]['name'] == os_parameters[0]['name'] + assert os.os_parameters_attributes[0]['value'] == os_parameters[0]['value'] # Read OS os = module_target_sat.api.OperatingSystem(id=os.id).read() assert os.name == name @@ -128,6 +99,8 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch assert str(ptable.id) in str(os.ptable) assert str(template.id) in str(os.provisioning_template) assert os.medium[0].id == medium.id + assert os.os_parameters_attributes[0]['name'] == os_parameters[0]['name'] + assert os.os_parameters_attributes[0]['value'] == os_parameters[0]['value'] new_name = gen_string('alpha') new_desc = gen_string('alpha') new_os_family = 'Rhcos' @@ -140,6 +113,7 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch new_template = module_target_sat.api.ProvisioningTemplate( organization=[module_org] ).create() + new_os_parameters = [{'name': gen_string('alpha'), 'value': gen_string('alpha')}] # Update OS os = module_target_sat.api.OperatingSystem( id=os.id, @@ -153,6 +127,7 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch provisioning_template=[new_template], ptable=[new_ptable], medium=[new_medium], + os_parameters_attributes=new_os_parameters, ).update( [ 'name', @@ -165,6 +140,7 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch 'provisioning_template', 'ptable', 'medium', + 'os_parameters_attributes', ] ) assert os.name == new_name @@ -177,6 +153,16 @@ def test_positive_end_to_end_os(self, module_target_sat, module_org, module_arch assert os.ptable[0].id == new_ptable.id assert os.provisioning_template[0].id == new_template.id assert os.medium[0].id == new_medium.id + assert os.os_parameters_attributes[0]['name'] == new_os_parameters[0]['name'] + assert os.os_parameters_attributes[0]['value'] == new_os_parameters[0]['value'] + # Delete OS Parameter + module_target_sat.api.OperatingSystemParameter( + operatingsystem=os.id, id=new_os_parameters[0]['name'] + ).delete() + with pytest.raises(HTTPError): + module_target_sat.api.OperatingSystemParameter( + operatingsystem=os.id, id=new_os_parameters[0]['name'] + ).read() # Delete OS module_target_sat.api.OperatingSystem(id=os.id).delete() with pytest.raises(HTTPError):