mirror of
				https://pagure.io/fedora-qa/os-autoinst-distri-fedora.git
				synced 2025-10-25 04:28:49 +00:00 
			
		
		
		
	We seem to be solidly back to always getting a permanent update notification in current F36/Rawhide, so we don't need this more complex path any more. We also don't need these needles any more, they haven't matched for months.
		
			
				
	
	
		
			140 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			5.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;
 | |
|     # use tty1 to avoid RHBZ #1821499 on F32 Workstation live
 | |
|     $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'));
 | |
|         }
 | |
|     }
 | |
|     # can't use assert_script_run here as long as we're on tty1
 | |
|     type_string "systemctl isolate 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 (get_var("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);
 | |
|     # 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:
 |