mirror of
https://pagure.io/fedora-qa/os-autoinst-distri-fedora.git
synced 2025-01-03 08:03:14 +00:00
a6e5700854
It looks like the desktop_notifications postinstall test on KDE on F38 is failing currently because the notification is being shown during the install_default_upload test that precedes it, so KDE decides not to show it again yet. So, unset the setting that stores the timestamp of the last time the notification was shown. This is similar to a thing we already do for GNOME above. Signed-off-by: Adam Williamson <awilliam@redhat.com>
159 lines
6.5 KiB
Perl
159 lines
6.5 KiB
Perl
use base "installedtest";
|
|
use strict;
|
|
use testapi;
|
|
use utils;
|
|
use packagetest;
|
|
|
|
# This test sort of covers QA:Testcase_desktop_update_notification
|
|
# and QA:Testcase_desktop_error_checks . If it fails, probably *one*
|
|
# of those failed, but we don't know which (deciphering which is
|
|
# tricky and involves likely-fragile needles to try and figure out
|
|
# what notifications we have).
|
|
|
|
sub run {
|
|
my $self = shift;
|
|
my $desktop = get_var("DESKTOP");
|
|
# for the live image case, handle bootloader here
|
|
if (get_var("BOOTFROM")) {
|
|
do_bootloader(postinstall => 1, params => '3');
|
|
}
|
|
else {
|
|
do_bootloader(postinstall => 0, params => '3');
|
|
}
|
|
boot_to_login_screen;
|
|
# tty1 is used here for historic reasons, but it's not hurting
|
|
# anything and changing it might, so let's leave it...
|
|
$self->root_console(tty => 1);
|
|
# ensure we actually have some package updates available
|
|
prepare_test_packages;
|
|
if ($desktop eq 'gnome') {
|
|
# On GNOME, move the clock forward if needed, because it won't
|
|
# check for updates before 6am(!)
|
|
my $hour = script_output 'date +%H';
|
|
if ($hour < 6) {
|
|
script_run 'systemctl stop chronyd.service ntpd.service';
|
|
script_run 'systemctl disable chronyd.service ntpd.service';
|
|
script_run 'systemctl mask chronyd.service ntpd.service';
|
|
assert_script_run 'date --set="06:00:00"';
|
|
}
|
|
if (get_var("BOOTFROM")) {
|
|
# Set a bunch of update checking-related timestamps to
|
|
# two days ago or two weeks ago to try and make sure we
|
|
# get notifications, see:
|
|
# https://wiki.gnome.org/Design/Apps/Software/Updates#Tentative_Design
|
|
my $now = script_output 'date +%s';
|
|
my $yyday = $now - 2 * 24 * 60 * 60;
|
|
my $longago = $now - 14 * 24 * 60 * 60;
|
|
# have to log in as the user to do this
|
|
script_run 'exit', 0;
|
|
console_login(user => get_var('USER_LOGIN', 'test'), password => get_var('USER_PASSWORD', 'weakpassword'));
|
|
script_run "gsettings set org.gnome.software check-timestamp ${yyday}", 0;
|
|
script_run "gsettings set org.gnome.software update-notification-timestamp ${longago}", 0;
|
|
script_run "gsettings set org.gnome.software online-updates-timestamp ${longago}", 0;
|
|
script_run "gsettings set org.gnome.software upgrade-notification-timestamp ${longago}", 0;
|
|
script_run "gsettings set org.gnome.software install-timestamp ${longago}", 0;
|
|
wait_still_screen 5;
|
|
script_run 'exit', 0;
|
|
console_login(user => 'root', password => get_var('ROOT_PASSWORD', 'weakpassword'));
|
|
}
|
|
}
|
|
if ($desktop eq 'kde' && get_var("BOOTFROM")) {
|
|
# need to login as user for this
|
|
script_run 'exit', 0;
|
|
console_login(user => get_var('USER_LOGIN', 'test'), password => get_var('USER_PASSWORD', 'weakpassword'));
|
|
# unset the 'last time notification was shown' setting in case
|
|
# it got shown during install_default_upload:
|
|
# https://bugzilla.redhat.com/show_bug.cgi?id=2178311
|
|
script_run 'kwriteconfig5 --file PlasmaDiscoverUpdates --group Global --key LastNotificationTime --delete', 0;
|
|
wait_still_screen 5;
|
|
script_run 'exit', 0;
|
|
console_login(user => 'root', password => get_var('ROOT_PASSWORD', 'weakpassword'));
|
|
}
|
|
|
|
# can't use assert_script_run here as long as we're on tty1
|
|
# we don't use isolate per:
|
|
# https://github.com/systemd/systemd/issues/26364#issuecomment-1424900066
|
|
type_string "systemctl start graphical.target\n";
|
|
# we trust systemd to switch us to the right tty here
|
|
if (get_var("BOOTFROM")) {
|
|
assert_screen 'graphical_login', 60;
|
|
wait_still_screen 10, 30;
|
|
# GDM 3.24.1 dumps a cursor in the middle of the screen here...
|
|
mouse_hide;
|
|
if ($desktop eq 'gnome') {
|
|
# we have to hit enter to get the password dialog, and it
|
|
# doesn't always work for some reason so just try it three
|
|
# times
|
|
send_key_until_needlematch("graphical_login_input", "ret", 3, 5);
|
|
}
|
|
assert_screen "graphical_login_input";
|
|
type_very_safely get_var("USER_PASSWORD", "weakpassword");
|
|
send_key 'ret';
|
|
}
|
|
check_desktop(timeout => 90);
|
|
# KDE lives on F38+ show the 'welcome tour' here and it messes
|
|
# with the needles because transparency, let's get rid
|
|
handle_welcome_screen if ($desktop eq 'kde' && !get_var("BOOTFROM"));
|
|
# now, WE WAIT. this is just an unconditional wait - rather than
|
|
# breaking if we see an update notification appear - so we catch
|
|
# things that crash a few minutes after startup, etc.
|
|
for my $n (1 .. 16) {
|
|
sleep 30;
|
|
mouse_set 10, 10;
|
|
send_key "spc";
|
|
mouse_hide;
|
|
}
|
|
if ($desktop eq 'gnome') {
|
|
# click the clock to show notifications. of course, we have no
|
|
# idea what'll be in the clock, so we just have to click where
|
|
# we know it is
|
|
mouse_set 512, 10;
|
|
mouse_click;
|
|
}
|
|
if ($desktop eq 'kde') {
|
|
if (get_var("BOOTFROM")) {
|
|
# first check the systray update notification is there
|
|
assert_screen "desktop_update_notification_systray";
|
|
}
|
|
# now open the notifications view in the systray
|
|
if (check_screen 'desktop_icon_notifications') {
|
|
# this is the little bell thing KDE sometimes shows if
|
|
# there's been a notification recently...
|
|
click_lastmatch;
|
|
}
|
|
else {
|
|
# ...otherwise you have to expand the systray and click
|
|
# "Notifications"
|
|
assert_and_click 'desktop_expand_systray';
|
|
assert_and_click 'desktop_systray_notifications';
|
|
}
|
|
# In F32+ we may get an 'akonadi did something' message
|
|
if (check_screen 'akonadi_migration_notification', 5) {
|
|
click_lastmatch;
|
|
# in F35+, closing that closes the entire panel, so
|
|
# re-open it
|
|
if (check_screen 'desktop_expand_systray', 10) {
|
|
click_lastmatch;
|
|
assert_and_click 'desktop_systray_notifications';
|
|
}
|
|
}
|
|
}
|
|
if (get_var("BOOTFROM")) {
|
|
# we should see an update notification and no others
|
|
assert_screen "desktop_update_notification_only";
|
|
}
|
|
else {
|
|
# for the live case there should be *no* notifications
|
|
assert_screen "desktop_no_notifications";
|
|
}
|
|
}
|
|
|
|
|
|
sub test_flags {
|
|
return {fatal => 1};
|
|
}
|
|
|
|
1;
|
|
|
|
# vim: set sw=4 et:
|