Skip to content

Commit

Permalink
[6.15.z] Errata with swidtags setup and modular update (#14618)
Browse files Browse the repository at this point in the history
  • Loading branch information
Satellite-QE authored Apr 3, 2024
1 parent 2fc980d commit 2cf91cb
Showing 1 changed file with 114 additions and 49 deletions.
163 changes: 114 additions & 49 deletions tests/foreman/api/test_errata.py
Original file line number Diff line number Diff line change
Expand Up @@ -1353,7 +1353,6 @@ def _set_prerequisites_for_swid_repos(vm):
f'curl --insecure --remote-name {settings.repos.swid_tools_repo}', vm
)
_run_remote_command_on_content_host('mv *swid*.repo /etc/yum.repos.d', vm)
_run_remote_command_on_content_host(r'subscription-manager repos --enable \*', vm)
_run_remote_command_on_content_host('yum install -y swid-tools', vm)
_run_remote_command_on_content_host('yum install -y dnf-plugin-swidtags', vm)

Expand All @@ -1365,37 +1364,47 @@ def _validate_swid_tags_installed(vm, module_name):
assert module_name in result


@pytest.fixture
def errata_host_lce(module_sca_manifest_org, target_sat):
"""Create and return a new lce in module SCA org."""
return target_sat.api.LifecycleEnvironment(organization=module_sca_manifest_org).create()


@pytest.mark.tier3
@pytest.mark.upgrade
@pytest.mark.pit_client
@pytest.mark.parametrize(
'function_repos_collection_with_manifest',
[{'YumRepository': {'url': settings.repos.swid_tag.url, 'distro': 'rhel8'}}],
indirect=True,
)
@pytest.mark.no_containers
@pytest.mark.rhel_ver_match('8')
def test_errata_installation_with_swidtags(
function_repos_collection_with_manifest, rhel8_contenthost, target_sat
module_sca_manifest_org,
rhel_contenthost,
errata_host_lce,
target_sat,
):
"""Verify errata installation with swid_tags and swid tags get updated after
module stream update.
:id: 43a59b9a-eb9b-4174-8b8e-73d923b1e51e
:setup:
1. rhel8 contenthost checked out, using org with simple content access.
2. create satellite repositories having rhel8 baseOS, prereqs, custom content w/ swid tags.
3. associate repositories to org, lifecycle environment, and cv. Sync all content.
4. publish & promote to environment, content view version with all content.
5. create activation key, for registering host to cv.
:steps:
1. create product and repository having swid tags
2. create content view and published it with repository
3. create activation key and register content host
4. create rhel8, swid repos on content host
5. install swid-tools, dnf-plugin-swidtags packages on content host
6. install older module stream and generate errata, swid tag
7. assert errata count, swid tags are generated
8. install errata vis updating module stream
9. assert errata count and swid tag after module update
1. register host using cv's activation key, assert succeeded.
2. install swid-tools, dnf-plugin-swidtags packages on content host.
3. install older module stream and generate errata, swid tag.
4. assert errata count, swid tags are generated.
5. install errata via updating module stream.
6. assert errata count and swid tag changed after module update.
:expectedresults: swid tags should get updated after errata installation via
module stream update
:expectedresults:
swid tags should get updated after errata installation via module stream update
:CaseAutomation: Automated
Expand All @@ -1406,44 +1415,100 @@ def test_errata_installation_with_swidtags(
"""
module_name = 'kangaroo'
version = '20180704111719'
# setup base_rhel8 and sat_tools repos
rhel8_contenthost.create_custom_repos(
**{
'baseos': settings.repos.rhel8_os.baseos,
'appstream': settings.repos.rhel8_os.appstream,
}
)
function_repos_collection_with_manifest.setup_virtual_machine(rhel8_contenthost)
org = module_sca_manifest_org
lce = errata_host_lce
cv = target_sat.api.ContentView(
organization=org,
environment=[lce],
).create()

# install older module stream
rhel8_contenthost.add_rex_key(satellite=target_sat)
_set_prerequisites_for_swid_repos(rhel8_contenthost)
_run_remote_command_on_content_host(
f'dnf -y module install {module_name}:0:{version}', rhel8_contenthost
repos = {
'base_os': settings.repos.rhel8_os.baseos, # base rhel8
'sat_tools': settings.repos.rhel8_os.appstream, # swid prereqs
'swid_tags': settings.repos.swid_tag.url, # module stream pkgs and errata
}
# associate repos with sat, org, lce, cv, and sync
for r in repos:
target_sat.cli_factory.setup_org_for_a_custom_repo(
{
'url': repos[r],
'organization-id': org.id,
'lifecycle-environment-id': lce.id,
'content-view-id': cv.id,
},
)
# promote newest cv version with all repos/content
cv = cv_publish_promote(
sat=target_sat,
org=org,
cv=cv,
lce=lce,
)['content-view']
# ak in env, tied to content-view
ak = target_sat.api.ActivationKey(
organization=org,
environment=lce,
content_view=cv,
).create()
# register host with ak, succeeds
result = rhel_contenthost.register(
activation_keys=ak.name,
target=target_sat,
org=org,
loc=None,
)
target_sat.cli.Host.errata_recalculate({'host-id': rhel8_contenthost.nailgun_host.id})
assert result.status == 0, f'Failed to register the host {target_sat.hostname},\n{result}'
assert (
rhel_contenthost.subscribed
), f'Failed to subscribe the host {target_sat.hostname}, to content.'
result = rhel_contenthost.execute(r'subscription-manager repos --enable \*')
assert result.status == 0, f'Failed to enable repositories with subscription-manager,\n{result}'

# install outdated module stream package
_set_prerequisites_for_swid_repos(rhel_contenthost)
result = rhel_contenthost.execute(f'dnf -y module install {module_name}:0:{version}')
assert (
result.status == 0
), f'Failed to install module stream package: {module_name}:0:{version}.\n{result.stdout}'
# recalculate errata after install of old module stream
rhel_contenthost.execute('subscription-manager repos')

# validate swid tags Installed
before_errata_apply_result = _run_remote_command_on_content_host(
f"swidq -i -n {module_name} | grep 'File' | grep -o 'rpm-.*.swidtag'",
rhel8_contenthost,
return_result=True,
result = rhel_contenthost.execute(
f'swidq -i -n {module_name} | grep "File" | grep -o "rpm-.*.swidtag"',
)
assert (
result.status == 0
), f'An error occured trying to fetch swid tags for {module_name}.\n{result}'
before_errata_apply_result = result.stdout
assert before_errata_apply_result != '', f'Found no swid tags contained in {module_name}.'
assert (app_errata_count := rhel_contenthost.applicable_errata_count) == 1, (
f'Found {rhel_contenthost.applicable_errata_count} applicable errata,'
f' after installing {module_name}:0:{version}, expected 1.'
)
assert before_errata_apply_result != ''
assert (applicable_errata_count := rhel8_contenthost.applicable_errata_count) == 1

# apply modular errata
_run_remote_command_on_content_host(f'dnf -y module update {module_name}', rhel8_contenthost)
_run_remote_command_on_content_host('dnf -y upload-profile', rhel8_contenthost)
target_sat.cli.Host.errata_recalculate({'host-id': rhel8_contenthost.nailgun_host.id})
rhel8_contenthost.execute('subscription-manager repos')
applicable_errata_count -= 1
assert rhel8_contenthost.applicable_errata_count == applicable_errata_count
after_errata_apply_result = _run_remote_command_on_content_host(
f"swidq -i -n {module_name} | grep 'File'| grep -o 'rpm-.*.swidtag'",
rhel8_contenthost,
return_result=True,
result = rhel_contenthost.execute(f'dnf -y module update {module_name}')
assert (
result.status == 0
), f'Failed to update module stream package: {module_name}.\n{result.stdout}'
assert rhel_contenthost.execute('dnf -y upload-profile').status == 0

# recalculate and check errata after modular update
rhel_contenthost.execute('subscription-manager repos')
app_errata_count -= 1
assert rhel_contenthost.applicable_errata_count == app_errata_count, (
f'Found {rhel_contenthost.applicable_errata_count} applicable errata, after modular update of {module_name},'
f' expected {app_errata_count}.'
)
# swidtags were updated based on package version
result = rhel_contenthost.execute(
f'swidq -i -n {module_name} | grep "File" | grep -o "rpm-.*.swidtag"',
)
# swidtags get updated based on package version
assert (
result.status == 0
), f'An error occured trying to fetch swid tags for {module_name}.\n{result}'
after_errata_apply_result = result.stdout
assert before_errata_apply_result != after_errata_apply_result


Expand Down

0 comments on commit 2cf91cb

Please sign in to comment.