From Fedora Project Wiki

mNo edit summary
(link to tracker issues)
 
(11 intermediate revisions by 2 users not shown)
Line 6: Line 6:
|description=This test case tests whether '''user switching''' works correctly, i.e. it is possible, in case one user is logged in a system session, another user (or users) can log onto the system and use their own session in parallel with the first user without affecting the original session in any way.
|description=This test case tests whether '''user switching''' works correctly, i.e. it is possible, in case one user is logged in a system session, another user (or users) can log onto the system and use their own session in parallel with the first user without affecting the original session in any way.


'''User switching''' in this context '''does not''' represent switching between a desktop session and a virtual console, nor it represents using '''su''' or '''sudo''' commands to acquire different user identities on a terminal session.
'''User switching''' in this context '''does not''' represent switching between a desktop session and a virtual console, nor it represents using '''su''' or '''sudo''' commands to acquire different user identities on a terminal session. Also note, that this test case does not cover switching different between different desktop environments.


|setup=
# Create a default installation of the Fedora release and Edition (Workstation, KDE) you wish to test.
# Create two user accounts.
#* Optional: Set a different desktop background for both of them, so that you can distinguish them easily.
# Clean boot the system.


|actions=
|actions=
# Create a default installation of the Fedora release and flavor (Workstation, KDE) you wish to test.
# Create two user accounts.
# Clean boot the system.
=== Scenario 1 ===
=== Scenario 1 ===
# Log in with the first user account.
# Log in with the first user account.
# Check if the correct user has been logged in.
# Check if the correct user has been logged in.
# Open one or more applications.
# Open one or more applications (optionally open or create some content in them).
# Optionally open or create some content in them.
# Use the system menu to switch users ('''switch users''' usually is located along '''reboot''' and '''shutdown''' menu items)
# Use the system menu to switch users ('''switch users''' usually is located along '''reboot''' and '''shutdown''' menu items)
# Log in with the second user account.
# Log in with the second user account.
# Open one or more applications and close them again.
# Open one or more applications.
# Switch to the first user again.
# Check that all applications are still running as they were before.
# Switch between the users several times.
# Log out of the current session.
# Log out of the current session.
# Log in with the first user account again.
# Try to reboot the system.
# Check that all applications are still running as they were before.
# '''Check that a warning dialog appears''', informing you that the other user is still logged in and his session data might be lost.
# Close them and log out.
# Confirm the reboot.


=== Scenario 2 ===
=== Scenario 2 ===
# Log in with the first user account.
# Log in with the first user account.
# Check if the correct user has been logged in.
# Check if the correct user has been logged in.
# Open one or more applications.
# Open one or more applications (optionally open or create some content in them).
# Optionally open or create some content in them.
# Identify all possible options to switch the users, e.g. menu item, locked screen, or login screen.
# '''Lock the screen''' using the menu or the keyboard shortcut.
# Use all those identified options to switch to a second user account (open some applications there as well) and back to the first user account.
# Use '''switch user button''' to switch users.
# Check that all applications are still running as they were before, after each switch, in both accounts.
# Log in with the second user account.
# Close all sessions.
# Open one or more applications and close them again.
# Log out of the current session.
# Log in with the first user account again.
# Check that all applications are still running as they were before.
# Close them and log out.


=== Scenario 3 ===
=== Scenario 3 ===
# Log in with the first user account.
# Log in with the first user account.
# Check if the correct user has been logged in.
# Check if the correct user has been logged in.
# Open one or more applications.
# Open one or more applications (optionally open or create some content in them).
# Optionally open or create some content in them.
# Switch to the second user.
# Switch to a different user.
# Do some activity in your session and log out.
# Open one or more applications and close them again.
# Log in again as the same (second) user.
# Log out of the current session.
# Repeat this process several times (steps 5 to 6).
# Reboot the system.
# Switch to the first user again.
# Check that all applications are still running as they were before.
# Close all sessions.


=== Scenario 4 (optional) ===
=== Scenario 4 (optional) ===
# Log in with the first user account.
# Try switching more than two users.
# Check if the correct user has been logged in.
# Open one or more applications.
# Optionally open or create some content in them.
# Use the system menu to switch users.
# Log in with the second user account.
# Open one or more applications.
# Switch between the two users several time and check the status of the sessions.
# Finally, log out of both accounts.


=== Scenario 5 (optional) ===
=== Scenario 5 (optional) ===
# Try switching more than two users.
<ol>
<li> If you performed the standard scenarios with users having a login password, try running some of those scenarios with passwordless users (having an empty password, not expired, not locked).
<ul><li> At the very minimum you can create passwordless users in certain editions of the Anaconda installer (KDE Live, Everything netinst, etc), or by using the command line on the installed system:
<pre>sudo useradd username
sudo passwd -d username</pre>
</ul>
<li> And the other way around - if you initially used passwordless users, try running the same steps using users with login passwords.
</ol>


|results=
|results=
# When switching users, the second user must be able to log in and another desktop session must start and function fully.
# When starting a new session through user switching, the particular user must be able to log in and his desktop session must start and function fully.
# When returning to a previous session, the particular user must be able to log back and the session's previous status-quo must be restored, i.e. all applications are still running as they were before the switch.
# When returning to a previous session, the particular user must be able to log back and the session's previous state must be restored, i.e. all applications are still running as they were before the switch.
# When trying to reboot or power-off a system with logged-in users, a warning message about possible consequences must appear and needs to be confirmed out before rebooting or powering off.
# When trying to reboot or power-off a system with logged-in users, a warning message about possible consequences must appear and needs to be confirmed before rebooting or powering off.
# Problems with logging in and out, as well as with rebooting or powering off the system, are out of scope of this test, but they would automatically fail the [[QA:Testcase_desktop_login]] test case.
# Problems with logging in and out, as well as with rebooting or powering off the system, are out of scope of this test, but they would automatically fail the [[QA:Testcase_desktop_login]] test case.
# When testing GNOME, please report all failures to the [https://gitlab.gnome.org/GNOME/gnome-shell/issues GNOME tracker].
}}
}}
[[Category:Desktop_Acceptance_Test_Cases]]
[[Category:Desktop_Acceptance_Test_Cases]]
[[Category:Package_gnome-shell_test_cases]]
[[Category:Package_gdm_test_cases]]
[[Category:GNOME desktop feature test cases]]

Latest revision as of 11:06, 8 March 2023

Associated release criterion
This test case is associated with the Fedora_42_Final_Release_Criteria#user-switching release criterion. If you are doing release validation testing, a failure of this test case may be a breach of that release criterion. If so, please file a bug and nominate it as blocking the appropriate milestone, using the blocker bug nomination page.


Description

This test case tests whether user switching works correctly, i.e. it is possible, in case one user is logged in a system session, another user (or users) can log onto the system and use their own session in parallel with the first user without affecting the original session in any way.

User switching in this context does not represent switching between a desktop session and a virtual console, nor it represents using su or sudo commands to acquire different user identities on a terminal session. Also note, that this test case does not cover switching different between different desktop environments.

Setup

  1. Create a default installation of the Fedora release and Edition (Workstation, KDE) you wish to test.
  2. Create two user accounts.
    • Optional: Set a different desktop background for both of them, so that you can distinguish them easily.
  3. Clean boot the system.

How to test

Scenario 1

  1. Log in with the first user account.
  2. Check if the correct user has been logged in.
  3. Open one or more applications (optionally open or create some content in them).
  4. Use the system menu to switch users (switch users usually is located along reboot and shutdown menu items)
  5. Log in with the second user account.
  6. Open one or more applications.
  7. Switch to the first user again.
  8. Check that all applications are still running as they were before.
  9. Switch between the users several times.
  10. Log out of the current session.
  11. Try to reboot the system.
  12. Check that a warning dialog appears, informing you that the other user is still logged in and his session data might be lost.
  13. Confirm the reboot.

Scenario 2

  1. Log in with the first user account.
  2. Check if the correct user has been logged in.
  3. Open one or more applications (optionally open or create some content in them).
  4. Identify all possible options to switch the users, e.g. menu item, locked screen, or login screen.
  5. Use all those identified options to switch to a second user account (open some applications there as well) and back to the first user account.
  6. Check that all applications are still running as they were before, after each switch, in both accounts.
  7. Close all sessions.

Scenario 3

  1. Log in with the first user account.
  2. Check if the correct user has been logged in.
  3. Open one or more applications (optionally open or create some content in them).
  4. Switch to the second user.
  5. Do some activity in your session and log out.
  6. Log in again as the same (second) user.
  7. Repeat this process several times (steps 5 to 6).
  8. Switch to the first user again.
  9. Check that all applications are still running as they were before.
  10. Close all sessions.

Scenario 4 (optional)

  1. Try switching more than two users.

Scenario 5 (optional)

  1. If you performed the standard scenarios with users having a login password, try running some of those scenarios with passwordless users (having an empty password, not expired, not locked).
    • At the very minimum you can create passwordless users in certain editions of the Anaconda installer (KDE Live, Everything netinst, etc), or by using the command line on the installed system:
      sudo useradd username
      sudo passwd -d username
  2. And the other way around - if you initially used passwordless users, try running the same steps using users with login passwords.

Expected Results

  1. When starting a new session through user switching, the particular user must be able to log in and his desktop session must start and function fully.
  2. When returning to a previous session, the particular user must be able to log back and the session's previous state must be restored, i.e. all applications are still running as they were before the switch.
  3. When trying to reboot or power-off a system with logged-in users, a warning message about possible consequences must appear and needs to be confirmed before rebooting or powering off.
  4. Problems with logging in and out, as well as with rebooting or powering off the system, are out of scope of this test, but they would automatically fail the QA:Testcase_desktop_login test case.
  5. When testing GNOME, please report all failures to the GNOME tracker.