diff options
author | 2018-04-26 13:07:56 -0700 | |
---|---|---|
committer | 2018-04-26 13:07:56 -0700 | |
commit | 317f7de44ce4441e64cbc3bfc65d34b90a5dab0d (patch) | |
tree | fb9ee13ddaefe9051262a9542e4355c26d6c6b6d | |
parent | ebf0b2b8893a66a86eee459455b302eae889a7b6 (diff) | |
parent | 9df8e5502117b9c62751b5c1b8c9e3168e7d8a8d (diff) |
Merge "Fixes null-ref when trying to start Guest session." into pi-dev am: 8491304cf6
am: 9df8e55021
Change-Id: Ie1b89ca436d97718d01b7d9382e8a68513736f44
5 files changed, 40 insertions, 26 deletions
diff --git a/packages/SettingsLib/src/com/android/settingslib/users/UserManagerHelper.java b/packages/SettingsLib/src/com/android/settingslib/users/UserManagerHelper.java index 113256ff929b..e2faf6a01197 100644 --- a/packages/SettingsLib/src/com/android/settingslib/users/UserManagerHelper.java +++ b/packages/SettingsLib/src/com/android/settingslib/users/UserManagerHelper.java @@ -354,20 +354,15 @@ public final class UserManagerHelper { return; } - if (userInfo.isGuest()) { - switchToGuest(userInfo.name); - return; - } - switchToUserId(userInfo.id); } /** - * Creates a guest session and switches into the guest session. + * Creates a new guest session and switches into the guest session. * * @param guestName Username for the guest user. */ - public void switchToGuest(String guestName) { + public void startNewGuestSession(String guestName) { UserInfo guest = mUserManager.createGuest(mContext, guestName); if (guest == null) { // Couldn't create user, most likely because there are too many, but we haven't @@ -375,6 +370,7 @@ public final class UserManagerHelper { Log.w(TAG, "can't create user."); return; } + assignDefaultIcon(guest); switchToUserId(guest.id); } @@ -417,6 +413,27 @@ public final class UserManagerHelper { mUserManager.setUserName(user.id, name); } + /** + * Gets a bitmap representing the user's default avatar. + * + * @param userInfo User whose avatar should be returned. + * @return Default user icon + */ + public Bitmap getUserDefaultIcon(UserInfo userInfo) { + return UserIcons.convertToBitmap( + UserIcons.getDefaultUserIcon(mContext.getResources(), userInfo.id, false)); + } + + /** + * Gets a bitmap representing the default icon for a Guest user. + * + * @return Degault guest icon + */ + public Bitmap getGuestDefaultIcon() { + return UserIcons.convertToBitmap(UserIcons.getDefaultUserIcon( + mContext.getResources(), UserHandle.USER_NULL, false)); + } + private void registerReceiver() { IntentFilter filter = new IntentFilter(); filter.addAction(Intent.ACTION_USER_REMOVED); @@ -435,8 +452,7 @@ public final class UserManagerHelper { * @return Bitmap that has been assigned to the user. */ private Bitmap assignDefaultIcon(UserInfo userInfo) { - Bitmap bitmap = UserIcons.convertToBitmap( - UserIcons.getDefaultUserIcon(mContext.getResources(), userInfo.id, false)); + Bitmap bitmap = userInfo.isGuest() ? getGuestDefaultIcon() : getUserDefaultIcon(userInfo); mUserManager.setUserIcon(userInfo.id, bitmap); return bitmap; } diff --git a/packages/SettingsLib/tests/integ/src/com/android/settingslib/users/UserManagerHelperTest.java b/packages/SettingsLib/tests/integ/src/com/android/settingslib/users/UserManagerHelperTest.java index 15f77703054d..54510b27e58d 100644 --- a/packages/SettingsLib/tests/integ/src/com/android/settingslib/users/UserManagerHelperTest.java +++ b/packages/SettingsLib/tests/integ/src/com/android/settingslib/users/UserManagerHelperTest.java @@ -247,13 +247,13 @@ public class UserManagerHelperTest { } @Test - public void switchToGuest() { - mHelper.switchToGuest("Test Guest"); + public void startNewGuestSession() { + mHelper.startNewGuestSession("Test Guest"); verify(mUserManager).createGuest(mContext, "Test Guest"); UserInfo guestInfo = new UserInfo(21, "Test Guest", UserInfo.FLAG_GUEST); when(mUserManager.createGuest(mContext, "Test Guest")).thenReturn(guestInfo); - mHelper.switchToGuest("Test Guest"); + mHelper.startNewGuestSession("Test Guest"); verify(mActivityManager).switchUser(21); } diff --git a/packages/SettingsLib/tests/robotests/src/com/android/settingslib/users/UserManagerHelperRoboTest.java b/packages/SettingsLib/tests/robotests/src/com/android/settingslib/users/UserManagerHelperRoboTest.java index f2ea3a4a3d87..890abefddd73 100644 --- a/packages/SettingsLib/tests/robotests/src/com/android/settingslib/users/UserManagerHelperRoboTest.java +++ b/packages/SettingsLib/tests/robotests/src/com/android/settingslib/users/UserManagerHelperRoboTest.java @@ -185,12 +185,7 @@ public class UserManagerHelperRoboTest { mHelper.switchToUser(createUserInfoForId(20)); assertThat(ShadowActivityManager.getShadow().getSwitchUserCalled()).isFalse(); - // Switching to Guest calls createGuest. - UserInfo guestInfo = new UserInfo(21, "Test Guest", UserInfo.FLAG_GUEST); - mHelper.switchToUser(guestInfo); - verify(mUserManager).createGuest(mContext, "Test Guest"); - - // Switching to non-current, non-guest user, simply calls switchUser. + // Switching to non-foreground user, simply calls switchUser. UserInfo userToSwitchTo = new UserInfo(22, "Test User", 0); mHelper.switchToUser(userToSwitchTo); assertThat(ShadowActivityManager.getShadow().getSwitchUserCalled()).isTrue(); diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/car/UserGridRecyclerView.java b/packages/SystemUI/src/com/android/systemui/statusbar/car/UserGridRecyclerView.java index a950cd5f0ca8..a54c778343ab 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/car/UserGridRecyclerView.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/car/UserGridRecyclerView.java @@ -207,7 +207,7 @@ public class UserGridRecyclerView extends PagedListView implements // If the user selects Guest, start the guest session. if (userRecord.mIsStartGuestSession) { - mUserManagerHelper.switchToGuest(mGuestName); + mUserManagerHelper.startNewGuestSession(mGuestName); return; } @@ -241,8 +241,7 @@ public class UserGridRecyclerView extends PagedListView implements private Bitmap getUserRecordIcon(UserRecord userRecord) { if (userRecord.mIsStartGuestSession) { - return UserIcons.convertToBitmap(UserIcons.getDefaultUserIcon( - mContext.getResources(), UserHandle.USER_NULL, false)); + return mUserManagerHelper.getGuestDefaultIcon(); } if (userRecord.mIsAddUser) { diff --git a/services/core/java/com/android/server/am/CarUserSwitchingDialog.java b/services/core/java/com/android/server/am/CarUserSwitchingDialog.java index 676f0c7dd28e..1149e8703a4f 100644 --- a/services/core/java/com/android/server/am/CarUserSwitchingDialog.java +++ b/services/core/java/com/android/server/am/CarUserSwitchingDialog.java @@ -23,6 +23,7 @@ import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Color; import android.graphics.drawable.ColorDrawable; +import android.os.UserManager; import android.view.LayoutInflater; import android.view.View; import android.widget.ImageView; @@ -59,11 +60,14 @@ final class CarUserSwitchingDialog extends UserSwitchingDialog { View view = LayoutInflater.from(getContext()).inflate(R.layout.car_user_switching_dialog, null); - FileDescriptor fileDescriptor = UserManagerService.getInstance() - .getUserIcon(mNewUser.id).getFileDescriptor(); - Bitmap bitmap = BitmapFactory.decodeFileDescriptor(fileDescriptor); - ((ImageView) view.findViewById(R.id.user_loading_avatar)) - .setImageBitmap(bitmap); + UserManager userManager = + (UserManager) getContext().getSystemService(Context.USER_SERVICE); + Bitmap bitmap = userManager.getUserIcon(mNewUser.id); + if (bitmap != null) { + ((ImageView) view.findViewById(R.id.user_loading_avatar)) + .setImageBitmap(bitmap); + } + ((TextView) view.findViewById(R.id.user_loading)) .setText(res.getString(R.string.car_loading_profile)); setView(view); |