Merge branch 'develop' into packageset-aarch64

This commit is contained in:
Trevor Cooper 2024-07-11 21:03:16 -07:00
commit 5f0fcf5bf1
Signed by: tcooper
GPG Key ID: 52364D7BBCEB35B8
94 changed files with 1345 additions and 275 deletions

View File

@ -107,6 +107,6 @@ These variables should be set when tests are scheduled (when running `isos post`
| `PREVREL` | the previous stable Rocky release at the time of the test run |
| `UP1REL` | the source release for "1-release" upgrade tests (usually but not always same as `CURRREL`) |
| `UP2REL` | the source release for "2-release" upgrade tests (currently always same as `PREVREL`) |
| `LOCATION` | contains Pungi base compose location (something like `https://kojipkgs.rockylinux.org/compose/branched/Rocky-8.4-20210801.n.0/compose/`) |
| `LOCATION` | Rocky doesn't replicate compose process used by upstream distribution. `LOCATION` has three general use cases: substitution value for `REPOSITORY_VARIATION` or `REPOSITORY_GRAPHICAL` in `templates.fif.json`, within `utils.pm` in `_repo_setup_compose` which is not valid for Rocky and within `support_server.pm` in `_pxe_setup` to pull the kernel and initrd used for PXE installs. Required value is repository URL prefix, eg. `https://download.rockylinux.org/pub/rocky/8/`. |
| `DNF_CONTENTDIR` | the value to change `/etc/dnf/vars/contentdir` to (eg. `stg/rocky`) allowing repository reconfiguration to point at staging (usually but not always used with `DNF_RELEASEVER`) |
| `DNF_RELEASEVER` | the value to change `/etc/dnf/vars/releasever` to (eg. `8.8-Beta`) allowing repository reconfiguration to point at a specific release (usually but not always used with `DNF_CONTENTDIR`) |

View File

@ -212,6 +212,11 @@ def generate_job_templates(products, profiles, testsuites):
jobtemplate['group_name'] = "Rocky PowerPC Updates"
else:
jobtemplate['group_name'] = "Rocky PowerPC"
elif jobtemplate['machine_name'] in ('s390x'):
if 'updates' in product['flavor']:
jobtemplate['group_name'] = "Rocky s390x Updates"
else:
jobtemplate['group_name'] = "Rocky s390x"
elif jobtemplate['machine_name'] in ('aarch64', 'ARM'):
if 'updates' in product['flavor']:
jobtemplate['group_name'] = "Rocky AArch64 Updates"

View File

@ -366,9 +366,9 @@ sub get_full_repo {
# repo URL with flavor and arch, leave hd & NFS ones alone
# (as for those tests we just use a mounted ISO and URL is complete)
if ($repourl !~ m/^(nfs|hd:)/) {
# Everything variant doesn't exist for modular composes atm,
# only Server
$repourl .= "/" . get_var("ARCH") . "/os";
# Rocky Linux default repo is BaseOS. This subdirectory
# should be added to ${LOCATION}.
$repourl .= "/BaseOS/" . get_var("ARCH") . "/os";
}
return $repourl;
}

View File

@ -8,7 +8,7 @@ use Exporter;
use feature "switch";
use lockapi;
use testapi;
our @EXPORT = qw/run_with_error_check type_safely type_very_safely desktop_vt boot_to_login_screen console_login console_switch_layout desktop_switch_layout console_loadkeys_us do_bootloader boot_decrypt check_release menu_launch_type repo_setup setup_workaround_repo cleanup_workaround_repo console_initial_setup handle_welcome_screen gnome_initial_setup anaconda_create_user check_desktop download_modularity_tests quit_firefox advisory_get_installed_packages advisory_check_nonmatching_packages start_with_launcher quit_with_shortcut lo_dismiss_tip disable_firefox_studies select_rescue_mode copy_devcdrom_as_isofile get_release_number get_version_major get_code_name check_left_bar check_top_bar check_prerelease check_version spell_version_number _assert_and_click is_branched rec_log click_unwanted_notifications repos_mirrorlist register_application get_registered_applications solidify_wallpaper/;
our @EXPORT = qw/run_with_error_check type_safely type_very_safely desktop_vt boot_to_login_screen console_login console_switch_layout desktop_switch_layout console_loadkeys_us do_bootloader boot_decrypt check_release menu_launch_type repo_setup cleanup_workaround_repo console_initial_setup handle_welcome_screen gnome_initial_setup anaconda_create_user check_desktop download_modularity_tests quit_firefox advisory_get_installed_packages advisory_check_nonmatching_packages start_with_launcher quit_with_shortcut lo_dismiss_tip disable_firefox_studies select_rescue_mode copy_devcdrom_as_isofile get_release_number get_version_major get_code_name check_left_bar check_top_bar check_prerelease check_version spell_version_number _assert_and_click is_branched rec_log click_unwanted_notifications repos_mirrorlist register_application get_registered_applications solidify_wallpaper/;
# We introduce this global variable to hold the list of applications that have
# registered during the apps_startstop_test when they have sucessfully run.
@ -433,9 +433,12 @@ sub repos_mirrorlist {
# the infra repo is updated but mirrormanager metadata checksums
# have not been updated, and the infra repo is rejected as its
# metadata checksum isn't known to MM
# NOTE: For Rocky CURRREL is used to specify/select HDD1 for multi-host
# tests, for example *8.10-BETA*qcow2, and repo names are
# really tied to the major version in Rocky.
my $files = shift;
my $currentversion = get_var("CURRREL");
if ($currentversion eq '8') {
my $currentversion = get_var("VERSION");
if (get_version_major($currentversion) eq '8') {
$files ||= "/etc/yum.repos.d/Rocky*.repo";
}
else {
@ -450,60 +453,6 @@ sub cleanup_workaround_repo {
script_run "rm -f /etc/yum.repos.d/workarounds.repo";
}
sub setup_workaround_repo {
# doesn't work for Rocky
my $distri = get_var("DISTRI");
return if ($distri eq "rocky");
# we periodically need to pull an update from updates-testing in
# to fix some bug or other. so, here's an organized way to do it.
# we do this here so the workaround packages are in the repo data
# but *not* in the package lists generated above (those should
# only include packages from the update under test). we'll define
# a hash of releases and update IDs. if no workarounds are needed
# for any release, the hash can be empty and this will do nothing
my $version = shift || get_var("VERSION");
cleanup_workaround_repo;
script_run "dnf -y install bodhi-client createrepo", 300;
# write a repo config file, unless this is the support_server test
# and it is running on a different release than the update is for
# (in this case we need the repo to exist but do not want to use
# it on the actual support_server system)
unless (get_var("TEST") eq "support_server" && $version ne get_var("CURRREL")) {
assert_script_run 'printf "[workarounds]\nname=Workarounds repo\nbaseurl=file:///opt/workarounds_repo\nenabled=1\nmetadata_expire=1\ngpgcheck=0" > /etc/yum.repos.d/workarounds.repo';
}
assert_script_run "mkdir -p /opt/workarounds_repo";
assert_script_run "pushd /opt/workarounds_repo";
my %workarounds = (
"32" => [],
"33" => [],
"34" => ["FEDORA-2021-d7b1dc57fe"]
);
# then we'll download each update for our release:
my $advortasks = $workarounds{$version};
foreach my $advortask (@$advortasks) {
my $cmd = "bodhi updates download --updateid=$advortask";
if ($advortask =~ /^\d+$/) {
my $arch = get_var("ARCH");
$cmd = "koji download-task --arch=$arch --arch=noarch $advortask";
}
my $count = 3;
my $success = 0;
while ($count) {
if (script_run $cmd, 180) {
$count -= 1;
}
else {
$count = 0;
$success = 1;
}
}
die "Workaround update download failed!" unless $success;
}
# and create repo metadata
assert_script_run "createrepo .";
assert_script_run "popd";
}
sub _repo_setup_compose {
# doesn't work for Rocky
my $distri = get_var("DISTRI");
@ -561,8 +510,6 @@ sub _repo_setup_updates {
assert_script_run "dnf config-manager --set-disabled updates-testing-modular";
}
}
# set up the workaround repo
setup_workaround_repo;
# Set up an additional repo containing the update or task packages. We do
# this rather than simply running a one-time update because it may be the
@ -1233,16 +1180,11 @@ sub check_prerelease {
# defaults to False, but if the compose has a label and it's an
# 'RC' or 'Update' or 'SecurityFix' compose (see definition of
# SUPPORTED_MILESTONES in productmd.composeinfo), the default is
# True. AFAICS, Fedora's pungi configs don't explicitly set this,
# but rely on the heuristic. So for installer images, we expect
# isFinal to be True for RC candidate composes and post-release
# nightly Cloud, IoT etc. composes (these are also marked as 'RC'
# composes), but False for Rawhide and Branched nightly composes
# and Beta candidate composes. For installer images built by our
# own _installer_build test, we control whether --isfinal is set
# or not; we pass it if the update is for a stable release, we do
# not pass it if the update is for Branched. Live images do not
# have the buildstamp file.
# True. Not sure if Rocky's pungi configs explicitly set this,
# or rely on the heuristic. So for installer images, we expect
# isFinal to be True for RC candidate and final composes, but
# False for LookAhead and Beta candidate composes. Live images
# do not have the buildstamp file.
# 2. If there's no buildstamp file, the value of the environment
# variable ANACONDA_ISFINAL is used as `product.isFinal`, default
@ -1250,22 +1192,11 @@ sub check_prerelease {
# wrapper script sets ANACONDA_ISFINAL based on the release field
# of whatever package provides system-release: if it starts with
# "0.", it sets ANACONA_ISFINAL to "false", otherwise it sets it
# to "true". So for live images, we expect isFinal to be True
# unless the fedora-release-common package release starts with 0.
# to "true".
# 3. If `product.isFinal` is False, the pre-release warning and
# tags are shown; if it is False, they are not shown.
# We don't really need to check this stuff for update tests, as
# the only installer images we test on updates are ones we build
# ourselves; there's no value to this check for those really.
# For compose tests, we will expect to see the pre-release tags if
# the compose is Rawhide, or a Beta candidate, or it's a nightly
# and we're checking an installer image. If it's an RC or Updates
# candidate, or a respin release, we expect NOT to see the tags.
# If it's a nightly and we're checking a live image, we don't do
# the check.
# bail if this is an update test
return if (get_var("ADVISORY OR TASK"));
@ -1273,25 +1204,18 @@ sub check_prerelease {
# any other value means we don't care
my $prerelease = 10;
# if this is RC or update compose we absolutely *MUST NOT* see tags
# if this is RC we absolutely *MUST NOT* see tags
my $label = get_var("LABEL");
$prerelease = 0 if ($label =~ /^(RC|Update)-/);
$prerelease = 0 if ($label =~ /^RC/);
# if it's a Beta compose we *MUST* see tags
$prerelease = 1 if ($label =~ /^Beta-/);
my $version = get_var('VERSION');
# if it's Rawhide we *MUST* see tags
$prerelease = 1 if ($version eq "Rawhide");
$prerelease = 1 if ($label =~ /^(B(?i)eta(?-i))/);
my $build = get_var('BUILD');
# if it's a nightly installer image we should see tags
$prerelease = 1 if ($build =~ /\.n\.\d+/ && !get_var("LIVE"));
# if it's a respin compose we *MUST NOT* see tags
$prerelease = 0 if ($build =~ /Respin/);
# we *could* go to a console and parse fedora-release-common
# to decide if a nightly live image should have tags or not, but
# it seems absurd as we're almost reinventing the code that
# decides whether to show the tags, at that point, and it's not
# really a big deal either way whether a nightly live image has
# the tags or not. So we don't.
$prerelease = 1 if ($build =~ /\.t\.\d+/ && !get_var("LIVE"));
# check based on ISO name, does not work for 8.x boot-iso name(s) which must use
# LABEL
my $iso = get_var('ISO');
$prerelease = 1 if ($iso =~ /^Rocky-\d+\.\d+-(B(?i)eta(?-i)|LookAhead)-(x86_64|aarch64|ppc64le|s390x)-(boot|dvd\d?|minimal).iso/);
# For all prerelease requiring ISOs, assert that prerelease is there.
if ($prerelease == 1) {

View File

@ -0,0 +1,16 @@
{
"area": [
{
"ypos": 220,
"type": "match",
"height": 35,
"width": 384,
"xpos": 41
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_create_user"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 236 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"xpos": 9,
"width": 384,
"type": "match",
"height": 35,
"ypos": 126
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_create_user"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 207 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"height": 34,
"width": 446,
"xpos": 41,
"type": "match",
"ypos": 220
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_install_destination"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 211 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"xpos": 39,
"height": 39,
"width": 490,
"type": "match",
"ypos": 217
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_installation_source"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 271 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"height": 38,
"ypos": 123,
"type": "match",
"xpos": 9,
"width": 499
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_language_selection"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 258 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"height": 39,
"width": 700,
"xpos": 41,
"type": "match",
"ypos": 218
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_network_host_name"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 247 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"type": "match",
"width": 676,
"height": 38,
"xpos": 42,
"ypos": 218
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_progress"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 265 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"type": "match",
"width": 454,
"height": 35,
"xpos": 40,
"ypos": 219
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_root_password"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 242 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"ypos": 125,
"height": 35,
"width": 454,
"xpos": 8,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_root_password"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 239 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"height": 36,
"xpos": 39,
"width": 488,
"type": "match",
"ypos": 218
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_select_packages"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 352 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"width": 488,
"xpos": 7,
"type": "match",
"ypos": 124,
"height": 36
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_select_packages"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 322 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"type": "match",
"height": 36,
"xpos": 41,
"width": 457,
"ypos": 194
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_summary"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 129 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 33,
"height": 19,
"type": "match",
"width": 145,
"xpos": 91
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"prerelease_note"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 111 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"type": "match",
"xpos": 734,
"width": 143,
"height": 19,
"ypos": 31
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-french",
"prerelease_note"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 35 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"width": 159,
"xpos": 754,
"type": "match",
"ypos": 35,
"height": 24
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"prerelease_note"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"type": "match",
"xpos": 135,
"width": 675,
"height": 32,
"ypos": 9
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"topbar_generic"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 123 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"ypos": 34,
"height": 27,
"width": 159,
"xpos": 754,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"prerelease_note"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

View File

@ -0,0 +1,21 @@
{
"area": [
{
"type": "match",
"xpos": 754,
"width": 253,
"height": 23,
"ypos": 546,
"click_point": {
"xpos": 239.5,
"ypos": 12.5
}
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_install_destination_encrypt_data"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 91 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 544,
"height": 23,
"width": 127,
"xpos": 786,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_install_destination_encrypt_data"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 158 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 211,
"height": 19,
"width": 105,
"xpos": 58,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-FLAVOR-server",
"anaconda_install_source_selected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 203 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"height": 15,
"ypos": 733,
"type": "match",
"xpos": 953,
"width": 27
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_select_install_lang_continue"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 262 KiB

View File

@ -0,0 +1,24 @@
{
"area": [
{
"height": 32,
"ypos": 173,
"xpos": 221,
"width": 50,
"type": "match"
},
{
"type": "match",
"xpos": 469,
"width": 75,
"height": 36,
"ypos": 173
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_select_install_lang_filtered"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 262 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"width": 93,
"xpos": 607,
"type": "match",
"ypos": 199,
"height": 16
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_select_install_lang_selected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 262 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 217,
"type": "match",
"xpos": 41,
"height": 38,
"width": 544
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"anaconda_help_language_support",
"anaconda_help_language_selection"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 252 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 228,
"ypos": 360,
"width": 64,
"height": 20,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 306 KiB

View File

@ -0,0 +1,21 @@
{
"area": [
{
"xpos": 12,
"width": 89,
"type": "match",
"height": 21,
"ypos": 705,
"click_point": {
"xpos": 44.5,
"ypos": 10.5
}
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_main_hub_begin_installation"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 106 KiB

View File

@ -0,0 +1,24 @@
{
"area": [
{
"xpos": 26,
"ypos": 685,
"type": "match",
"width": 175,
"height": 21
},
{
"type": "match",
"width": 39,
"height": 19,
"xpos": 415,
"ypos": 133
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 69 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 568,
"ypos": 133,
"type": "match",
"width": 60,
"height": 17
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-french",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 74 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"width": 88,
"height": 25,
"type": "match",
"ypos": 136,
"xpos": 587
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 131,
"xpos": 603,
"height": 23,
"width": 83,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-russian",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 73 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 124,
"height": 35,
"type": "match",
"width": 411,
"xpos": 587
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_graphical-server_selected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 206 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"height": 34,
"ypos": 126,
"xpos": 27,
"width": 392,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-french",
"anaconda_graphical-server_selected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 235 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"height": 41,
"ypos": 136,
"type": "match",
"xpos": 47,
"width": 400
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_graphical-server_selected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 225 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 128,
"height": 35,
"type": "match",
"width": 418,
"xpos": 28
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-russian",
"anaconda_graphical-server_selected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 242 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 497,
"width": 77,
"type": "match",
"height": 56,
"ypos": 330
}
],
"properties": [],
"tags": [
"anaconda_part_fs",
"anaconda_part_fs_ext4_selected",
"ENV-DISTRI-rocky"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 106 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 37,
"height": 23,
"width": 52,
"xpos": 950,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_spoke_done"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 336 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"width": 52,
"xpos": 950,
"type": "match",
"ypos": 38,
"height": 23
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_spoke_done"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 206 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"height": 18,
"xpos": 14,
"ypos": 128,
"width": 132,
"type": "match",
"match": 82
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"console_in_toolbox"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 744,
"height": 22,
"xpos": 14,
"type": "match",
"match": 82,
"width": 135
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"console_in_toolbox"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 74 KiB

View File

@ -0,0 +1,18 @@
{
"area": [
{
"xpos": 961,
"ypos": 34,
"type": "match",
"height": 24,
"width": 52
}
],
"properties": [],
"tags": [
"DESKTOP-gnome",
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"gdm_spoke_done"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 488,
"width": 49,
"type": "match",
"height": 22,
"ypos": 478
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"desktop_input_source_japanese"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

View File

@ -3,5 +3,5 @@
"$id": "fif-arch.json",
"title": "FIF arch schema",
"type": "string",
"enum": [ "x86_64", "arm", "aarch64", "ppc64le" ]
"enum": [ "x86_64", "arm", "aarch64", "ppc64le", "s390x" ]
}

View File

@ -84,40 +84,40 @@
"machine": "aarch64",
"product": "rocky-updates-server-upgrade-aarch64-*"
},
"rocky-updates-server-upgrade-x86_64-*-64bit": {
"machine": "64bit",
"rocky-updates-server-upgrade-x86_64-*-bios": {
"machine": "bios",
"product": "rocky-updates-server-upgrade-x86_64-*"
},
"rocky-updates-server-aarch64-*-aarch64": {
"machine": "aarch64",
"product": "rocky-updates-server-aarch64-*"
},
"rocky-updates-server-x86_64-*-64bit": {
"machine": "64bit",
"rocky-updates-server-x86_64-*-bios": {
"machine": "bios",
"product": "rocky-updates-server-x86_64-*"
},
"rocky-updates-workstation-upgrade-aarch64-*-aarch64": {
"machine": "aarch64",
"product": "rocky-updates-workstation-upgrade-aarch64-*"
},
"rocky-updates-workstation-upgrade-x86_64-*-64bit": {
"machine": "64bit",
"rocky-updates-workstation-upgrade-x86_64-*-bios": {
"machine": "bios",
"product": "rocky-updates-workstation-upgrade-x86_64-*"
},
"rocky-updates-workstation-aarch64-*-aarch64": {
"machine": "aarch64",
"product": "rocky-updates-workstation-aarch64-*"
},
"rocky-updates-workstation-x86_64-*-64bit": {
"machine": "64bit",
"rocky-updates-workstation-x86_64-*-bios": {
"machine": "bios",
"product": "rocky-updates-workstation-x86_64-*"
},
"rocky-updates-minimal-aarch64-*-aarch64": {
"machine": "aarch64",
"product": "rocky-updates-minimal-aarch64-*"
},
"rocky-updates-minimal-x86_64-*-64bit": {
"machine": "64bit",
"rocky-updates-minimal-x86_64-*-bios": {
"machine": "bios",
"product": "rocky-updates-minimal-x86_64-*"
}
},
@ -125,7 +125,7 @@
"advisory_boot": {
"profiles": {
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40
},
"settings": {
"ADVISORY_BOOT_TEST": "1",
@ -136,116 +136,116 @@
},
"base_selinux": {
"profiles": {
"rocky-updates-minimal-x86_64-*-64bit": 40,
"rocky-updates-minimal-x86_64-*-bios": 40,
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40,
"rocky-updates-workstation-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40,
"rocky-updates-workstation-x86_64-*-bios": 40
}
},
"base_service_manipulation": {
"profiles": {
"rocky-updates-minimal-x86_64-*-64bit": 40,
"rocky-updates-minimal-x86_64-*-bios": 40,
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40,
"rocky-updates-workstation-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40,
"rocky-updates-workstation-x86_64-*-bios": 40
}
},
"base_services_start": {
"profiles": {
"rocky-updates-minimal-x86_64-*-64bit": 40,
"rocky-updates-minimal-x86_64-*-bios": 40,
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40,
"rocky-updates-workstation-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40,
"rocky-updates-workstation-x86_64-*-bios": 40
}
},
"base_update_cli": {
"profiles": {
"rocky-updates-minimal-x86_64-*-64bit": 40,
"rocky-updates-minimal-x86_64-*-bios": 40,
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40,
"rocky-updates-workstation-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40,
"rocky-updates-workstation-x86_64-*-bios": 40
}
},
"base_reboot_unmount": {
"profiles": {
"rocky-updates-minimal-x86_64-*-64bit": 40,
"rocky-updates-minimal-x86_64-*-bios": 40,
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40,
"rocky-updates-workstation-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40,
"rocky-updates-workstation-x86_64-*-bios": 40
}
},
"base_system_logging": {
"profiles": {
"rocky-updates-minimal-x86_64-*-64bit": 40,
"rocky-updates-minimal-x86_64-*-bios": 40,
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40,
"rocky-updates-workstation-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40,
"rocky-updates-workstation-x86_64-*-bios": 40
}
},
"desktop_background": {
"profiles": {
"rocky-updates-workstation-aarch64-*-aarch64": 30,
"rocky-updates-workstation-x86_64-*-64bit": 30
"rocky-updates-workstation-x86_64-*-bios": 30
}
},
"desktop_browser": {
"profiles": {
"rocky-updates-workstation-aarch64-*-aarch64": 30,
"rocky-updates-workstation-x86_64-*-64bit": 30
"rocky-updates-workstation-x86_64-*-bios": 30
}
},
"desktop_printing": {
"profiles": {
"rocky-updates-workstation-aarch64-*-aarch64": 30,
"rocky-updates-workstation-x86_64-*-64bit": 30
"rocky-updates-workstation-x86_64-*-bios": 30
}
},
"desktop_terminal": {
"profiles": {
"rocky-updates-workstation-aarch64-*-aarch64": 30,
"rocky-updates-workstation-x86_64-*-64bit": 30
"rocky-updates-workstation-x86_64-*-bios": 30
}
},
"desktop_update_graphical": {
"profiles": {
"rocky-updates-workstation-aarch64-*-aarch64": 30,
"rocky-updates-workstation-x86_64-*-64bit": 30
"rocky-updates-workstation-x86_64-*-bios": 30
}
},
"server_cockpit_basic": {
"profiles": {
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40
}
},
"server_cockpit_default": {
"profiles": {
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40
}
},
"server_cockpit_updates": {
"profiles": {
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40
}
},
"server_database_client": {
"profiles": {
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40
}
},
"server_firewall_default": {
"profiles": {
"rocky-updates-server-aarch64-*-aarch64": 40,
"rocky-updates-server-x86_64-*-64bit": 40
"rocky-updates-server-x86_64-*-bios": 40
}
},
"upgrade_desktop_encrypted_64bit": {
"profiles": {
"rocky-updates-workstation-upgrade-aarch64-*-aarch64": 40,
"rocky-updates-workstation-upgrade-x86_64-*-64bit": 40
"rocky-updates-workstation-upgrade-x86_64-*-bios": 40
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,29 @@
use base "installedtest";
use strict;
use testapi;
use utils;
sub run {
my $self = shift;
if (not(check_screen "root_console", 0)) {
$self->root_console(tty => 4);
}
script_run 'efibootmgr';
# now try deleting the "rocky" boot entry and rebooting, to check the fallback path
assert_script_run('efibootmgr -b $(efibootmgr | grep -i rocky | cut -f1 | sed -e "s,[^0-9],,g") -B');
# check that worked
validate_script_output('efibootmgr', sub { $_ !~ m/.*rocky.*/s });
type_string("reboot\n");
boot_to_login_screen;
$self->root_console(tty => 3);
# rocky entry should have been recreated
validate_script_output('efibootmgr', sub { m/rocky/ });
# SB should still be enabled
validate_script_output('mokutil --sb-state', sub { m/SecureBoot enabled/ });
}
sub test_flags {
return {fatal => 1};
}
1;

View File

@ -25,6 +25,7 @@ sub _pxe_setup {
assert_script_run "printf 'dhcp-match=set:efi-x86_64,option:client-arch,7\ndhcp-match=set:efi-x86_64,option:client-arch,9\ndhcp-match=set:bios,option:client-arch,0\ndhcp-match=set:efi-aarch64,option:client-arch,11\ndhcp-match=set:ppc64,option:client-arch,12\ndhcp-match=set:ppc64,option:client-arch,13\ndhcp-boot=tag:efi-x86_64,\"shim.efi\"\ndhcp-boot=tag:bios,\"pxelinux.0\"\ndhcp-boot=tag:efi-aarch64,\"grubaa64.efi\"\ndhcp-boot=tag:ppc64,\"boot/grub2/powerpc-ieee1275/core.elf\"\n' >> /etc/dnsmasq.conf";
# install and configure bootloaders
my $ourversion = get_var("CURRREL");
my $contentdir = get_var("DNF_CONTENTDIR");
my $testversion = get_var("RELEASE");
assert_script_run "mkdir -p /var/tmp/rocky";
my $arch = get_var("ARCH");
@ -41,7 +42,26 @@ sub _pxe_setup {
assert_script_run "rpm --root=/var/tmp/rocky --rebuilddb", 60;
assert_script_run "cd /var/tmp; dnf download rocky-release rocky-repos rocky-gpg-keys", 60;
assert_script_run "rpm --root=/var/tmp/rocky --nodeps -i /var/tmp/*.rpm", 60;
#assert_script_run "sed -i /var/tmp/rocky/etc/yum.repos.d/Rocky-*.repo -e 's/repo=/repo=rocky-/g'", 60;
# Rocky Linux repos in /var/tmp/rocky point at mirrorlist and should be
# pointed at baseurl to support repositories in the staging if used for
# Beta or Lookahead builds.
if (get_version_major() < 9) {
assert_script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s,^#\(baseurl=http[s]*://\),\1,g" ' . '/var/tmp/rocky/etc/yum.repos.d/Rocky-BaseOS.repo';
assert_script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s,^#\(baseurl=http[s]*://\),\1,g" ' . '/var/tmp/rocky/etc/yum.repos.d/Rocky-AppStream.repo';
assert_script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s,^#\(baseurl=http[s]*://\),\1,g" ' . '/var/tmp/rocky/etc/yum.repos.d/Rocky-Extras.repo';
assert_script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s,^#\(baseurl=http[s]*://\),\1,g" ' . '/var/tmp/rocky/etc/yum.repos.d/Rocky-Devel.repo';
} else {
script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s/^#baseurl/baseurl/g" ' . '/var/tmp/rocky/etc/yum.repos.d/rocky.repo';
script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s/^#baseurl/baseurl/g" ' . '/var/tmp/rocky/etc/yum.repos.d/rocky-addons.repo';
script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s/^#baseurl/baseurl/g" ' . '/var/tmp/rocky/etc/yum.repos.d/rocky-devel.repo';
script_run 'sed -i -e "s/^mirrorlist/#mirrorlist/g;s/^#baseurl/baseurl/g" ' . '/var/tmp/rocky/etc/yum.repos.d/rocky-extras.repo';
}
# If we're pointing at Staging via alternate DNF_CONTENTDIR then modify dnf vars in /var/tmp/rocky
if ($contentdir) {
assert_script_run 'printf "%s\n" ' . $contentdir . ' > ' . '/var/tmp/rocky/etc/dnf/vars/contentdir';
}
assert_script_run "dnf -y --releasever=$ourversion --refresh --installroot=/var/tmp/rocky install shim-x64 grub2-efi-x64", 1800;
# copy bootloader files to tftp root
@ -49,12 +69,9 @@ sub _pxe_setup {
assert_script_run "cp /var/tmp/rocky/boot/efi/EFI/rocky/{shimx64.efi,shimx64-rocky.efi,grubx64.efi} /var/lib/tftpboot";
# bootloader configs
# BIOS
assert_script_run "printf 'default vesamenu.c32\nprompt 1\ntimeout 600\n\nlabel linux\n menu label ^Install Rocky Linux 64-bit\n menu default\n kernel rocky/vmlinuz\n append initr
d=rocky/initrd.img inst.ks=file:///ks.cfg ip=dhcp\nlabel local\n menu label Boot from ^local drive\n localboot 0xffff\n' >> /var/lib/tftpboot/pxelinux.cfg/default";
assert_script_run "printf 'default vesamenu.c32\nprompt 1\ntimeout 600\n\nlabel linux\n menu label ^Install Rocky Linux 64-bit\n menu default\n kernel rocky/vmlinuz\n append initrd=rocky/initrd.img inst.ks=file:///ks.cfg ip=dhcp\nlabel local\n menu label Boot from ^local drive\n localboot 0xffff\n' >> /var/lib/tftpboot/pxelinux.cfg/default";
# UEFI
assert_script_run "printf 'function load_video {\n insmod efi_gop\n insmod efi_uga\n insmod ieee1275_fb\n insmod vbe\n insmod vga\n insmod video_bochs\n insmod video_cirrus\n}\
n\nload_video\nset gfxpayload=keep\ninsmod gzio\n\nmenuentry \"Install Rocky Linux 64-bit\" --class rocky --class gnu-linux --class gnu --class os {\n linuxefi rocky/vmlinuz ip=dhcp inst.ks=
file:///ks.cfg\n initrdefi rocky/initrd.img\n}' >> /var/lib/tftpboot/grub.cfg";
assert_script_run "printf 'function load_video {\n insmod efi_gop\n insmod efi_uga\n insmod ieee1275_fb\n insmod vbe\n insmod vga\n insmod video_bochs\n insmod video_cirrus\n}\n\nload_video\nset gfxpayload=keep\ninsmod gzio\n\nmenuentry \"Install Rocky Linux 64-bit\" --class rocky --class gnu-linux --class gnu --class os {\n linuxefi rocky/vmlinuz ip=dhcp inst.ks=file:///ks.cfg\n initrdefi rocky/initrd.img\n}' >> /var/lib/tftpboot/grub.cfg";
# DEBUG DEBUG
upload_logs "/etc/dnsmasq.conf";
upload_logs "/var/lib/tftpboot/grub.cfg";
@ -97,7 +114,7 @@ file:///ks.cfg\n initrdefi rocky/initrd.img\n}' >> /var/lib/tftpboot/grub.cfg";
# https://fedoraproject.org/wiki/QA:Testcase_Kickstart_File_Path_Ks_Cfg
assert_script_run "curl -o ks.cfg https://git.rockylinux.org/tcooper/kickstarts/-/raw/main/root-user-crypted-net.ks";
# tweak the repo config in it
assert_script_run "sed -i -e 's,^url.*,nfs --server=nfs://172.16.2.110 --dir=/repo --opts=nfsver=4,g' ks.cfg";
assert_script_run "sed -i -e 's,^url.*,nfs --server=nfs://172.16.2.110 --dir=/repo,g' ks.cfg";
# embed it
assert_script_run "echo ks.cfg | cpio -c -o >> /var/lib/tftpboot/rocky/initrd.img";
# chown root
@ -109,6 +126,7 @@ file:///ks.cfg\n initrdefi rocky/initrd.img\n}' >> /var/lib/tftpboot/grub.cfg";
sub run {
my $self = shift;
my $contentdir = get_var("DNF_CONTENTDIR");
# disable systemd-resolved, it conflicts with dnsmasq
unless (script_run "systemctl is-active systemd-resolved.service") {
script_run "systemctl stop systemd-resolved.service";
@ -148,8 +166,20 @@ sub run {
# create the file share
assert_script_run "mkdir -p /export";
# get the kickstart
assert_script_run "curl -o /export/root-user-crypted-net.ks https://git.rockylinux.org/tcooper/kickstarts/-/raw/main/root-user-crypted-net.ks";
# get the kickstart or kickstart template and replace content
if ($contentdir) {
my $releasever = get_var("DNF_RELEASEVAR");
assert_script_run "curl -o /export/root-user-crypted-net.ks https://git.rockylinux.org/tcooper/kickstarts/-/raw/main/root-user-crypted-net-template.ks";
# Tweak the kickstart template
if ($releasever) {
assert_script_run "sed -e 's,DNF_CONTENTDIR," . $contentdir . ",g;s,DNF_RELEASEVER," . $releasever . ",g' ks.cfg";
} else {
my $version = get_var("VERSION");
assert_script_run "sed -e 's,DNF_CONTENTDIR," . $contentdir . ",g;s,DNF_RELEASEVER," . $version . ",g' ks.cfg";
}
} else {
assert_script_run "curl -o /export/root-user-crypted-net.ks https://git.rockylinux.org/tcooper/kickstarts/-/raw/main/root-user-crypted-net.ks";
}
# for update tests, set up the update repository and export it
if (get_var("ADVISORY_OR_TASK")) {
assert_script_run "echo '/opt/update_repo 172.16.2.0/24(ro)' >> /etc/exports";
@ -176,8 +206,14 @@ sub run {
assert_script_run "printf '/export 172.16.2.0/24(ro)\n/repo 172.16.2.0/24(ro)\n/iso 172.16.2.0/24(ro)' > /etc/exports";
}
# open firewall port
assert_script_run "firewall-cmd --add-service=nfs";
# configure nfsv3 ports
assert_script_run "printf '[lockd]\nport=5555\n\n[statd]\nport=6666\n' > /etc/nfs.conf";
# configure firewall
assert_script_run "firewall-cmd --add-service={nfs,rpc-bind,mountd}";
assert_script_run "firewall-cmd --add-port={5555/tcp,5555/udp,6666/tcp,6666/udp}";
assert_script_run "firewall-cmd --reload";
# start the server
assert_script_run "systemctl restart nfs-server.service";
assert_script_run "systemctl is-active nfs-server.service";

41
tests/toolbox.pm Normal file
View File

@ -0,0 +1,41 @@
# does a basic test of toolbox
use base "installedtest";
use strict;
use testapi;
use utils;
sub run {
my $self = shift;
my $version_major = get_version_major();
assert_script_run "dnf install toolbox --assumeyes", 360 unless (get_var("CANNED"));
assert_script_run "rpm -q toolbox";
assert_script_run "toolbox create container_rl -y", 300;
assert_script_run "toolbox list | grep container_rl";
validate_script_output "toolbox run --container container_rl uname -a", sub { m/Linux toolbox/ };
validate_script_output "toolbox run --container container_rl cat /etc/rocky-release", sub { m/Rocky Linux release $version_major/ };
type_string "toolbox enter container_rl\n";
assert_screen "console_in_toolbox", 180;
type_string "exit\n";
sleep 5;
assert_script_run "clear";
assert_script_run 'podman stop container_rl';
assert_script_run "toolbox rm container_rl";
assert_script_run "toolbox rmi --all --force";
# pull fedora here as a quick test
assert_script_run "toolbox -y create --distro fedora --release 39", 300;
type_string "toolbox enter fedora-toolbox-39\n";
assert_screen "console_in_toolbox", 180;
type_string "exit\n";
sleep 5;
validate_script_output "toolbox run --distro fedora --release 39 cat /etc/fedora-release", sub { m/Fedora release 39 \(Thirty Nine\)/ };
# clean up
assert_script_run 'podman stop fedora-toolbox-39';
assert_script_run "toolbox rm fedora-toolbox-39";
assert_script_run "toolbox rmi --all --force";
}
sub test_flags {
return {fatal => 1};
}
1;

View File

@ -13,6 +13,8 @@ sub run {
console_loadkeys_us;
# this test shows if the system is booted with efi
assert_script_run '[ -d /sys/firmware/efi/ ]';
# this test shows if the system is secure boot
script_run 'mokutil --sb-state';
}
sub test_flags {

View File

@ -13,7 +13,6 @@ sub run {
if (index($testname, "upgrade_2") != -1) {
$version = get_var("UP2REL");
}
setup_workaround_repo $version;
assert_script_run 'dnf -y update --refresh', 1800;
script_run "reboot", 0;