Skip to content

Commit

Permalink
Fix satellite_maintain_upgrade_list_versions scenarios
Browse files Browse the repository at this point in the history
  • Loading branch information
lpramuk authored and damoore044 committed Oct 10, 2023
1 parent a687f3e commit a2e38dd
Showing 1 changed file with 21 additions and 99 deletions.
120 changes: 21 additions & 99 deletions tests/upgrades/test_satellite_maintain.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
"""Test for Satellite-maintain related Upgrade Scenario's
"""satellite-maintain Upgrade Scenarios
:Requirement: UpgradedSatellite
Expand All @@ -16,12 +16,13 @@
:Upstream: No
"""
import re

import pytest


class TestSatelliteMaintain:
"""The test class contains pre-upgrade and post-upgrade scenarios to test
satellite-maintain utility
"""Pre-upgrade and post-upgrade scenarios to test satellite-maintain utility.
Test Steps:
1. Before Satellite upgrade, Perform test for "satellite-maintain upgrade list-versions"
Expand All @@ -32,123 +33,44 @@ class TestSatelliteMaintain:

@staticmethod
def satellite_upgradable_version_list(sat_obj):
"""
This function is used to collect the details of satellite version and upgradable
version list.
:return: satellite_version, upgradeable_version, major_version_change
"""

cmd = "rpm -q satellite > /dev/null && rpm -q satellite --queryformat=%{VERSION}"
# leaving this section as-is for now but this could be refactored to use sat_obj.version
satellite_version = sat_obj.execute(cmd)
if satellite_version.status == 0:
satellite_version = satellite_version.stdout
else:
return [], [], None, None
satellite_maintain_version = sat_obj.execute(
"satellite-maintain upgrade list-versions --disable-self-upgrade"
)
upgradeable_version = [
version for version in satellite_maintain_version.stdout if version != ''
]
version_change = 0
for version in upgradeable_version:
version_change += int(version.split('.')[0])
if version_change % 2 == 0:
major_version_change = False
y_version = ''
else:
major_version_change = True
y_version = list(set(satellite_maintain_version) - set(satellite_version))[0].split(
'.'
)[-1]

return satellite_version, upgradeable_version, major_version_change, y_version
"""Obtain upgradable version list by satellite-maintain.
@staticmethod
def version_details(
satellite_version, major_version_change, y_version, upgrade_stage="pre-upgrade"
):
"""
This function is used to update the details of zstream upgrade and
next version upgrade
:param str satellite_version: satellite version would be like 6.5.0, 6.6.0, 6.7.0
:param bool major_version_change: For major version upgrade like 6.8 to 7.0, 7.0
to 8.0 etc, then major_version_change would be True.
:param str y_version: y_version change depends on major_version_change
:param str upgrade_stage: upgrade stage would be pre or post.
:return: zstream_version, next_version
:return: upgradeable_versions
"""

major_version = satellite_version.split('.')[0:1]
if major_version_change:
major_version = [int(major_version[0]) + 1].append(y_version)
else:
y_version = int(satellite_version.split('.')[0:2][-1])
zstream_version = ''
if upgrade_stage == "pre-upgrade":
major_version.append(str(y_version + 1))
zstream_version = ".".join(satellite_version.split('.')[0:2]) + ".z"
else:
major_version.append(str(y_version))
major_version.append("z")
next_version = ".".join(major_version)
return zstream_version, next_version
cmd = 'satellite-maintain upgrade list-versions --disable-self-upgrade'
list_versions = sat_obj.execute(cmd).stdout
regex = re.compile(r'^\d+\.\d+')
upgradeable_versions = [version for version in list_versions if regex.match(version)]
return upgradeable_versions

@pytest.mark.pre_upgrade
def test_pre_satellite_maintain_upgrade_list_versions(self, target_sat):
"""Pre-upgrade sceanrio that tests list of satellite version
which satellite can be upgraded.
"""Test list of satellite target versions before upgrade.
:id: preupgrade-fc2c54b2-2663-11ea-b47c-48f17f1fc2e1
:steps:
1. Run satellite-maintain upgrade list-versions
:expectedresults: Versions should be current z-stream.
"""
(
satellite_version,
upgradable_version,
major_version_change,
y_version,
) = self.satellite_upgradable_version_list(target_sat)
if satellite_version:
# In future If satellite-maintain packages update add before
# pre-upgrade test case execution then next version kind of
# stuff check we can add it here.
zstream_version, next_version = self.version_details(
satellite_version[0], major_version_change, y_version
)
else:
zstream_version = -1
assert zstream_version in upgradable_version
zstream = '.'.join(target_sat.version.split('.')[0:2]) + '.z'
upgradable_versions = self.satellite_upgradable_version_list(target_sat)
# only possible target should be appropriate zstream
assert set(upgradable_versions) - {zstream} == set()

@pytest.mark.post_upgrade
def test_post_satellite_maintain_upgrade_list_versions(self, target_sat):
"""Post-upgrade sceanrio that tests list of satellite version
which satellite can be upgraded.
"""Test list of satellite target versions after upgrade.
:id: postupgrade-0bce689c-2664-11ea-b47c-48f17f1fc2e1
:steps:
1. Run satellite-maintain upgrade list-versions.
:expectedresults: Versions should be next z-stream.
"""
(
satellite_version,
upgradable_version,
major_version_change,
y_version,
) = self.satellite_upgradable_version_list(target_sat)
if satellite_version:
zstream_version, next_version = self.version_details(
satellite_version[0], major_version_change, y_version, upgrade_stage="post-upgrade"
)
else:
next_version = -1
assert next_version in upgradable_version
zstream = '.'.join(target_sat.version.split('.')[0:2]) + '.z'
upgradable_versions = self.satellite_upgradable_version_list(target_sat)
# only possible target should be appropriate zstream
assert set(upgradable_versions) - {zstream} == set()

0 comments on commit a2e38dd

Please sign in to comment.