Merge branch 'develop'
This commit is contained in:
commit
8cb07a4950
@ -82,7 +82,7 @@
|
|||||||
},
|
},
|
||||||
"version": "*"
|
"version": "*"
|
||||||
},
|
},
|
||||||
"rocky-boot-iso-aarch64-*": {
|
"rocky-boot-iso-aarch64-*": {
|
||||||
"arch": "aarch64",
|
"arch": "aarch64",
|
||||||
"distri": "rocky",
|
"distri": "rocky",
|
||||||
"flavor": "boot-iso",
|
"flavor": "boot-iso",
|
||||||
@ -210,7 +210,7 @@
|
|||||||
"machine": "uefi",
|
"machine": "uefi",
|
||||||
"product": "rocky-GenericCloud_LVM-qcow2-qcow2-x86_64-*"
|
"product": "rocky-GenericCloud_LVM-qcow2-qcow2-x86_64-*"
|
||||||
},
|
},
|
||||||
"rocky-boot-iso-aarch64-*-aarch64": {
|
"rocky-boot-iso-aarch64-*-aarch64": {
|
||||||
"machine": "aarch64",
|
"machine": "aarch64",
|
||||||
"product": "rocky-boot-iso-aarch64-*"
|
"product": "rocky-boot-iso-aarch64-*"
|
||||||
},
|
},
|
||||||
@ -422,7 +422,7 @@
|
|||||||
"POSTINSTALL": "autocloud"
|
"POSTINSTALL": "autocloud"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"install_resize_lvm": {
|
"install_resize_lvm": {
|
||||||
"profiles": {
|
"profiles": {
|
||||||
"rocky-dvd-iso-aarch64-*-aarch64": 40,
|
"rocky-dvd-iso-aarch64-*-aarch64": 40,
|
||||||
"rocky-dvd-iso-x86_64-*-64bit": 40
|
"rocky-dvd-iso-x86_64-*-64bit": 40
|
||||||
@ -926,8 +926,8 @@
|
|||||||
},
|
},
|
||||||
"install_scsi_updates_img": {
|
"install_scsi_updates_img": {
|
||||||
"profiles": {
|
"profiles": {
|
||||||
"rocky-universal-aarch64-*-aarch64": 20,
|
"rocky-universal-aarch64-*-aarch64": 20,
|
||||||
"rocky-universal-x86_64-*-64bit": 20
|
"rocky-universal-x86_64-*-64bit": 20
|
||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"CDMODEL": "scsi-cd",
|
"CDMODEL": "scsi-cd",
|
||||||
@ -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,
|
||||||
|
65
tests/slurm.pm
Normal file
65
tests/slurm.pm
Normal 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:
|
Loading…
Reference in New Issue
Block a user