From 0a9f1c9b549d582c205e2a930b66184076dd959f Mon Sep 17 00:00:00 2001 From: Shweta Singh Date: Tue, 14 May 2024 18:14:10 +0530 Subject: [PATCH] Add preconversion check for convert2rhel (#15044) (cherry picked from commit f54260bd6a545314d1d61a67c8b123fcb45db02d) --- tests/foreman/api/test_convert2rhel.py | 57 ++++++++++++++++++++++++-- 1 file changed, 53 insertions(+), 4 deletions(-) diff --git a/tests/foreman/api/test_convert2rhel.py b/tests/foreman/api/test_convert2rhel.py index 2568db7564a..580e6f8de7f 100644 --- a/tests/foreman/api/test_convert2rhel.py +++ b/tests/foreman/api/test_convert2rhel.py @@ -251,7 +251,9 @@ def version(request): @pytest.mark.e2e @pytest.mark.parametrize('version', ['oracle7', 'oracle8'], indirect=True) -def test_convert2rhel_oracle(module_target_sat, oracle, activation_key_rhel, version): +def test_convert2rhel_oracle_with_pre_conversion_template_check( + module_target_sat, oracle, activation_key_rhel, version +): """Convert Oracle linux to RHEL :id: 7fd393f0-551a-4de0-acdd-7f026b485f79 @@ -278,6 +280,29 @@ def test_convert2rhel_oracle(module_target_sat, oracle, activation_key_rhel, ver host_content = module_target_sat.api.Host(id=oracle.hostname).read_json() assert host_content['operatingsystem_name'] == f"OracleLinux {version}" + # Pre-conversion template job + template_id = ( + module_target_sat.api.JobTemplate() + .search(query={'search': 'name="Convert2RHEL analyze"'})[0] + .id + ) + job = module_target_sat.api.JobInvocation().run( + synchronous=False, + data={ + 'job_template_id': template_id, + 'targeting_type': 'static_query', + 'search_query': f'name = {oracle.hostname}', + }, + ) + + # wait for job to complete + module_target_sat.wait_for_tasks( + f'resource_type = JobInvocation and resource_id = {job["id"]}', + poll_timeout=5500, + search_rate=20, + ) + result = module_target_sat.api.JobInvocation(id=job['id']).read() + assert result.succeeded == 1 # execute job 'Convert 2 RHEL' on host template_id = ( module_target_sat.api.JobTemplate().search(query={'search': 'name="Convert to RHEL"'})[0].id @@ -289,7 +314,6 @@ def test_convert2rhel_oracle(module_target_sat, oracle, activation_key_rhel, ver 'inputs': { 'Activation Key': activation_key_rhel.id, 'Restart': 'yes', - 'Data telemetry': 'yes', }, 'targeting_type': 'static_query', 'search_query': f'name = {oracle.hostname}', @@ -315,7 +339,9 @@ def test_convert2rhel_oracle(module_target_sat, oracle, activation_key_rhel, ver @pytest.mark.e2e @pytest.mark.parametrize('version', ['centos7', 'centos8'], indirect=True) -def test_convert2rhel_centos(module_target_sat, centos, activation_key_rhel, version): +def test_convert2rhel_centos_with_pre_conversion_template_check( + module_target_sat, centos, activation_key_rhel, version +): """Convert CentOS linux to RHEL :id: 6f698440-7d85-4deb-8dd9-363ea9003b92 @@ -333,6 +359,30 @@ def test_convert2rhel_centos(module_target_sat, centos, activation_key_rhel, ver host_content = module_target_sat.api.Host(id=centos.hostname).read_json() major = version.split('.')[0] assert host_content['operatingsystem_name'] == f'CentOS {major}' + + # Pre-conversion template job + template_id = ( + module_target_sat.api.JobTemplate() + .search(query={'search': 'name="Convert2RHEL analyze"'})[0] + .id + ) + job = module_target_sat.api.JobInvocation().run( + synchronous=False, + data={ + 'job_template_id': template_id, + 'targeting_type': 'static_query', + 'search_query': f'name = {centos.hostname}', + }, + ) + # wait for job to complete + module_target_sat.wait_for_tasks( + f'resource_type = JobInvocation and resource_id = {job["id"]}', + poll_timeout=5500, + search_rate=20, + ) + result = module_target_sat.api.JobInvocation(id=job['id']).read() + assert result.succeeded == 1 + # execute job 'Convert 2 RHEL' on host template_id = ( module_target_sat.api.JobTemplate().search(query={'search': 'name="Convert to RHEL"'})[0].id @@ -344,7 +394,6 @@ def test_convert2rhel_centos(module_target_sat, centos, activation_key_rhel, ver 'inputs': { 'Activation Key': activation_key_rhel.id, 'Restart': 'yes', - 'Data telemetry': 'yes', }, 'targeting_type': 'static_query', 'search_query': f'name = {centos.hostname}',