1
0
mirror of https://pagure.io/fedora-qa/os-autoinst-distri-fedora.git synced 2024-11-21 21:43:08 +00:00

Compare commits

...

2 Commits

Author SHA1 Message Date
Adam Williamson
e9e967c4bf Consistently use desktop_launch_terminal
Also be a bit more consistent about asserting we saw a terminal
and waiting a bit before typing stuff. We can drop the doublek
workarounds from the keyring tests as we no longer use the
kicker to launch the terminal on KDE (we use ctrl-alt-t shortcut).

Signed-off-by: Adam Williamson <awilliam@redhat.com>
2024-10-09 17:19:00 -07:00
Adam Williamson
1f4324b270 abstract desktop terminal launch, refactor user switch, enable for KDE
This started out as just factoring out the repeated pattern for
launching a terminal on the desktop that came in with the i3
tests. But as I worked on desktop_login, which is a major user
of it, I noticed some potential cleanups and improvements in the
user switching stuff, and also realized we can turn that test
back on for KDE now - user switching was re-enabled in KDE a year
ago and is advertised to be reliable.

I don't think the "switch user from a lock screen" test fully
worked before, as we did not verify that we'd really switched
back to an existing session rather than starting a new one. Now
we do. Using the terminal to verify the logged-in user on all
desktops just keeps things simpler than using the kicker menu
on KDE (though if typing proves unreliable on KDE I may switch
this back).

Signed-off-by: Adam Williamson <awilliam@redhat.com>
2024-10-09 17:16:13 -07:00
32 changed files with 72 additions and 234 deletions

View File

@ -6,7 +6,7 @@ use base 'Exporter';
use Exporter; use Exporter;
use lockapi; use lockapi;
use testapi qw(is_serial_terminal :DEFAULT); use testapi qw(is_serial_terminal :DEFAULT);
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 setup_repos repo_setup get_workarounds disable_updates_repos cleanup_workaround_repo console_initial_setup handle_welcome_screen gnome_initial_setup anaconda_create_user check_desktop quit_firefox advisory_get_installed_packages acnp_handle_output advisory_check_nonmatching_packages start_with_launcher quit_with_shortcut disable_firefox_studies select_rescue_mode copy_devcdrom_as_isofile get_release_number check_left_bar check_top_bar check_prerelease check_version spell_version_number _assert_and_click is_branched rec_log repos_mirrorlist register_application get_registered_applications solidify_wallpaper check_and_install_git download_testdata make_serial_writable set_update_notification_timestamp kde_doublek_workaround dm_perform_login/; 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 setup_repos repo_setup get_workarounds disable_updates_repos cleanup_workaround_repo console_initial_setup handle_welcome_screen gnome_initial_setup anaconda_create_user check_desktop quit_firefox advisory_get_installed_packages acnp_handle_output advisory_check_nonmatching_packages start_with_launcher quit_with_shortcut disable_firefox_studies select_rescue_mode copy_devcdrom_as_isofile get_release_number check_left_bar check_top_bar check_prerelease check_version spell_version_number _assert_and_click is_branched rec_log repos_mirrorlist register_application get_registered_applications desktop_launch_terminal solidify_wallpaper check_and_install_git download_testdata make_serial_writable set_update_notification_timestamp kde_doublek_workaround dm_perform_login/;
# We introduce this global variable to hold the list of applications that have # We introduce this global variable to hold the list of applications that have
@ -1609,6 +1609,22 @@ sub register_application {
print("APPLICATION REGISTERED: $application \n"); print("APPLICATION REGISTERED: $application \n");
} }
# launch a terminal from a desktop, using the most efficient/reliable
# approach (not appropriate if we really need to test launching it a
# specific way)
sub desktop_launch_terminal {
my $desktop = get_var("DESKTOP");
if ($desktop eq "i3") {
send_key "alt-ret";
}
elsif ($desktop eq "kde") {
send_key "ctrl-alt-t";
}
else {
menu_launch_type "terminal";
}
}
# The KDE desktop tests are very difficult to maintain, because the transparency # The KDE desktop tests are very difficult to maintain, because the transparency
# of the menu requires a lot of different needles to cover the elements. # of the menu requires a lot of different needles to cover the elements.
# Therefore it is useful to change the background to a solid colour. # Therefore it is useful to change the background to a solid colour.
@ -1652,7 +1668,8 @@ sub solidify_wallpaper {
} }
elsif ($desktop eq "gnome") { elsif ($desktop eq "gnome") {
# Start the terminal to set up backgrounds. # Start the terminal to set up backgrounds.
menu_launch_type("terminal"); desktop_launch_terminal;
assert_screen "apps_run_terminal";
# wait to be sure it's fully open # wait to be sure it's fully open
wait_still_screen(stilltime => 5, similarity_level => 38); wait_still_screen(stilltime => 5, similarity_level => 38);
# When the application opens, run command in it to set the background to black # When the application opens, run command in it to set the background to black
@ -1760,7 +1777,8 @@ sub set_update_notification_timestamp {
sub start_applications { sub start_applications {
my @applications = @_; my @applications = @_;
# Open the terminal # Open the terminal
menu_launch_type("terminal"); desktop_launch_terminal;
assert_screen("apps_run_terminal");
wait_still_screen(2); wait_still_screen(2);
# Iterate over the application list # Iterate over the application list
# and start each application from it. # and start each application from it.

View File

@ -1,15 +0,0 @@
{
"area": [
{
"width": 41,
"type": "match",
"ypos": 173,
"xpos": 191,
"height": 21
}
],
"properties": [],
"tags": [
"user_confirm_jack"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"height": 21,
"width": 39,
"ypos": 165,
"type": "match",
"xpos": 185
}
],
"properties": [],
"tags": [
"user_confirm_jack"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 25 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"width": 39,
"height": 21,
"type": "match",
"xpos": 185,
"ypos": 165
}
],
"properties": [],
"tags": [
"user_confirm_jack"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"height": 15,
"type": "match",
"ypos": 176,
"xpos": 193,
"width": 31
}
],
"properties": [],
"tags": [
"user_confirm_jim"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"height": 15,
"width": 31,
"ypos": 168,
"xpos": 185,
"type": "match"
}
],
"properties": [],
"tags": [
"user_confirm_jim"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 25 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"height": 15,
"width": 31,
"xpos": 185,
"ypos": 168,
"type": "match"
}
],
"properties": [],
"tags": [
"user_confirm_jim"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"height": 15,
"xpos": 40,
"ypos": 217,
"type": "match",
"width": 31
}
],
"properties": [],
"tags": [
"user_confirm_jack"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 59 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"height": 16,
"type": "match",
"ypos": 200,
"width": 31,
"xpos": 44
}
],
"properties": [],
"tags": [
"user_confirm_jack"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 102 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"ypos": 215,
"type": "match",
"width": 26,
"xpos": 39,
"height": 17
}
],
"properties": [],
"tags": [
"user_confirm_jim"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 58 KiB

View File

@ -1,15 +0,0 @@
{
"area": [
{
"width": 26,
"xpos": 43,
"ypos": 199,
"type": "match",
"height": 17
}
],
"properties": [],
"tags": [
"user_confirm_jim"
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 101 KiB

View File

@ -6,7 +6,8 @@ use utils;
sub run { sub run {
my $self = shift; my $self = shift;
menu_launch_type 'terminal'; desktop_launch_terminal;
assert_screen "apps_run_terminal";
wait_still_screen 5; wait_still_screen 5;
type_very_safely "vncviewer -FullScreen -listen\n"; type_very_safely "vncviewer -FullScreen -listen\n";
mutex_create 'vncconnect_client_ready'; mutex_create 'vncconnect_client_ready';

View File

@ -24,7 +24,7 @@ sub run {
my $self = shift; my $self = shift;
# Open the terminal to enable us to set the # Open the terminal to enable us to set the
# volume level. # volume level.
menu_launch_type("terminal"); desktop_launch_terminal;
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
# Set the volume to 0% # Set the volume to 0%
type_safely('amixer -D pipewire sset Master 0%'); type_safely('amixer -D pipewire sset Master 0%');

View File

@ -63,10 +63,8 @@ sub connect_localhost {
# Therefore, we will use a different approach - we will enable # Therefore, we will use a different approach - we will enable
# CLI keyring integration and perform an SFTP connection # CLI keyring integration and perform an SFTP connection
# in Konsole. # in Konsole.
# try and avoid double-typing issues desktop_launch_terminal;
kde_doublek_workaround; assert_screen("apps_run_terminal");
menu_launch_type("konsole");
assert_screen("konsole_runs");
# Export the environmental variables, this is needed for the process # Export the environmental variables, this is needed for the process
# to work correctly. # to work correctly.
export_kde_vars(); export_kde_vars();

View File

@ -28,18 +28,11 @@ sub export_kde_vars {
sub connect_localhost { sub connect_localhost {
my $type = shift; my $type = shift;
# Start the terminal application. On KDE also export the variables. # Start the terminal application
if (get_var("DESKTOP") eq "gnome") { desktop_launch_terminal;
menu_launch_type("terminal");
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
} # On KDE also export the variables
else { export_kde_vars() if (get_var("DESKTOP") eq "kde");
# try and avoid double-typing issues
kde_doublek_workaround;
menu_launch_type("konsole");
assert_screen("konsole_runs");
export_kde_vars();
}
# Establish the SFTP connection to the localhost. # Establish the SFTP connection to the localhost.
# A dialogue should appear to collect credentials to open # A dialogue should appear to collect credentials to open

View File

@ -9,6 +9,8 @@ sub run {
my $self = shift; my $self = shift;
# Start the application # Start the application
# we don't use desktop_launch_terminal here as we specifically
# want to run 'konsole' from the kicker menu in this test
menu_launch_type 'konsole'; menu_launch_type 'konsole';
# Check that it is started # Check that it is started
assert_screen 'konsole_runs', timeout => 60; assert_screen 'konsole_runs', timeout => 60;

View File

@ -27,12 +27,12 @@ sub run {
desktop_switch_layout 'ascii'; desktop_switch_layout 'ascii';
wait_still_screen(2); wait_still_screen(2);
menu_launch_type("terminal"); desktop_launch_terminal;
# Similarly to _graphical_input.pm, repeat running the command # Similarly to _graphical_input.pm, repeat running the command
# if it fails the first time (it often does). # if it fails the first time (it often does).
unless (check_screen "apps_run_terminal", 30) { unless (check_screen "apps_run_terminal", 30) {
check_desktop; check_desktop;
menu_launch_type("terminal"); desktop_launch_terminal;
} }
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
wait_still_screen(stilltime => 5, similarity_level => 42); wait_still_screen(stilltime => 5, similarity_level => 42);

View File

@ -115,32 +115,21 @@ sub login_user {
sub check_user_logged_in { sub check_user_logged_in {
# Performs a check that a correct user has been locked in. # Performs a check that a correct user has been locked in.
my $user = shift; my %args = @_;
my $exitkey; $args{termopen} //= 0;
# In Gnome, the name of the user was accessible through menu $args{keepterm} //= 0;
# in the upper right corner, but apparently it has been removed. my $user = $args{user};
# Reading the login name from the terminal prompt seems to be # In Gnome and i3, the current user's name is not easily visible,
# the most reliable thing to do. # so reading the login name from the terminal prompt seems to be
if ($desktop eq "gnome") { # the most reliable thing to do. In KDE we could see it on the
menu_launch_type("terminal"); # launcher menu, but it keeps things clean if we use the same
wait_still_screen 2; # approach for all desktops.
$exitkey = "alt-f4"; my $exitkey = "alt-f4";
} $exitkey = "shift-ctrl-q" if ($desktop eq "i3");
elsif ($desktop eq "i3") { desktop_launch_terminal unless ($args{termopen});
send_key("alt-ret");
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
assert_script_run('[ $(whoami) = "' . "$user\" ]"); assert_script_run('[ $(whoami) = "' . "$user\" ]");
wait_screen_change { send_key("alt-shift-q"); }; send_key $exitkey unless ($args{keepterm});
return;
}
# With KDE, the user is shown in the main menu, so let us just
# open this and see.
else {
assert_and_click "system_menu_button";
$exitkey = "esc";
}
assert_screen "user_confirm_$user";
send_key $exitkey;
wait_still_screen 5; wait_still_screen 5;
} }
@ -163,7 +152,6 @@ sub logout_user {
sub switch_user { sub switch_user {
# Switch the user, i.e. leave the current user logged in and # Switch the user, i.e. leave the current user logged in and
# log in another user simultaneously. # log in another user simultaneously.
send_key "ret";
if (check_screen "locked_screen_switch_user", 5) { if (check_screen "locked_screen_switch_user", 5) {
assert_and_click "locked_screen_switch_user"; assert_and_click "locked_screen_switch_user";
} }
@ -276,7 +264,7 @@ sub run {
# Log in with the first user account. # Log in with the first user account.
login_user(user => "jack", password => $jackpass); login_user(user => "jack", password => $jackpass);
check_user_logged_in("jack"); check_user_logged_in(user => "jack");
# Log out the user. # Log out the user.
logout_user(); logout_user();
@ -289,7 +277,7 @@ sub run {
# If not, we are in KDE and we will log in normally. # If not, we are in KDE and we will log in normally.
login_user(user => "jim", password => $jimpass); login_user(user => "jim", password => $jimpass);
} }
check_user_logged_in("jim"); check_user_logged_in(user => "jim");
# And this time reboot the system using the menu. # And this time reboot the system using the menu.
reboot_system(); reboot_system();
@ -307,7 +295,7 @@ sub run {
# only work if we were correctly denied login with the wrong password, # only work if we were correctly denied login with the wrong password,
# if we were let in with the wrong password it'll fail # if we were let in with the wrong password it'll fail
login_user(user => "jim", password => $jimpass); login_user(user => "jim", password => $jimpass);
check_user_logged_in("jim"); check_user_logged_in(user => "jim");
# Lock the screen and unlock again. # Lock the screen and unlock again.
lock_screen(); lock_screen();
@ -315,32 +303,29 @@ sub run {
login_user(user => "jim", password => $jimpass, method => "unlock"); login_user(user => "jim", password => $jimpass, method => "unlock");
# Switch user tests # Switch user tests
if ($desktop eq "gnome") { unless ($desktop eq "i3") {
# Because KDE at the moment (20200403) is very unreliable concerning switching the users inside
# the virtual machine, we will skip this part, until situation is better. Switching users will
# be only tested in Gnome.
# Start a terminal session to monitor on which sessions we are, when we start switching users. # Start a terminal session to monitor on which sessions we are, when we start switching users.
# This time, we will open the terminal window manually because we want to leave it open later. # This time, we will open the terminal window manually because we want to leave it open later.
menu_launch_type "terminal"; desktop_launch_terminal;
wait_still_screen 2; wait_still_screen 2;
# Initiate switch user # Initiate switch user
switch_user(); switch_user();
# Now, we get a new login screen, so let's do the login into the new session. # Now, we get a new login screen, so let's do the login into the new session.
login_user(user => "jack", password => $jackpass); login_user(user => "jack", password => $jackpass);
# Check that it is a new session, the terminal window should not be visible. # Check that it is a new session, the terminal window should not be visible.
if (check_screen "user_confirm_jim") { if (check_screen "apps_run_terminal") {
die "The session was not switched!"; die "The session was not switched!";
} }
else { else {
check_user_logged_in("jack"); # keep the terminal open so we can check later
check_user_logged_in(user => "jack", keepterm => 1);
} }
# Log out the user. # Switch again.
logout_user(); switch_user();
# Now, let us log into the original session, this time, the terminal window # Now, let us log into the original session, this time, the terminal window
# should still be visible. # should still be visible.
login_user(user => "jim", password => $jimpass); login_user(user => "jim", password => $jimpass);
assert_screen "user_confirm_jim"; check_user_logged_in(user => "jim", termopen => 1);
# We will also test another alternative - switching the user from # We will also test another alternative - switching the user from
# a locked screen. # a locked screen.
@ -348,7 +333,9 @@ sub run {
send_key "ret"; send_key "ret";
switch_user(); switch_user();
login_user(user => "jack", password => $jackpass); login_user(user => "jack", password => $jackpass);
check_user_logged_in("jack"); # we should be back in the previous 'jack' session so the terminal
# we kept open should be there
check_user_logged_in(user => "jack", termopen => 1);
} }
# Power off the machine # Power off the machine
power_off(); power_off();

View File

@ -146,7 +146,7 @@ sub run {
# we launch a terminal so that the top of the screen is filled with # we launch a terminal so that the top of the screen is filled with
# something that we know and can check that it is not covered by a # something that we know and can check that it is not covered by a
# notification popup from dunst # notification popup from dunst
send_key('alt-ret'); desktop_launch_terminal;
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
assert_script_run('notify-send -t 10000 "foo"'); assert_script_run('notify-send -t 10000 "foo"');
assert_screen("i3_dunst_foo_notification", timeout => 5); assert_screen("i3_dunst_foo_notification", timeout => 5);

View File

@ -71,17 +71,11 @@ sub run {
} }
# Let's open the terminal. We will use it to start the applications # Let's open the terminal. We will use it to start the applications
# as well as to check for the name of the printed file. # as well as to check for the name of the printed file.
if ($desktop eq "i3") { desktop_launch_terminal;
send_key('alt-ret');
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
wait_still_screen 3;
# switch to tabbed mode # switch to tabbed mode
send_key("alt-w"); send_key("alt-w") if ($desktop eq "i3");
}
else {
menu_launch_type($term);
wait_still_screen(5);
}
# Open the text editor and maximize it. # Open the text editor and maximize it.
wait_screen_change { type_very_safely "$editor /home/$user/testfile.txt &\n"; }; wait_screen_change { type_very_safely "$editor /home/$user/testfile.txt &\n"; };
wait_still_screen(stilltime => 2, similarity_level => 45); wait_still_screen(stilltime => 2, similarity_level => 45);

View File

@ -10,12 +10,7 @@ sub run {
check_desktop; check_desktop;
# try and avoid double-typing issues # try and avoid double-typing issues
kde_doublek_workaround(key => 't') if ($desktop eq "kde"); kde_doublek_workaround(key => 't') if ($desktop eq "kde");
if ($desktop eq "i3") { desktop_launch_terminal;
send_key("alt-ret");
}
else {
menu_launch_type('terminal');
}
assert_screen "apps_run_terminal"; assert_screen "apps_run_terminal";
wait_still_screen(stilltime => 5, similarity_level => 42); wait_still_screen(stilltime => 5, similarity_level => 42);
# need to be root # need to be root

View File

@ -7,7 +7,7 @@ sub run {
my $password = get_var('USER_PASSWORD', 'weakpassword'); my $password = get_var('USER_PASSWORD', 'weakpassword');
# launch a terminal first # launch a terminal first
send_key("alt-ret"); desktop_launch_terminal;
assert_screen("apps_run_terminal"); assert_screen("apps_run_terminal");
# start blivet_gui, mousepad and check that they are split on the screen # start blivet_gui, mousepad and check that they are split on the screen