From 012207d79d52f6e21c3f97483aaa825973908ca2 Mon Sep 17 00:00:00 2001 From: vsedmik <46570670+vsedmik@users.noreply.github.com> Date: Wed, 21 Feb 2024 13:33:49 +0100 Subject: [PATCH] SCA refactor of Subscription HTTP proxy test (#14133) --- robottelo/host_helpers/api_factory.py | 2 +- tests/foreman/api/test_http_proxy.py | 72 +++++++++++++++------------ 2 files changed, 41 insertions(+), 33 deletions(-) diff --git a/robottelo/host_helpers/api_factory.py b/robottelo/host_helpers/api_factory.py index 027d00d4919..ba830abda2b 100644 --- a/robottelo/host_helpers/api_factory.py +++ b/robottelo/host_helpers/api_factory.py @@ -144,7 +144,7 @@ def enable_sync_redhat_repo(self, rh_repo, org_id, timeout=1500): """Enable the RedHat repo, sync it and returns repo_id""" # Enable RH repo and fetch repository_id repo_id = self.enable_rhrepo_and_fetchid( - basearch=rh_repo['basearch'], + basearch=rh_repo.get('basearch', rh_repo.get('arch', DEFAULT_ARCHITECTURE)), org_id=org_id, product=rh_repo['product'], repo=rh_repo['name'], diff --git a/tests/foreman/api/test_http_proxy.py b/tests/foreman/api/test_http_proxy.py index 4fff1c3bc5f..a8d5b37f3d1 100644 --- a/tests/foreman/api/test_http_proxy.py +++ b/tests/foreman/api/test_http_proxy.py @@ -125,6 +125,7 @@ def test_positive_end_to_end(setup_http_proxy, module_target_sat, module_manifes assert docker_repo['result'] == 'success' +@pytest.mark.e2e @pytest.mark.upgrade @pytest.mark.rhel_ver_match('8') @pytest.mark.run_in_one_thread @@ -135,29 +136,40 @@ def test_positive_end_to_end(setup_http_proxy, module_target_sat, module_manifes ids=['no_http_proxy', 'auth_http_proxy', 'unauth_http_proxy'], ) @pytest.mark.tier3 -def test_positive_auto_attach_with_http_proxy( - setup_http_proxy, module_target_sat, rhel_contenthost, function_entitlement_manifest_org +def test_positive_install_content_with_http_proxy( + setup_http_proxy, module_target_sat, rhel_contenthost, function_sca_manifest_org ): - """Attempt to auto attach a subscription to content host + """Attempt to sync and install RH content on a content host via HTTP proxy. :id: cce888b5-e023-4ee2-bffe-efa9260224ee - :customerscenario: true + :setup: + 1. Satellite with or without Global HTTP proxy set. + 2. Unregistered RHEL contenthost. - :expectedresults: host successfully subscribed, subscription - repository enabled, and repository package installed. + :steps: + 1. Create an LCE and CV. + 2. Sync a RH repository, publish it in the CV, promote to the LCE. + 3. Create an AK using the created entities and override the RH repo to Enabled. + 4. Register the content host using the AK via global registration. + 5. Install a package from the RH repository. - :Team: Phoenix-content + :expectedresults: + 1. RH repos can be synced successfully. + 2. Content host can be registered via AK. + 3. Content can be installed on the content host. - :BZ: 2046337 + :customerscenario: true :parametrized: yes """ - org = function_entitlement_manifest_org + repo_to_use = 'rhae2.9_el8' + pkg_name = 'ansible' + org = function_sca_manifest_org lce = module_target_sat.api.LifecycleEnvironment(organization=org).create() content_view = module_target_sat.api.ContentView(organization=org).create() rh_repo_id = module_target_sat.api_factory.enable_sync_redhat_repo( - constants.REPOS['rhel8_bos'], org.id + constants.REPOS[repo_to_use], org.id ) rh_repo = module_target_sat.api.Repository(id=rh_repo_id).read() assert rh_repo.content_counts['rpm'] >= 1 @@ -167,35 +179,31 @@ def test_positive_auto_attach_with_http_proxy( content_view.publish() content_view = content_view.read() content_view.version[-1].promote(data={'environment_ids': lce.id}) - subscription = module_target_sat.api.Subscription(organization=org.id).search( - query={'search': f'name="{constants.DEFAULT_SUBSCRIPTION_NAME}"'} - ) - assert len(subscription) + activation_key = module_target_sat.api.ActivationKey( content_view=content_view, organization=org, environment=lce, - auto_attach=False, ).create() - activation_key.add_subscriptions(data={'subscription_id': subscription[0].id}) - rhel_contenthost.install_katello_ca(module_target_sat) - rhel_contenthost.register_contenthost(org=org.name, activation_key=activation_key.name) - assert rhel_contenthost.subscribed - module_target_sat.cli.Host.subscription_register( - { - 'organization-id': org.id, - 'content-view-id': content_view.id, - 'lifecycle-environment-id': lce.id, - 'name': rhel_contenthost.hostname, + activation_key.content_override( + data={ + 'content_overrides': [ + {'content_label': constants.REPOS[repo_to_use]['id'], 'value': '1'} + ] } ) - host = module_target_sat.api.Host().search( - query={'search': f'name={rhel_contenthost.hostname}'} - )[0] - # To Do: Use api - module_target_sat.cli.Host.subscription_auto_attach({'host-id': host.id}) - result = rhel_contenthost.execute('yum install -y zsh') - assert result.status == 0, 'package was not installed' + + result = rhel_contenthost.register( + org=org, + activation_keys=activation_key.name, + target=module_target_sat, + loc=None, + ) + assert result.status == 0, f'Failed to register the host: {rhel_contenthost.hostname}' + assert rhel_contenthost.subscribed + + result = rhel_contenthost.execute(f'yum install -y {pkg_name}') + assert result.status == 0, f'{pkg_name} installation failed with: {result.stderr}' @pytest.mark.e2e