Fix user id is not used correctly when fetching app info
FIXES: 73994288 Test: m -j RunSettingsRoboTest Test: Install an app in work profile, set it to be restricted, observe that the app is rendered properly in restricted app list Change-Id: Ic8a79eb3d0a675f9d1cae3125e8006739e492966
This commit is contained in:
@@ -976,8 +976,8 @@ public final class Utils extends com.android.settingslib.Utils {
|
|||||||
public static Drawable getBadgedIcon(IconDrawableFactory iconDrawableFactory,
|
public static Drawable getBadgedIcon(IconDrawableFactory iconDrawableFactory,
|
||||||
PackageManager packageManager, String packageName, int userId) {
|
PackageManager packageManager, String packageName, int userId) {
|
||||||
try {
|
try {
|
||||||
final ApplicationInfo appInfo = packageManager.getApplicationInfo(packageName,
|
final ApplicationInfo appInfo = packageManager.getApplicationInfoAsUser(
|
||||||
PackageManager.GET_META_DATA);
|
packageName, PackageManager.GET_META_DATA, userId);
|
||||||
return iconDrawableFactory.getBadgedIcon(appInfo, userId);
|
return iconDrawableFactory.getBadgedIcon(appInfo, userId);
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
return packageManager.getDefaultActivityIcon();
|
return packageManager.getDefaultActivityIcon();
|
||||||
|
@@ -131,8 +131,8 @@ public class RestrictedAppDetails extends DashboardFragment {
|
|||||||
final CheckBoxPreference checkBoxPreference = new AppCheckBoxPreference(context);
|
final CheckBoxPreference checkBoxPreference = new AppCheckBoxPreference(context);
|
||||||
final AppInfo appInfo = mAppInfos.get(i);
|
final AppInfo appInfo = mAppInfos.get(i);
|
||||||
try {
|
try {
|
||||||
final ApplicationInfo applicationInfo = mPackageManager.getApplicationInfo(
|
final ApplicationInfo applicationInfo = mPackageManager.getApplicationInfoAsUser(
|
||||||
appInfo.packageName, 0 /* flags */);
|
appInfo.packageName, 0 /* flags */, UserHandle.getUserId(appInfo.uid));
|
||||||
checkBoxPreference.setChecked(true);
|
checkBoxPreference.setChecked(true);
|
||||||
checkBoxPreference.setTitle(mPackageManager.getApplicationLabel(applicationInfo));
|
checkBoxPreference.setTitle(mPackageManager.getApplicationLabel(applicationInfo));
|
||||||
checkBoxPreference.setIcon(
|
checkBoxPreference.setIcon(
|
||||||
|
@@ -17,6 +17,9 @@
|
|||||||
package com.android.settings;
|
package com.android.settings;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
import static org.mockito.Matchers.anyString;
|
import static org.mockito.Matchers.anyString;
|
||||||
import static org.mockito.Mockito.RETURNS_DEEP_STUBS;
|
import static org.mockito.Mockito.RETURNS_DEEP_STUBS;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
@@ -188,12 +191,13 @@ public class UtilsTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testGetBadgedIcon_usePackageNameAndUserId()
|
public void testGetBadgedIcon_usePackageNameAndUserId()
|
||||||
throws PackageManager.NameNotFoundException {
|
throws PackageManager.NameNotFoundException {
|
||||||
doReturn(mApplicationInfo).when(mPackageManager).getApplicationInfo(PACKAGE_NAME,
|
doReturn(mApplicationInfo).when(mPackageManager).getApplicationInfoAsUser(
|
||||||
PackageManager.GET_META_DATA);
|
PACKAGE_NAME, PackageManager.GET_META_DATA, USER_ID);
|
||||||
|
|
||||||
Utils.getBadgedIcon(mIconDrawableFactory, mPackageManager, PACKAGE_NAME, USER_ID);
|
Utils.getBadgedIcon(mIconDrawableFactory, mPackageManager, PACKAGE_NAME, USER_ID);
|
||||||
|
|
||||||
// Verify that it uses the correct user id
|
// Verify that it uses the correct user id
|
||||||
|
verify(mPackageManager).getApplicationInfoAsUser(eq(PACKAGE_NAME), anyInt(), eq(USER_ID));
|
||||||
verify(mIconDrawableFactory).getBadgedIcon(mApplicationInfo, USER_ID);
|
verify(mIconDrawableFactory).getBadgedIcon(mApplicationInfo, USER_ID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -21,13 +21,13 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
import static org.mockito.Mockito.doAnswer;
|
import static org.mockito.Mockito.doAnswer;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.os.UserHandle;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
import android.support.v7.preference.PreferenceCategory;
|
import android.support.v7.preference.PreferenceCategory;
|
||||||
import android.support.v7.preference.PreferenceManager;
|
import android.support.v7.preference.PreferenceManager;
|
||||||
@@ -54,7 +54,8 @@ import java.util.List;
|
|||||||
public class RestrictedAppDetailsTest {
|
public class RestrictedAppDetailsTest {
|
||||||
|
|
||||||
private static final String PACKAGE_NAME = "com.android.app";
|
private static final String PACKAGE_NAME = "com.android.app";
|
||||||
private static final int UID = 234;
|
private static final int USER_ID = 10;
|
||||||
|
private static final int UID = UserHandle.getUid(USER_ID, 234);
|
||||||
private static final String APP_NAME = "app";
|
private static final String APP_NAME = "app";
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
@@ -99,7 +100,8 @@ public class RestrictedAppDetailsTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testRefreshUi_displayPreference() throws Exception {
|
public void testRefreshUi_displayPreference() throws Exception {
|
||||||
doReturn(mApplicationInfo).when(mPackageManager).getApplicationInfo(PACKAGE_NAME, 0);
|
doReturn(mApplicationInfo).when(mPackageManager)
|
||||||
|
.getApplicationInfoAsUser(PACKAGE_NAME, 0, USER_ID);
|
||||||
doReturn(APP_NAME).when(mPackageManager).getApplicationLabel(mApplicationInfo);
|
doReturn(APP_NAME).when(mPackageManager).getApplicationLabel(mApplicationInfo);
|
||||||
|
|
||||||
mRestrictedAppDetails.refreshUi();
|
mRestrictedAppDetails.refreshUi();
|
||||||
|
Reference in New Issue
Block a user