Skip to content

Commit

Permalink
Fix foreman-maintain tests failing because of automation issues
Browse files Browse the repository at this point in the history
  • Loading branch information
jameerpathan111 authored and ogajduse committed Sep 6, 2023
1 parent e9ad5fb commit 5b7dc33
Show file tree
Hide file tree
Showing 8 changed files with 91 additions and 133 deletions.
31 changes: 21 additions & 10 deletions pytest_fixtures/component/maintain.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
from robottelo.constants import SATELLITE_MAINTAIN_YML
from robottelo.hosts import Capsule
from robottelo.hosts import Satellite
from robottelo.hosts import SatelliteHostError
from robottelo.logging import logger

synced_repos = pytest.StashKey[dict]

Expand All @@ -21,16 +23,27 @@ def module_stash(request):
yield request.node.stash


@pytest.fixture(scope='session')
def sat_maintain(request, session_target_sat, session_capsule_configured):
@pytest.fixture(scope='module')
def sat_maintain(request, module_target_sat, module_capsule_configured):
if settings.remotedb.server:
yield Satellite(settings.remotedb.server)
else:
session_target_sat.register_to_cdn(pool_ids=settings.subscription.fm_rhn_poolid.split())
hosts = {'satellite': session_target_sat, 'capsule': session_capsule_configured}
module_target_sat.register_to_cdn(pool_ids=settings.subscription.fm_rhn_poolid.split())
hosts = {'satellite': module_target_sat, 'capsule': module_capsule_configured}
yield hosts[request.param]


@pytest.fixture
def start_satellite_services(sat_maintain):
"""Teardown for satellite-maintain tests to ensure that all Satellite services are started"""
yield
logger.info('Ensuring that all %s services are running', sat_maintain.__class__.__name__)
result = sat_maintain.cli.Service.start()
if result.status != 0:
logger.error('Unable to start all %s services', sat_maintain.__class__.__name__)
raise SatelliteHostError('Failed to start Satellite services')


@pytest.fixture
def setup_backup_tests(request, sat_maintain):
"""Teardown for backup/restore tests"""
Expand All @@ -42,9 +55,7 @@ def _finalize():


@pytest.fixture(scope='module')
def module_synced_repos(
sat_maintain, session_capsule_configured, module_sca_manifest, module_stash
):
def module_synced_repos(sat_maintain, module_capsule_configured, module_sca_manifest, module_stash):
if not module_stash[synced_repos]:
org = sat_maintain.satellite.api.Organization().create()
sat_maintain.satellite.upload_manifest(org.id, module_sca_manifest.content)
Expand Down Expand Up @@ -80,13 +91,13 @@ def module_synced_repos(
lce = sat_maintain.satellite.api.LifecycleEnvironment(
organization=module_stash[synced_repos]['org']
).search(query={'search': f'name={constants.ENVIRONMENT}'})[0]
session_capsule_configured.nailgun_capsule.content_add_lifecycle_environment(
module_capsule_configured.nailgun_capsule.content_add_lifecycle_environment(
data={'environment_id': lce.id}
)
result = session_capsule_configured.nailgun_capsule.content_lifecycle_environments()
result = module_capsule_configured.nailgun_capsule.content_lifecycle_environments()
assert lce.id in [capsule_lce['id'] for capsule_lce in result['results']]
# sync the Capsule
sync_status = session_capsule_configured.nailgun_capsule.content_sync()
sync_status = module_capsule_configured.nailgun_capsule.content_sync()
assert sync_status['result'] == 'success'

yield {
Expand Down
1 change: 1 addition & 0 deletions robottelo/constants/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ class Colored(Box):
# This should be updated after each version branch
SATELLITE_VERSION = "6.14"
SATELLITE_OS_VERSION = "8"
SAT_NON_GA_VERSIONS = ['6.14', '6.15']

# Default system ports
HTTPS_PORT = '443'
Expand Down
9 changes: 4 additions & 5 deletions robottelo/host_helpers/contenthost_mixins.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ def OSCAP(self):
'cbrhel': constants.OSCAP_PROFILE[f'cbrhel{self._v_major}'],
}

def _dogfood_helper(self, product, release, snap, repo=None):
def _dogfood_helper(self, product, release, repo=None):
"""Function to return repository related attributes
based on the input and the host object
"""
Expand All @@ -89,18 +89,17 @@ def _dogfood_helper(self, product, release, snap, repo=None):
'or the version of the Satellite object. '
f'settings: {settings_release}, parameter: {release}'
)
snap = str(snap or settings.server.version.get("snap"))
return product, release, snap, v_major, repo
return product, release, v_major, repo

def download_repofile(self, product=None, release=None, snap=''):
"""Downloads the tools/client, capsule, or satellite repos on the machine"""
product, release, snap, v_major, _ = self._dogfood_helper(product, release, snap)
product, release, v_major, _ = self._dogfood_helper(product, release)
url = dogfood_repofile_url(settings.ohsnap, product, release, v_major, snap)
self.execute(f'curl -o /etc/yum.repos.d/dogfood.repo -L {url}')

def dogfood_repository(self, repo=None, product=None, release=None, snap=''):
"""Returns a repository definition based on the arguments provided"""
product, release, snap, v_major, repo = self._dogfood_helper(product, release, snap, repo)
product, release, v_major, repo = self._dogfood_helper(product, release, repo)
return dogfood_repository(settings.ohsnap, repo, product, release, v_major, snap, self.arch)

def enable_tools_repo(self, organization_id):
Expand Down
145 changes: 45 additions & 100 deletions tests/foreman/maintain/test_advanced.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,67 +22,26 @@
from robottelo.config import robottelo_tmp_dir
from robottelo.config import settings
from robottelo.constants import MAINTAIN_HAMMER_YML
from robottelo.constants import SAT_NON_GA_VERSIONS
from robottelo.hosts import get_sat_rhel_version
from robottelo.hosts import get_sat_version

pytestmark = pytest.mark.destructive


# Common repositories for Satellite and Capsule
common_repos = ['rhel-8-for-x86_64-baseos-rpms', 'rhel-8-for-x86_64-appstream-rpms']

# Satellite repositories
sat_611_repos = [
'satellite-6.11-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.11-for-rhel-8-x86_64-rpms',
] + common_repos

sat_612_repos = [
'satellite-6.12-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.12-for-rhel-8-x86_64-rpms',
] + common_repos

sat_613_repos = [
'satellite-6.13-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.13-for-rhel-8-x86_64-rpms',
] + common_repos

sat_614_repos = [
'satellite-6.14-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.14-for-rhel-8-x86_64-rpms',
] + common_repos

# Capsule repositories
cap_611_repos = [
'satellite-capsule-6.11-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.11-for-rhel-8-x86_64-rpms',
] + common_repos

cap_612_repos = [
'satellite-capsule-6.12-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.12-for-rhel-8-x86_64-rpms',
] + common_repos

cap_613_repos = [
'satellite-capsule-6.13-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.13-for-rhel-8-x86_64-rpms',
] + common_repos

cap_614_repos = [
'satellite-capsule-6.14-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6.14-for-rhel-8-x86_64-rpms',
] + common_repos

sat_repos = {
'6.11': sat_611_repos,
'6.12': sat_612_repos,
'6.13': sat_613_repos,
'6.14': sat_614_repos,
}
cap_repos = {
'6.11': cap_611_repos,
'6.12': cap_612_repos,
'6.13': cap_613_repos,
'6.14': cap_614_repos,
}

sat_x_y_release = f'{get_sat_version().major}.{get_sat_version().minor}'


def get_satellite_capsule_repos(
x_y_release=sat_x_y_release, product='satellite', os_major_ver=get_sat_rhel_version().major
):
if product == 'capsule':
product = 'satellite-capsule'
repos = [
f'{product}-{x_y_release}-for-rhel-{os_major_ver}-x86_64-rpms',
f'satellite-maintenance-{x_y_release}-for-rhel-{os_major_ver}-x86_64-rpms',
f'rhel-{os_major_ver}-for-x86_64-baseos-rpms',
f'rhel-{os_major_ver}-for-x86_64-appstream-rpms',
]
return repos


def test_positive_advanced_run_service_restart(sat_maintain):
Expand Down Expand Up @@ -299,7 +258,7 @@ def test_positive_sync_plan_with_hammer_defaults(request, sat_maintain, module_o
:customerscenario: true
"""
sat_maintain.cli.Defaults.add({'param-name': 'organization_id', 'param-value': 1})
sat_maintain.cli.Defaults.add({'param-name': 'organization_id', 'param-value': module_org.id})

sync_plans = []
for name in ['plan1', 'plan2']:
Expand All @@ -321,6 +280,11 @@ def test_positive_sync_plan_with_hammer_defaults(request, sat_maintain, module_o
def _finalize():
sat_maintain.cli.Defaults.delete({'param-name': 'organization_id'})
sync_plans[1].delete()
sync_plan = sat_maintain.api.SyncPlan(organization=module_org.id).search(
query={'search': f'name="{sync_plans[0]}"'}
)
if sync_plan:
sync_plans[0].delete()


@pytest.mark.e2e
Expand All @@ -336,21 +300,21 @@ def test_positive_satellite_repositories_setup(sat_maintain):
:expectedresults: Required Satellite repositories for install/upgrade should get enabled
"""
supported_versions = ['6.11', '6.12', '6.13']
for ver in supported_versions:
result = sat_maintain.cli.Advanced.run_repositories_setup(options={'version': ver})
sat_version = ".".join(sat_maintain.version.split('.')[0:2])
result = sat_maintain.cli.Advanced.run_repositories_setup(options={'version': sat_version})
if sat_version not in SAT_NON_GA_VERSIONS:
assert result.status == 0
assert 'FAIL' not in result.stdout
result = sat_maintain.execute('yum repolist')
for repo in sat_repos[ver]:
for repo in get_satellite_capsule_repos(sat_version):
assert repo in result.stdout

# 6.14 till not GA
result = sat_maintain.cli.Advanced.run_repositories_setup(options={'version': '6.14'})
assert result.status == 1
assert 'FAIL' in result.stdout
for repo in sat_repos['6.14']:
assert repo in result.stdout
# for non-ga versions
else:
assert result.status == 1
assert 'FAIL' in result.stdout
for repo in get_satellite_capsule_repos(sat_version):
assert repo in result.stdout


@pytest.mark.e2e
Expand All @@ -369,36 +333,17 @@ def test_positive_capsule_repositories_setup(sat_maintain):
:expectedresults: Required Capsule repositories should get enabled
"""
supported_versions = ['6.11', '6.12']
for ver in supported_versions:
result = sat_maintain.cli.Advanced.run_repositories_setup(options={'version': ver})
sat_version = ".".join(sat_maintain.version.split('.')[0:2])
result = sat_maintain.cli.Advanced.run_repositories_setup(options={'version': sat_version})
if sat_version not in SAT_NON_GA_VERSIONS:
assert result.status == 0
assert 'FAIL' not in result.stdout
result = sat_maintain.execute('yum repolist')
for repo in cap_repos[ver]:
for repo in get_satellite_capsule_repos(sat_version, 'capsule'):
assert repo in result.stdout
# for non-ga versions
else:
assert result.status == 1
assert 'FAIL' in result.stdout
for repo in get_satellite_capsule_repos(sat_version, 'capsule'):
assert repo in result.stdout

# 6.13 till not GA
result = sat_maintain.cli.Advanced.run_repositories_setup(options={'version': '6.13'})
assert result.status == 1
assert 'FAIL' in result.stdout
for repo in cap_repos['6.13']:
assert repo in result.stdout

# Verify that all required beta repositories gets enabled
# maintain beta repo is unavailable for EL8 https://bugzilla.redhat.com/show_bug.cgi?id=2106750
cap_beta_repo = common_repos
missing_beta_el8_repos = [
'satellite-capsule-6-beta-for-rhel-8-x86_64-rpms',
'satellite-maintenance-6-beta-for-rhel-8-x86_64-rpms',
]
result = sat_maintain.cli.Advanced.run_repositories_setup(
options={'version': '6.12'}, env_var='FOREMAN_MAINTAIN_USE_BETA=1'
)
assert result.status != 0
assert 'FAIL' in result.stdout
for repo in missing_beta_el8_repos:
assert f"Error: '{repo}' does not match a valid repository ID" in result.stdout
result = sat_maintain.execute('yum repolist')
for repo in cap_beta_repo:
assert repo in result.stdout
8 changes: 2 additions & 6 deletions tests/foreman/maintain/test_health.py
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,8 @@ def test_positive_health_check_server_ping(sat_maintain):
assert 'FAIL' not in result.stdout


def test_health_check_server_ping(sat_maintain, request):
@pytest.mark.usefixtures('start_satellite_services')
def test_health_check_server_ping(sat_maintain):
"""Verify health check server-ping
:id: ecdc5bfb-2adf-49f6-948d-995dae34bcd3
Expand All @@ -185,10 +186,6 @@ def test_health_check_server_ping(sat_maintain, request):
assert result.status == 0
assert 'FAIL' in result.stdout

@request.addfinalizer
def _finalize():
assert sat_maintain.cli.Service.start().status == 0


@pytest.mark.include_capsule
def test_negative_health_check_upstream_repository(sat_maintain, request):
Expand Down Expand Up @@ -225,7 +222,6 @@ def _finalize():
sat_maintain.execute('dnf clean all')


@pytest.mark.include_capsule
def test_positive_health_check_available_space(sat_maintain):
"""Verify available-space check
Expand Down
2 changes: 0 additions & 2 deletions tests/foreman/maintain/test_maintenance_mode.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,6 @@

from robottelo.config import robottelo_tmp_dir

pytestmark = pytest.mark.destructive


@pytest.mark.e2e
@pytest.mark.tier2
Expand Down
13 changes: 6 additions & 7 deletions tests/foreman/maintain/test_service.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,6 @@
from robottelo.constants import SATELLITE_ANSWER_FILE
from robottelo.hosts import Satellite

pytestmark = pytest.mark.destructive

SATELLITE_SERVICES = [
"[email protected]",
"foreman-proxy.service",
Expand Down Expand Up @@ -94,6 +92,7 @@ def test_positive_service_list(sat_maintain):


@pytest.mark.include_capsule
@pytest.mark.usefixtures('start_satellite_services')
def test_positive_service_stop_start(sat_maintain):
"""Start/Stop services using satellite-maintain service subcommand
Expand Down Expand Up @@ -124,6 +123,7 @@ def test_positive_service_stop_start(sat_maintain):


@pytest.mark.include_capsule
@pytest.mark.usefixtures('start_satellite_services')
def test_positive_service_stop_restart(sat_maintain):
"""Disable services using satellite-maintain service
Expand Down Expand Up @@ -156,6 +156,7 @@ def test_positive_service_stop_restart(sat_maintain):


@pytest.mark.include_capsule
@pytest.mark.usefixtures('start_satellite_services')
def test_positive_service_enable_disable(sat_maintain):
"""Enable/Disable services using satellite-maintain service subcommand
Expand All @@ -180,7 +181,8 @@ def test_positive_service_enable_disable(sat_maintain):
assert result.status == 0


def test_positive_foreman_service(request, sat_maintain):
@pytest.mark.usefixtures('start_satellite_services')
def test_positive_foreman_service(sat_maintain):
"""Validate httpd service should work as expected even stopping of the foreman service
:id: 08a29ea2-2e49-11eb-a22b-d46d6dd3b5b2
Expand All @@ -201,10 +203,7 @@ def test_positive_foreman_service(request, sat_maintain):
result = sat_maintain.cli.Health.check(options={'assumeyes': True})
assert result.status == 0
assert 'foreman' in result.stdout

@request.addfinalizer
def _finalize():
assert sat_maintain.cli.Service.start(options={'only': 'foreman'}).status == 0
assert sat_maintain.cli.Service.start(options={'only': 'foreman'}).status == 0


@pytest.mark.include_capsule
Expand Down
Loading

0 comments on commit 5b7dc33

Please sign in to comment.