mirror of
https://pagure.io/fedora-qa/os-autoinst-distri-fedora.git
synced 2024-10-31 21:44:23 +00:00
add ARM initial-setup test
ARM actually doesn't have "install" test, but in install matrix, there is test whether ARM disk boots into initial_setup. HDD is saved after this test for Base tests. Differential Revision: https://phab.qadevel.cloud.fedoraproject.org/D853
This commit is contained in:
parent
0d488890ba
commit
dfc58f1b73
15
needles/console/console_initial_setup.json
Normal file
15
needles/console/console_initial_setup.json
Normal file
@ -0,0 +1,15 @@
|
||||
{
|
||||
"properties": [],
|
||||
"tags": [
|
||||
"console_initial_setup"
|
||||
],
|
||||
"area": [
|
||||
{
|
||||
"xpos": 3,
|
||||
"ypos": 610,
|
||||
"width": 100,
|
||||
"height": 12,
|
||||
"type": "match"
|
||||
}
|
||||
]
|
||||
}
|
BIN
needles/console/console_initial_setup.png
Normal file
BIN
needles/console/console_initial_setup.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
29
needles/console/console_initial_setup_done.json
Normal file
29
needles/console/console_initial_setup_done.json
Normal file
@ -0,0 +1,29 @@
|
||||
{
|
||||
"area": [
|
||||
{
|
||||
"xpos": 360,
|
||||
"ypos": 624,
|
||||
"width": 98,
|
||||
"height": 14,
|
||||
"type": "match"
|
||||
},
|
||||
{
|
||||
"xpos": 361,
|
||||
"ypos": 658,
|
||||
"width": 65,
|
||||
"height": 12,
|
||||
"type": "match"
|
||||
},
|
||||
{
|
||||
"xpos": 33,
|
||||
"ypos": 690,
|
||||
"width": 65,
|
||||
"height": 11,
|
||||
"type": "match"
|
||||
}
|
||||
],
|
||||
"tags": [
|
||||
"console_initial_setup_done"
|
||||
],
|
||||
"properties": []
|
||||
}
|
BIN
needles/console/console_initial_setup_done.png
Normal file
BIN
needles/console/console_initial_setup_done.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.6 KiB |
40
templates
40
templates
@ -28,6 +28,17 @@
|
||||
},
|
||||
test_suite => { name => "install_default" },
|
||||
},
|
||||
{
|
||||
machine => { name => "ARM" },
|
||||
prio => 60,
|
||||
product => {
|
||||
arch => "arm",
|
||||
distri => "fedora",
|
||||
flavor => "Minimal-raw_xz-raw.xz",
|
||||
version => "*",
|
||||
},
|
||||
test_suite => { name => "install_arm_image_deployment_upload" },
|
||||
},
|
||||
{
|
||||
machine => { name => "64bit" },
|
||||
prio => 10,
|
||||
@ -1010,6 +1021,19 @@
|
||||
{ key => "PART_TABLE_TYPE", value => "gpt"}
|
||||
],
|
||||
},
|
||||
{
|
||||
backend => "qemu",
|
||||
name => "ARM",
|
||||
settings => [
|
||||
{ key => "QEMU", value => "arm" },
|
||||
{ key => "QEMUCPUS", value => "2"},
|
||||
{ key => "QEMUMACHINE", value => "virt"},
|
||||
{ key => "QEMURAM", value => "1024"},
|
||||
{ key => "QEMU_NO_KVM", value => "1"},
|
||||
{ key => "TIMEOUT_SCALE", value => "5" },
|
||||
{ key => "SERIALDEV", value => "ttyAMA0" }
|
||||
],
|
||||
},
|
||||
],
|
||||
Products => [
|
||||
{
|
||||
@ -1157,6 +1181,15 @@
|
||||
{ key => "DESKTOP", value => "kde" }
|
||||
],
|
||||
version => "*",
|
||||
},
|
||||
{
|
||||
arch => "arm",
|
||||
distri => "fedora",
|
||||
flavor => "Minimal-raw_xz-raw.xz",
|
||||
name => "",
|
||||
settings => [
|
||||
],
|
||||
version => "*",
|
||||
}
|
||||
],
|
||||
TestSuites => [
|
||||
@ -1173,6 +1206,13 @@
|
||||
{ key => "STORE_HDD_1", value => "disk_%FLAVOR%_%MACHINE%.qcow2" },
|
||||
],
|
||||
},
|
||||
{
|
||||
name => "install_arm_image_deployment_upload",
|
||||
settings => [
|
||||
{ key => "ENTRYPOINT", value => "install_arm_image_deployment" },
|
||||
{ key => "STORE_HDD_1", value => "disk_%FLAVOR%_%MACHINE%.qcow2" },
|
||||
],
|
||||
},
|
||||
{
|
||||
name => "install_package_set_minimal",
|
||||
settings => [
|
||||
|
73
tests/install_arm_image_deployment.pm
Normal file
73
tests/install_arm_image_deployment.pm
Normal file
@ -0,0 +1,73 @@
|
||||
use base "installedtest";
|
||||
use strict;
|
||||
use testapi;
|
||||
|
||||
sub run {
|
||||
my $self = shift;
|
||||
assert_screen "console_initial_setup", 150;
|
||||
# IMHO it's better to use sleeps than to have needle for every text screen
|
||||
wait_still_screen 5;
|
||||
|
||||
# Set timezone
|
||||
type_string "2\n";
|
||||
wait_still_screen 5;
|
||||
type_string "1\n"; # Europe
|
||||
wait_still_screen 5;
|
||||
type_string "37\n"; # Prague
|
||||
wait_still_screen 7;
|
||||
|
||||
# Set root password
|
||||
type_string "4\n";
|
||||
wait_still_screen 5;
|
||||
type_string get_var("ROOT_PASSWORD") || "weakpassword";
|
||||
send_key "ret";
|
||||
wait_still_screen 5;
|
||||
type_string get_var("ROOT_PASSWORD") || "weakpassword";
|
||||
send_key "ret";
|
||||
wait_still_screen 7;
|
||||
|
||||
# Create user
|
||||
type_string "5\n";
|
||||
wait_still_screen 5;
|
||||
type_string "1\n"; # create new
|
||||
wait_still_screen 5;
|
||||
type_string "3\n"; # set username
|
||||
wait_still_screen 5;
|
||||
type_string get_var("USER_LOGIN", "test");
|
||||
send_key "ret";
|
||||
wait_still_screen 5;
|
||||
type_string "4\n"; # use password
|
||||
wait_still_screen 5;
|
||||
type_string "5\n"; # set password
|
||||
wait_still_screen 5;
|
||||
type_string get_var("USER_PASSWORD", "weakpassword");
|
||||
send_key "ret";
|
||||
wait_still_screen 5;
|
||||
type_string get_var("USER_PASSWORD", "weakpassword");
|
||||
send_key "ret";
|
||||
wait_still_screen 5;
|
||||
type_string "6\n"; # make him an administrator
|
||||
wait_still_screen 5;
|
||||
type_string "c\n";
|
||||
wait_still_screen 7;
|
||||
|
||||
assert_screen "console_initial_setup_done", 30;
|
||||
type_string "c\n"; # continue
|
||||
assert_screen "text_console_login", 60;
|
||||
|
||||
# Try to log in as an user
|
||||
$self->console_login(user=>get_var("USER_LOGIN", "test"), password=>get_var("USER_PASSWORD", "weakpassword"));
|
||||
}
|
||||
|
||||
|
||||
sub test_flags {
|
||||
# without anything - rollback to 'lastgood' snapshot if failed
|
||||
# 'fatal' - whole test suite is in danger if this fails
|
||||
# 'milestone' - after this test succeeds, update 'lastgood'
|
||||
# 'important' - if this fails, set the overall state to 'fail'
|
||||
return { fatal => 1 };
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
# vim: set sw=4 et:
|
Loading…
Reference in New Issue
Block a user