Compare commits

..

19 Commits

Author SHA1 Message Date
akatch
5e28bb1d81
Merge pull request #189 from AlanMarshall/needles
Add bootloader tags
2023-08-17 18:20:01 -05:00
ab8128ebb6
Add bootloader tags 2023-08-07 12:14:00 +01:00
690e04cc79
Merge branch 'develop' 2023-08-06 15:11:20 -07:00
fd1fe3424a
add uefi bootloader needles 2023-08-04 13:48:46 -07:00
8cb07a4950
Merge branch 'develop' 2023-08-03 16:42:19 -07:00
Al Bowles
8becb62887
Provide tests for SIG/HPC slurm packages
This MR provides a very, very basic test suite for the Slurm packages
built by the HPC SIG. It checks the following:

- Necessary packages for a single-node Slurm instance install
  successfully from the SIG/HPC repository
- A job can be scheduled and executed to completion
- A job can be scheduled and then cancelled

```
./fifloader.py --clean --load templates.fif.json
openqa-cli api -X POST isos ISO=Rocky-8.8-x86_64-dvd.iso ARCH=x86_64 DISTRI=rocky FLAVOR=dvd-iso VERSION=8.8 CURRREL=8 BUILD=-${date +%Y%d%m}.0-slurm-8.8 TEST=slurm22,slurm23
openqa-cli api -X POST isos ISO=Rocky-9.2-x86_64-dvd.iso ARCH=x86_64 DISTRI=rocky FLAVOR=dvd-iso VERSION=9.2 CURRREL=9 BUILD=-${date +%Y%d%m}.0-slurm-9.2 TEST=slurm22,slurm23

```

- [x] My code follows the style guidelines of this project
- [x] I have performed a self-review of my own code
- [x] I have commented my code, particularly in hard-to-understand areas
- [ ] I have made corresponding changes to the documentation
- [x] My changes generate no new warnings
- [x] Any dependent changes have been merged and published in downstream modules
2023-07-25 15:04:07 -05:00
70a5e26c25
Merge branch 'develop' 2023-06-07 09:10:29 -07:00
f4c33a4f21
minor cleanup 2023-05-24 08:55:46 -07:00
2e641ba7fa
Merge branch 'develop' into base_update_cli 2023-05-24 08:54:28 -07:00
5d18a012c6
task: merge develop to main (#182)
* Cockpit needle

* Another Cockpit needle

* One more cockpit needle

---------

Co-authored-by: Al Bowles <bowlesalx@gmail.com>
Co-authored-by: Lukas Magauer <42647570+lumarel@users.noreply.github.com>
2023-05-24 08:47:20 -07:00
Lukas Magauer
2d0113c054
Merge pull request #181 from akatch/8.8_release
Needle updates for 8.8 release
2023-05-19 11:55:11 +02:00
Al Bowles
020c7ea4b5
One more cockpit needle 2023-05-18 11:41:44 -05:00
Al Bowles
8605e5e093
Another Cockpit needle 2023-05-17 17:06:58 -05:00
Al Bowles
3fc2d3bb12
Cockpit needle 2023-05-17 16:01:23 -05:00
Lukas Magauer
eeea512450
Merge pull request #180 from rocky-linux/develop
Merge develop to main
2023-05-17 22:59:55 +02:00
akatch
bc6c92e9a9
Needle updates for 9.2 release (#179)
* Consolidate build names for all flavors by version

This PR neither adds nor updates specific test functionality, but does
update the wrapper scripts based on @tcooper's recommendations for
consolidating all flavors for a particular version into a single build.

* cheers neil

* New needles

* Add needle for _anaconda_network_enable

* Multilingual needles for _anaconda_network_enable

* Set language tag

* A few more multilingual needles

* Clean up dangling needles in the root of the needles dir
2023-05-17 15:53:13 -05:00
f39910d953
add missing use statement 2023-05-06 07:56:50 -07:00
7361baef9f
consider Rocky Linux version when adding powertools/crb 2023-05-05 20:57:13 -07:00
ff0cb91b4e
Merge pull request #173 from rocky-linux/develop
merge develop to main
2023-05-02 23:57:56 -07:00
48 changed files with 514 additions and 158 deletions

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 66,
"ypos": 295,
"width": 441,
"type": "match",
"height": 20
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"anaconda_help_localization_link"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 91 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"width": 36,
"ypos": 145,
"xpos": 250,
"height": 11,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_install_user_created"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 123 KiB

View File

@ -0,0 +1,24 @@
{
"area": [
{
"ypos": 634,
"xpos": 716,
"width": 305,
"height": 14,
"type": "match"
},
{
"type": "match",
"height": 14,
"ypos": 698,
"width": 105,
"xpos": 875
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_install_done"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 226 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 398,
"ypos": 145,
"width": 36,
"type": "match",
"height": 11
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-russian",
"anaconda_install_user_created"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 129 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 224,
"ypos": 361,
"width": 45,
"height": 11,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 250 KiB

View File

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 253 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 785,
"ypos": 362,
"width": 50,
"height": 10,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-japanese",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 288 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 719,
"height": 18,
"type": "match",
"ypos": 359,
"width": 105
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 250 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"xpos": 778,
"ypos": 364,
"width": 68,
"height": 10,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-russian",
"anaconda_network_connected"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 256 KiB

View File

@ -0,0 +1,21 @@
{
"area": [
{
"height": 21,
"type": "match",
"width": 42,
"xpos": 965,
"ypos": 34,
"click_point": {
"xpos": 21,
"ypos": 10.5
}
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-arabic",
"anaconda_spoke_done"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

View File

@ -0,0 +1,20 @@
{
"area": [
{
"width": 56,
"ypos": 34,
"xpos": 17,
"height": 21,
"type": "match",
"click_point": {
"xpos": 28,
"ypos": 10.5
}
}
],
"properties": [],
"tags": [
"LANGUAGE-russian",
"anaconda_spoke_done"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"ypos": 475,
"xpos": 529,
"width": 40,
"height": 21,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"autoupdate_planned_time"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 47 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"height": 28,
"type": "match",
"ypos": 585,
"xpos": 264,
"width": 133
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"cockpit_services_detail"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 73 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 362,
"width": 39,
"xpos": 14,
"height": 18,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"cockpit_logs"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"ypos": 618,
"xpos": 16,
"width": 143,
"height": 10,
"type": "match"
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"LANGUAGE-english",
"boot_enter_passphrase"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 97 KiB

View File

@ -0,0 +1,17 @@
{
"area": [
{
"width": 113,
"ypos": 575,
"xpos": 427,
"type": "match",
"height": 19
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"bootloader_uefi"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.8 KiB

View File

@ -0,0 +1,18 @@
{
"area": [
{
"type": "match",
"ypos": 611,
"width": 113,
"xpos": 210,
"height": 19
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"bootloader",
"bootloader_uefi"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.4 KiB

View File

@ -0,0 +1,18 @@
{
"area": [
{
"width": 113,
"ypos": 611,
"type": "match",
"height": 19,
"xpos": 210
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"ENV-LANGUAGE-english",
"bootloader",
"bootloader_uefi"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.9 KiB

View File

@ -0,0 +1,16 @@
{
"area": [
{
"type": "match",
"height": 157,
"width": 163,
"ypos": 224,
"xpos": 445
}
],
"properties": [],
"tags": [
"ENV-DISTRI-rocky",
"getting_started"
]
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 201 KiB

View File

@ -1,16 +1,18 @@
#!/bin/bash #!/bin/bash
set -e set -e
MAJOR_VERSION=9
MINOR_VERSION=0
## Usage: Posts ISOs to openQA for each of the universal, dvd-iso, package-set, minimal-iso, and boot-iso FLAVORs. ## Usage: Posts ISOs to openQA for each of the universal, dvd-iso, package-set, minimal-iso, and boot-iso FLAVORs.
# scripts/run-all-flavors.sh # scripts/run-all-flavors.sh
# Test a beta build with alternative repo URL
# ROCKY_EXTRA_ARGS="GRUB=ip=dhcp GRUBADD=inst.repo=https://dl.rockylinux.org/stg/rocky/8.8-BETA/BaseOS/x86_64/os DNF_CONTENTDIR=stg CURRREL=8 IDENTIFICATION=false" scripts/run-all-flavors.sh
ROCKY_VERSION="$MAJOR_VERSION.$MINOR_VERSION" ROCKY_VERSION="9.2"
MAJOR_VERSION=${ROCKY_VERSION:0:1}
MINOR_VERSION=${ROCKY_VERSION:2:1}
ROCKY_ARCH="${ROCKY_ARCH:=x86_64}" ROCKY_ARCH="${ROCKY_ARCH:=x86_64}"
ROCKY_EXTRA_ARGS="${ROCKY_EXTRA_ARGS:-}" ROCKY_EXTRA_ARGS="${ROCKY_EXTRA_ARGS:-}"
BUILD_PREFIX="-$(date +%Y%m%d.%H%M%S).0-$(git branch --show-current)" BUILD_NAME="-$(date +%Y%m%d).0-$(git branch --show-current)-$ROCKY_VERSION"
ISO_PREFIX="Rocky-$ROCKY_VERSION-$ROCKY_ARCH" ISO_PREFIX="Rocky-$ROCKY_VERSION-$ROCKY_ARCH"
DVD_ISOTYPE=dvd1 DVD_ISOTYPE=dvd1
@ -31,8 +33,8 @@ openqa-cli api \
DISTRI=rocky \ DISTRI=rocky \
FLAVOR=universal \ FLAVOR=universal \
VERSION="$ROCKY_VERSION" \ VERSION="$ROCKY_VERSION" \
BUILD="$BUILD_PREFIX-universal-$ROCKY_VERSION" \ BUILD="$BUILD_NAME" \
"${ROCKY_EXTRA_ARGS}" ${ROCKY_EXTRA_ARGS}
openqa-cli api \ openqa-cli api \
-X POST isos \ -X POST isos \
@ -41,8 +43,8 @@ openqa-cli api \
DISTRI=rocky \ DISTRI=rocky \
FLAVOR="dvd-iso" \ FLAVOR="dvd-iso" \
VERSION="$ROCKY_VERSION" \ VERSION="$ROCKY_VERSION" \
BUILD="$BUILD_PREFIX-dvd-$ROCKY_VERSION" \ BUILD="$BUILD_NAME" \
"${ROCKY_EXTRA_ARGS}" ${ROCKY_EXTRA_ARGS}
openqa-cli api \ openqa-cli api \
-X POST isos \ -X POST isos \
@ -51,8 +53,8 @@ openqa-cli api \
DISTRI=rocky \ DISTRI=rocky \
FLAVOR=package-set \ FLAVOR=package-set \
VERSION="$ROCKY_VERSION" \ VERSION="$ROCKY_VERSION" \
BUILD="$BUILD_PREFIX-packageset-$ROCKY_VERSION" \ BUILD="$BUILD_NAME" \
"${ROCKY_EXTRA_ARGS}" ${ROCKY_EXTRA_ARGS}
openqa-cli api \ openqa-cli api \
-X POST isos \ -X POST isos \
@ -61,8 +63,8 @@ openqa-cli api \
DISTRI=rocky \ DISTRI=rocky \
FLAVOR=minimal-iso \ FLAVOR=minimal-iso \
VERSION="$ROCKY_VERSION" \ VERSION="$ROCKY_VERSION" \
BUILD="$BUILD_PREFIX-minimal-$ROCKY_VERSION" \ BUILD="$BUILD_NAME" \
"${ROCKY_EXTRA_ARGS}" ${ROCKY_EXTRA_ARGS}
openqa-cli api \ openqa-cli api \
-X POST isos \ -X POST isos \
@ -71,5 +73,5 @@ openqa-cli api \
DISTRI=rocky \ DISTRI=rocky \
FLAVOR=boot-iso \ FLAVOR=boot-iso \
VERSION="$ROCKY_VERSION" \ VERSION="$ROCKY_VERSION" \
BUILD="$BUILD_PREFIX-boot-$ROCKY_VERSION" \ BUILD="$BUILD_NAME" \
"${ROCKY_EXTRA_ARGS}" ${ROCKY_EXTRA_ARGS}

View File

@ -1,9 +1,6 @@
#!/bin/bash #!/bin/bash
set -e set -e
MAJOR_VERSION=9
MINOR_VERSION=0
## Usage: Post an ISO for the specified FLAVOR. Defaults to boot-iso. ## Usage: Post an ISO for the specified FLAVOR. Defaults to boot-iso.
# #
## Run the boot-iso FLAVOR ## Run the boot-iso FLAVOR
@ -15,13 +12,14 @@ MINOR_VERSION=0
## Run the localization test suites ## Run the localization test suites
# ROCKY_FLAVOR ROCKY_EXTRA_ARGS=TEST=install_arabic_language,install_asian_language,install_european_language,install_cyrillic_language scripts/run-openqa-tests.sh # ROCKY_FLAVOR ROCKY_EXTRA_ARGS=TEST=install_arabic_language,install_asian_language,install_european_language,install_cyrillic_language scripts/run-openqa-tests.sh
ROCKY_VERSION="9.2"
MAJOR_VERSION=${ROCKY_VERSION:0:1}
MINOR_VERSION=${ROCKY_VERSION:2:1}
ROCKY_FLAVOR="${ROCKY_FLAVOR:-boot-iso}" ROCKY_FLAVOR="${ROCKY_FLAVOR:-boot-iso}"
ROCKY_VERSION="$MAJOR_VERSION.$MINOR_VERSION"
ROCKY_ARCH="${ROCKY_ARCH:=x86_64}" ROCKY_ARCH="${ROCKY_ARCH:=x86_64}"
ROCKY_EXTRA_ARGS="${ROCKY_EXTRA_ARGS:-}" ROCKY_EXTRA_ARGS="${ROCKY_EXTRA_ARGS:-}"
BUILD_PREFIX="-$(date +%Y%m%d.%H%M%S).0-$(git branch --show-current)" BUILD_NAME="-$(date +%Y%m%d).0-$(git branch --show-current)-$ROCKY_VERSION"
BUILD_NAME="$BUILD_PREFIX-$ROCKY_FLAVOR-$ROCKY_VERSION"
ISO_PREFIX="Rocky-$ROCKY_VERSION-$ROCKY_ARCH" ISO_PREFIX="Rocky-$ROCKY_VERSION-$ROCKY_ARCH"
if [[ "$ROCKY_FLAVOR" == "dvd-iso" || "$ROCKY_FLAVOR" == "universal" ]]; then if [[ "$ROCKY_FLAVOR" == "dvd-iso" || "$ROCKY_FLAVOR" == "universal" ]]; then

View File

@ -1418,6 +1418,36 @@
"WORKER_CLASS": "tap" "WORKER_CLASS": "tap"
} }
}, },
"slurm22": {
"profiles": {
"rocky-dvd-iso-aarch64-*-aarch64": 10,
"rocky-dvd-iso-x86_64-*-64bit": 10
},
"settings": {
"BOOTFROM": "c",
"HDD_1": "disk_%FLAVOR%_%MACHINE%.qcow2",
"POSTINSTALL": "slurm",
"START_AFTER_TEST": "%DEPLOY_UPLOAD_TEST%",
"ROOT_PASSWORD": "weakpassword",
"USER_LOGIN": "false",
"SLURM_VERSION": "22"
}
},
"slurm23": {
"profiles": {
"rocky-dvd-iso-aarch64-*-aarch64": 10,
"rocky-dvd-iso-x86_64-*-64bit": 10
},
"settings": {
"BOOTFROM": "c",
"HDD_1": "disk_%FLAVOR%_%MACHINE%.qcow2",
"POSTINSTALL": "slurm",
"START_AFTER_TEST": "%DEPLOY_UPLOAD_TEST%",
"ROOT_PASSWORD": "weakpassword",
"USER_LOGIN": "false",
"SLURM_VERSION": "23"
}
},
"support_server": { "support_server": {
"profiles": { "profiles": {
"rocky-dvd-iso-aarch64-*-aarch64": 10, "rocky-dvd-iso-aarch64-*-aarch64": 10,

View File

@ -2,24 +2,37 @@ use base "installedtest";
use strict; use strict;
use testapi; use testapi;
use packagetest; use packagetest;
use utils;
sub run { sub run {
my $self = shift; my $self = shift;
# switch to TTY3 for both, graphical and console tests # switch to TTY3 for both, graphical and console tests
$self->root_console(tty => 3); $self->root_console(tty => 3);
# enable test repos and install test packages # enable test repos and install test packages
prepare_test_packages; prepare_test_packages;
# check rpm agrees they installed good # check rpm agrees they installed good
verify_installed_packages; verify_installed_packages;
if (get_var("DISTRI") eq "rocky") { if (get_var("DISTRI") eq "rocky") {
# pandoc-common is in PowerTools in RockyLinux if (get_version_major() < 9) {
# pandoc-common is in PowerTools in Rocky Linux 8
assert_script_run 'dnf config-manager --set-enabled powertools', 60; assert_script_run 'dnf config-manager --set-enabled powertools', 60;
} }
else {
# pandoc-common is in CRB in Rocky Linux 8
assert_script_run 'dnf config-manager --set-enabled crb', 60;
}
}
# update the fake pandoc-common (should come from the real repo) # update the fake pandoc-common (should come from the real repo)
# this can take a long time if we get unlucky with the metadata refresh # this can take a long time if we get unlucky with the metadata refresh
assert_script_run 'dnf -y --disablerepo=openqa-testrepo* --disablerepo=updates-testing update pandoc-common', 600; assert_script_run 'dnf -y --disablerepo=openqa-testrepo* --disablerepo=updates-testing update pandoc-common', 600;
# check we got the updated version # check we got the updated version
verify_updated_packages; verify_updated_packages;
# now remove pandoc-common, and see if we can do a straight # now remove pandoc-common, and see if we can do a straight
# install from the default repos # install from the default repos
assert_script_run 'dnf -y remove pandoc-common'; assert_script_run 'dnf -y remove pandoc-common';

View File

@ -8,20 +8,18 @@ sub run {
# switch to tty1 (we're usually there already, but just in case # switch to tty1 (we're usually there already, but just in case
# we're carrying on from a failed freeipa_webui that didn't fail # we're carrying on from a failed freeipa_webui that didn't fail
# at tty1) # at tty1)
my $ipa_domain = 'test.openqa.rockylinux.org';
my $ipa_realm = 'TEST.OPENQA.ROCKYLINUX.ORG';
send_key "ctrl-alt-f1"; send_key "ctrl-alt-f1";
wait_still_screen 1; wait_still_screen 1;
# check domain is listed in 'realm list' # check domain is listed in 'realm list'
validate_script_output 'realm list', sub { $_ =~ m/domain-name: test\.openqa\.rockylinux\.org.*configured: kerberos-member/s }; validate_script_output 'realm list', sub { $_ =~ m/domain-name: test\.openqa\.rockylinux\.org.*configured: kerberos-member/s };
# check we can see the admin user in getent # check we can see the admin user in getent
assert_script_run "getent passwd admin\@$ipa_realm"; assert_script_run 'getent passwd admin@TEST.OPENQA.ROCKYLINUX.ORG';
# check keytab entries # check keytab entries
my $hostname = script_output 'hostname'; my $hostname = script_output 'hostname';
my $qhost = quotemeta($hostname); my $qhost = quotemeta($hostname);
validate_script_output 'klist -k', sub { $_ =~ m/$qhost\@TEST\.OPENQA\.ROCKYLINUX\.ORG/ }; validate_script_output 'klist -k', sub { $_ =~ m/$qhost\@TEST\.OPENQA\.ROCKYLINUX\.ORG/ };
# check we can kinit with the host principal # check we can kinit with the host principal
assert_script_run "kinit -k host/$hostname\@$ipa_realm"; assert_script_run "kinit -k host/$hostname\@TEST.OPENQA.ROCKYLINUX.ORG";
# Set a longer timeout for login(1) to workaround RHBZ #1661273 # Set a longer timeout for login(1) to workaround RHBZ #1661273
assert_script_run 'echo "LOGIN_TIMEOUT 180" >> /etc/login.defs'; assert_script_run 'echo "LOGIN_TIMEOUT 180" >> /etc/login.defs';
# switch to tty2 for login tests # switch to tty2 for login tests
@ -34,7 +32,7 @@ sub run {
# "permission denied" message doesn't last that long # "permission denied" message doesn't last that long
sleep 2; sleep 2;
assert_screen "text_console_login"; assert_screen "text_console_login";
type_string "test2\@$ipa_realm\n"; type_string "test2\@TEST.OPENQA.ROCKYLINUX.ORG\n";
assert_screen "console_password_required"; assert_screen "console_password_required";
type_string "batterystaple\n"; type_string "batterystaple\n";
assert_screen "login_permission_denied"; assert_screen "login_permission_denied";

View File

@ -9,9 +9,7 @@ sub run {
# we're restarting firefox (instead of using the same one from # we're restarting firefox (instead of using the same one from
# realmd_join_cockpit) so Firefox's trusted CA store refreshes and # realmd_join_cockpit) so Firefox's trusted CA store refreshes and
# it trusts the web server cert # it trusts the web server cert
my $ipa_realm = 'TEST.OPENQA.ROCKYLINUX.ORG'; start_webui("admin", "monkeys123");
my $ipa_admin_password = 'b1U3OnyX!';
start_webui("admin", $ipa_admin_password);
add_user("test3", "Three"); add_user("test3", "Three");
add_user("test4", "Four"); add_user("test4", "Four");
assert_screen "freeipa_webui_users_added"; assert_screen "freeipa_webui_users_added";
@ -50,8 +48,8 @@ sub run {
assert_screen "root_console"; assert_screen "root_console";
wait_still_screen 5; wait_still_screen 5;
# set permanent passwords for both accounts # set permanent passwords for both accounts
assert_script_run "printf 'correcthorse\nbatterystaple\nbatterystaple' | kinit test3\@$ipa_realm"; assert_script_run 'printf "correcthorse\nbatterystaple\nbatterystaple" | kinit test3@TEST.OPENQA.ROCKYLINUX.ORG';
assert_script_run "printf 'correcthorse\nbatterystaple\nbatterystaple' | kinit test4\@$ipa_realm"; assert_script_run 'printf "correcthorse\nbatterystaple\nbatterystaple" | kinit test4@TEST.OPENQA.ROCKYLINUX.ORG';
# switch to tty4 (boy, the tty jugglin') # switch to tty4 (boy, the tty jugglin')
send_key "ctrl-alt-f4"; send_key "ctrl-alt-f4";
# try and login as test3, should work # try and login as test3, should work

View File

@ -57,7 +57,7 @@ sub run {
type_string("admin", 4); type_string("admin", 4);
send_key "tab"; send_key "tab";
sleep 3; sleep 3;
type_string("b1U3OnyX!", 4); type_string("monkeys123", 4);
sleep 3; sleep 3;
assert_and_click "cockpit_join_button"; assert_and_click "cockpit_join_button";
# join involves package installs, so it may take some time # join involves package installs, so it may take some time

View File

@ -6,39 +6,12 @@ use mmapi;
use tapnet; use tapnet;
use utils; use utils;
# Adapted from Fedora's OpenQA tests, with some modifications. This will need
# to be maintained per major version as necessary.
# label@rockylinux.org
use feature "switch";
sub run { sub run {
my $self = shift; my $self = shift;
# use FreeIPA server or replica as DNS server # use FreeIPA server or replica as DNS server
my $version_major = get_version_major;
my $relnum = get_release_number;
my $ipa_admin_password = 'b1U3OnyX!';
my $server = 'ipa001.test.openqa.rockylinux.org'; my $server = 'ipa001.test.openqa.rockylinux.org';
my $server_ip = '172.16.2.100'; my $server_ip = '172.16.2.100';
my $server_mutex = 'freeipa_ready'; my $server_mutex = 'freeipa_ready';
my $ipa_install_cmd;
my @ipa_firewall_services;
given ($version_major) {
when ('8') {
$ipa_install_cmd = 'dnf --assumeyes module install idm:DL1/{dns,client,server,common}';
@ipa_firewall_services = qw(http https kerberos kpasswd ldap ldaps dns);
}
when ('9') {
$ipa_install_cmd = 'dnf --assumeyes install ipa-server ipa-client ipa-server-dns sssd sssd-ipa';
@ipa_firewall_services = qw(freeipa-4 dns);
}
default {
$ipa_install_cmd = 'dnf --assumeyes install ipa-server ipa-client ipa-server-dns sssd sssd-ipa';
@ipa_firewall_services = qw(freeipa-4 dns);
}
}
if (get_var("FREEIPA_REPLICA")) { if (get_var("FREEIPA_REPLICA")) {
$server = 'ipa002.test.openqa.rockylinux.org'; $server = 'ipa002.test.openqa.rockylinux.org';
$server_ip = '172.16.2.106'; $server_ip = '172.16.2.106';
@ -67,22 +40,22 @@ sub run {
if (get_var("FREEIPA_REPLICA")) { if (get_var("FREEIPA_REPLICA")) {
# here we're enrolling not just as a client, but as a replica # here we're enrolling not just as a client, but as a replica
# install server packages # install server packages
assert_script_run "$ipa_install_cmd", 600; assert_script_run "dnf -y groupinstall freeipa-server", 600;
# we need a lot of entropy for this, and we don't care how good # we need a lot of entropy for this, and we don't care how good
# it is, so let's use haveged # it is, so let's use haveged
assert_script_run "dnf --assumeyes install rng-tools", 300; assert_script_run "dnf -y install haveged", 300;
assert_script_run 'systemctl start rngd.service'; assert_script_run 'systemctl start haveged.service';
# configure the firewall # configure the firewall
for my $service (@ipa_firewall_services) { for my $service (qw(freeipa-ldap freeipa-ldaps dns)) {
assert_script_run "firewall-cmd --permanent --add-service $service"; assert_script_run "firewall-cmd --permanent --add-service $service";
} }
assert_script_run "systemctl restart firewalld.service"; assert_script_run "systemctl restart firewalld.service";
# deploy as a replica # deploy as a replica
my ($ip, $hostname) = split(/ /, get_var("POST_STATIC")); my ($ip, $hostname) = split(/ /, get_var("POST_STATIC"));
my $args = "--ip-address=$ip --setup-dns --auto-forwarders --setup-ca --allow-zone-overlap -U --principal admin --admin-password $ipa_admin_password"; my $args = "--ip-address=$ip --setup-dns --auto-forwarders --setup-ca --allow-zone-overlap -U --principal admin --admin-password monkeys123";
assert_script_run "ipa-replica-install $args", 1500; assert_script_run "ipa-replica-install $args", 1500;
# enable and start the systemd service # enable and start the systemd service
@ -96,7 +69,7 @@ sub run {
wait_for_children; wait_for_children;
} }
else { else {
assert_script_run "echo '$ipa_admin_password' | realm join --user=admin ${server}", 300; assert_script_run "echo 'monkeys123' | realm join --user=admin ${server}", 300;
} }
# set sssd debugging level higher (useful for debugging failures) # set sssd debugging level higher (useful for debugging failures)
# optional as it's not really part of the test # optional as it's not really part of the test

View File

@ -6,45 +6,23 @@ use mmapi;
use tapnet; use tapnet;
use utils; use utils;
# Adapted from Fedora's OpenQA tests, with some modifications. This will need
# to be maintained per major version as necessary.
# label@rockylinux.org
use feature "switch";
sub run { sub run {
my $self = shift; my $self = shift;
my $version_major = get_version_major;
my $relnum = get_release_number;
my $ipa_hostname = script_output 'hostname';
my $ipa_install_cmd;
my @ipa_firewall_services;
my $ipa_domain = 'test.openqa.rockylinux.org';
my $ipa_realm = 'TEST.OPENQA.ROCKYLINUX.ORG';
my $ipa_admin_password = 'b1U3OnyX!';
my $ipa_reverse_zone = '2.16.172.in-addr.arpa';
my $ipa_install_args = "-U --auto-forwarders --realm=$ipa_realm --domain=$ipa_domain --ds-password=$ipa_admin_password --admin-password=$ipa_admin_password --setup-dns --reverse-zone=$ipa_reverse_zone --allow-zone-overlap";
given ($version_major) {
when ('8') {
$ipa_install_cmd = 'dnf --assumeyes module install idm:DL1/{dns,client,server,common}';
@ipa_firewall_services = qw(http https kerberos kpasswd ldap ldaps dns);
}
when ('9') {
$ipa_install_cmd = 'dnf --assumeyes install ipa-server ipa-client ipa-server-dns sssd sssd-ipa';
@ipa_firewall_services = qw(freeipa-4 dns);
}
default {
$ipa_install_cmd = 'dnf --assumeyes install ipa-server ipa-client ipa-server-dns sssd sssd-ipa';
@ipa_firewall_services = qw(freeipa-4 dns);
}
}
# login # login
$self->root_console(); $self->root_console();
# We need entropy. Install rng-tools and start it up. Fedora uses haveged # use compose repo, disable u-t, etc. unless this is an upgrade
# but Rocky Linux does not have it unless EPEL is used. # test (in which case we're on the 'old' release at this point;
assert_script_run "dnf --assumeyes install rng-tools", 300; # one of the upgrade test modules does repo_setup later)
assert_script_run 'systemctl start rngd.service'; repo_setup() unless get_var("UPGRADE");
# use --enablerepo=fedora for Modular compose testing (we need to
# create and use a non-Modular repo to get some packages which
# aren't in Modular Server composes)
my $extraparams = '';
$extraparams = '--enablerepo=fedora' if (get_var("MODULAR"));
# we need a lot of entropy for this, and we don't care how good
# it is, so let's use haveged
assert_script_run "dnf ${extraparams} -y install haveged", 300;
assert_script_run 'systemctl start haveged.service';
# per ab, this should get us extra debug logging from the web UI # per ab, this should get us extra debug logging from the web UI
# in error_log # in error_log
assert_script_run 'mkdir -p /etc/ipa'; assert_script_run 'mkdir -p /etc/ipa';
@ -52,49 +30,24 @@ sub run {
# per ab, this gets us more debugging for bind # per ab, this gets us more debugging for bind
assert_script_run 'mkdir -p /etc/systemd/system/named-pkcs11.service.d'; assert_script_run 'mkdir -p /etc/systemd/system/named-pkcs11.service.d';
assert_script_run 'printf "[Service]\nEnvironment=OPTIONS=-d5\n" > /etc/systemd/system/named-pkcs11.service.d/debug.conf'; assert_script_run 'printf "[Service]\nEnvironment=OPTIONS=-d5\n" > /etc/systemd/system/named-pkcs11.service.d/debug.conf';
# Based on the major version, install FreeIPA # First install the necessary packages
assert_script_run "$ipa_install_cmd", 600; assert_script_run "dnf -y groupinstall freeipa-server", 600;
# Enable all the firewall services as needed per major version # configure the firewall
for my $service (@ipa_firewall_services) { for my $service (qw(freeipa-ldap freeipa-ldaps dns)) {
assert_script_run "firewall-cmd --permanent --add-service $service"; assert_script_run "firewall-cmd --permanent --add-service $service";
} }
assert_script_run "systemctl restart firewalld.service"; assert_script_run "systemctl restart firewalld.service";
# deploy the server # deploy the server
assert_script_run "ipa-server-install $ipa_install_args", 1200; my $args = "-U --auto-forwarders --realm=TEST.OPENQA.ROCKYLINUX.ORG --domain=test.openqa.rockylinux.org --ds-password=monkeys123 --admin-password=monkeys123 --setup-dns --reverse-zone=2.16.172.in-addr.arpa --allow-zone-overlap";
assert_script_run "ipa-server-install $args", 1200;
# enable and start the systemd service # enable and start the systemd service
assert_script_run "systemctl enable ipa.service"; assert_script_run "systemctl enable ipa.service";
assert_script_run "systemctl start ipa.service", 300; assert_script_run "systemctl start ipa.service", 300;
# kinit as admin # kinit as admin
assert_script_run "echo '$ipa_admin_password' | kinit admin"; assert_script_run 'echo "monkeys123" | kinit admin';
# set up an OTP for client001 enrolment (this should enroll by kickstart or another way) # set up an OTP for client001 enrolment (it will enrol with a kickstart)
assert_script_run "ipa host-add client001.$ipa_domain --password=monkeys --force"; assert_script_run 'ipa host-add client001.test.openqa.rockylinux.org --password=monkeys --force';
############################################################################
# Testing kerb services
assert_script_run "ipa service-add testservice/$ipa_hostname";
assert_script_run "ipa-getkeytab -s $ipa_hostname -p testservice/$ipa_hostname";
validate_script_output 'klist -k /tmp/testservice.keytab', sub { $_ =~ m/testservice\/$ipa_hostname/ };
# This is commented for now. We need a while loop that watches for ipa-getcert list -r to become empty.
#assert_script_run "ipa-getcert request -K testservice/$ipa_hostname -D $ipa_hostname -f /etc/pki/tls/certs/testservice.pki -k /etc/pki/tls/private/testservice.key";
#validate_script_output "ipa-getcert list -r | sed -n '/Request ID/,/auto-renew: yes/p'", sub { $_ =~ m// };
############################################################################
# Testing DNS
assert_script_run "ipa dnszone-add --name-server=$ipa_hostname. --admin-email=hostmaster.testzone.$ipa_domain. testzone.$ipa_domain";
sleep(5);
# ensure subdomain was made
validate_script_output "dig \@localhost SOA testzone.$ipa_domain", sub { $_ =~ m/status: NOERROR/ };
# make test records with CNAME
assert_script_run "ipa dnsrecord-add $ipa_domain testrecord --cname-hostname=onyxtest";
# validate it works
validate_script_output "dig \@localhost CNAME testrecord.$ipa_domain", sub { $_ =~ m/status: NOERROR/ };
# make test records with CNAME in subdomain
assert_script_run "ipa dnsrecord-add testzone.$ipa_domain testrecord --cname-hostname=onyxtest.$ipa_domain";
# validate it works
validate_script_output "dig \@localhost CNAME testrecord.testzone.$ipa_domain", sub { $_ =~ m/status: NOERROR/ };
############################################################################
# User Accounts + HBAC + SUDO
# create two user accounts, test1 and test2 # create two user accounts, test1 and test2
assert_script_run 'echo "correcthorse" | ipa user-add test1 --first test --last one --password'; assert_script_run 'echo "correcthorse" | ipa user-add test1 --first test --last one --password';
assert_script_run 'echo "correcthorse" | ipa user-add test2 --first test --last two --password'; assert_script_run 'echo "correcthorse" | ipa user-add test2 --first test --last two --password';
@ -108,24 +61,13 @@ sub run {
assert_script_run 'ipa pwpolicy-mod --minlife=0'; assert_script_run 'ipa pwpolicy-mod --minlife=0';
# magic voodoo crap to allow reverse DNS client sync to work # magic voodoo crap to allow reverse DNS client sync to work
# https://docs.pagure.org/bind-dyndb-ldap/BIND9/SyncPTR.html # https://docs.pagure.org/bind-dyndb-ldap/BIND9/SyncPTR.html
assert_script_run "ipa dnszone-mod $ipa_domain. --allow-sync-ptr=TRUE"; assert_script_run 'ipa dnszone-mod test.openqa.rockylinux.org. --allow-sync-ptr=TRUE';
# kinit as each user and set a new password # kinit as each user and set a new password
assert_script_run "printf 'correcthorse\nbatterystaple\nbatterystaple' | kinit test1\@$ipa_realm"; assert_script_run 'printf "correcthorse\nbatterystaple\nbatterystaple" | kinit test1@TEST.OPENQA.ROCKYLINUX.ORG';
assert_script_run "printf 'correcthorse\nbatterystaple\nbatterystaple' | kinit test2\@$ipa_realm"; assert_script_run 'printf "correcthorse\nbatterystaple\nbatterystaple" | kinit test2@TEST.OPENQA.ROCKYLINUX.ORG';
# we're ready for children to enrol, now
# add a sudo rule
assert_script_run 'ipa sudorule-add testrule --desc="Test rule in IPA" --hostcat=all --cmdcat=all --runasusercat=all --runasgroupcat=all';
assert_script_run 'ipa sudorule-add-user testrule --users="test1"';
validate_script_output 'ipa sudorule-show testrule', sub { $_ =~ m/Rule name: testrule/ };
validate_script_output 'ipa sudorule-show testrule', sub { $_ =~ m/Users: test1/ };
# This may fail - Invalidate sudo cache and check test1's sudo perms
assert_script_run 'sss_cache -R';
validate_script_output 'sudo -l -U test1', sub { $_ =~ m/test1 may run the following commands/ };
# we're ready for children to enroll, now
mutex_create("freeipa_ready"); mutex_create("freeipa_ready");
# This generally applies to Fedora upgrades. We don't perform upgrades in EL # if upgrade test, wait for children to enrol before upgrade
# but we will leave this here.
if (get_var("UPGRADE")) { if (get_var("UPGRADE")) {
my $children = get_children(); my $children = get_children();
my $child_id = (keys %$children)[0]; my $child_id = (keys %$children)[0];

65
tests/slurm.pm Normal file
View File

@ -0,0 +1,65 @@
use base "installedtest";
use strict;
use testapi;
use utils;
sub slurm_setup {
# install HPC repository
my $version = get_var("SLURM_VERSION");
assert_script_run "dnf -y install rocky-release-hpc", 120;
# Set up munge
assert_script_run "dnf -y install munge", 120;
assert_script_run "dd if=/dev/urandom bs=1 count=1024 >/etc/munge/munge.key";
assert_script_run "chmod 400 /etc/munge/munge.key";
assert_script_run "chown munge.munge /etc/munge/munge.key";
assert_script_run "systemctl enable --now munge.service";
# install slurm
if (get_var("CURRREL") eq '8') {
assert_script_run "dnf config-manager --set-enabled powertools";
}
assert_script_run "dnf install -y slurm$version-slurmdbd slurm$version-slurmrestd slurm$version-slurmctld slurm$version-slurmd";
# Since this is a single node system, we don't have to modify the conf files. We will for larger multi-node tests.
# start services
assert_script_run "systemctl enable --now slurmctld slurmdbd slurmrestd slurmd";
}
sub run {
my $self = shift;
# do all the install stuff
slurm_setup();
# if everything is configured right, sinfo should show the following output
# $ sinfo
# PARTITION AVAIL TIMELIMIT NODES STATE NODELIST
# debug* up infinite 1 idle localhost
validate_script_output "sinfo", sub { m/debug.*localhost/ };
# write a boring job script
assert_script_run "echo '#!/bin/bash\n#SBATCH --job-name=antarctica_time\nsleep 120\nTZ=NZST date' > job.sh";
## schedule a job and run it to completion
assert_script_run "sbatch job.sh";
validate_script_output "squeue", sub { m/antar/ };
sleep 121;
# after 121 seconds, job should have completed and no longer exist in the queue
validate_script_output "squeue", sub { $_ !~ m/antar/ };
## cancel a job
assert_script_run "sbatch job.sh";
validate_script_output "squeue", sub { m/antar/ };
assert_script_run "scancel 2";
# job should no longer be in the queue
validate_script_output "squeue", sub { $_ !~ m/antar/ };
}
sub test_flags {
return {fatal => 1};
}
1;
# vim: set sw=4 et: