Refactored switchUSer to handle user switch back to the current user
The existing implementation of user switching puts subsequent user switches into a queue if there is already a user switch in progress. For example, if the current user is A and there is a user switch sequence to switch to user B and then to user C, the UserController#switchUser method will put the user switch to C into a pending user switch list and perform it once the existing user switch to B is finished. However, if the sequence is to switch from user A to user B and then back to user A, and when switch to user A reaches the UserController#switchUser method before the switch to user B is completed, the method will think that the current user is A and that there is no need to switch to user A, and will therefore skip that switch. The refactored code handles this scenario by adding an extra condition which additionally verifies that there are no further switches scheduled in case the target user is equal to the current user and the switch is going to be skipped. Bug: 303743201 Test: tested manually with switch user scenario current user is 0 switch to user 10 and then switch back to user 0. Change-Id: Ia40cfacbee6fc174c90db8e3687838ae01e2858b Merged-In: Ia40cfacbee6fc174c90db8e3687838ae01e2858b
Loading
Please register or sign in to comment