Add summary for role-based default apps preference.

This change adds summary for role-based default apps preference, based
on what we have now for default apps.

Bug: 110557011
Test: atest RolesPreferenceControllerTest
Change-Id: Ic3dd84dc7ca687ea1de63a856ac3fcf679e1bda9
This commit is contained in:
Hai Zhang
2019-01-07 18:30:49 -08:00
parent 2dbdc888c3
commit d07b049de1
2 changed files with 198 additions and 16 deletions

View File

@@ -16,31 +16,44 @@
package com.android.settings.applications.defaultapps; package com.android.settings.applications.defaultapps;
import android.app.role.RoleManager;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.pm.PackageManager; import android.content.pm.PackageManager;
import android.icu.text.ListFormatter;
import android.provider.Settings; import android.provider.Settings;
import android.text.TextUtils; import android.text.TextUtils;
import androidx.preference.Preference; import androidx.preference.Preference;
import com.android.settings.core.BasePreferenceController; import com.android.settings.core.BasePreferenceController;
import com.android.settingslib.applications.AppUtils;
import java.util.ArrayList;
import java.util.List;
/** /**
* STOPSHIP(b/110557011): Remove once the new UI is ready. * STOPSHIP(b/110557011): Remove once the new UI is ready.
*/ */
public class RolesPreferenceController extends BasePreferenceController { public class RolesPreferenceController extends BasePreferenceController {
private Intent mIntent; private final PackageManager mPackageManager;
private final RoleManager mRoleManager;
private final Intent mIntent;
public RolesPreferenceController(Context context, String preferenceKey) { public RolesPreferenceController(Context context, String preferenceKey) {
super(context, preferenceKey); super(context, preferenceKey);
PackageManager packageManager = context.getPackageManager(); mPackageManager = context.getPackageManager();
String packageName = packageManager.getPermissionControllerPackageName(); mRoleManager = context.getSystemService(RoleManager.class);
final String packageName = mPackageManager.getPermissionControllerPackageName();
if (packageName != null) { if (packageName != null) {
mIntent = new Intent(Settings.ACTION_MANAGE_DEFAULT_APPS_SETTINGS) mIntent = new Intent(Settings.ACTION_MANAGE_DEFAULT_APPS_SETTINGS)
.setPackage(packageName); .setPackage(packageName);
} else {
mIntent = null;
} }
} }
@@ -59,4 +72,34 @@ public class RolesPreferenceController extends BasePreferenceController {
} }
return false; return false;
} }
@Override
public CharSequence getSummary() {
final List<CharSequence> defaultAppLabels = new ArrayList<>();
final CharSequence defaultBrowserLabel = getDefaultAppLabel(RoleManager.ROLE_BROWSER);
if(!TextUtils.isEmpty(defaultBrowserLabel)) {
defaultAppLabels.add(defaultBrowserLabel);
}
final CharSequence defaultPhoneLabel = getDefaultAppLabel(RoleManager.ROLE_DIALER);
if(!TextUtils.isEmpty(defaultPhoneLabel)) {
defaultAppLabels.add(defaultPhoneLabel);
}
final CharSequence defaultSmsLabel = getDefaultAppLabel(RoleManager.ROLE_SMS);
if(!TextUtils.isEmpty(defaultSmsLabel)) {
defaultAppLabels.add(defaultSmsLabel);
}
if (defaultAppLabels.isEmpty()) {
return null;
}
return ListFormatter.getInstance().format(defaultAppLabels);
}
private CharSequence getDefaultAppLabel(String roleName) {
final List<String> packageNames = mRoleManager.getRoleHolders(roleName);
if (packageNames.isEmpty()) {
return null;
}
final String packageName = packageNames.get(0);
return AppUtils.getApplicationLabel(mPackageManager, packageName);
}
} }

View File

@@ -19,13 +19,17 @@ package com.android.settings.applications.defaultapps;
import static com.google.common.truth.Truth.assertThat; import static com.google.common.truth.Truth.assertThat;
import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.any;
import static org.mockito.ArgumentMatchers.anyInt;
import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never; import static org.mockito.Mockito.never;
import static org.mockito.Mockito.verify; import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
import android.app.role.RoleManager;
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.PackageManager; import android.content.pm.PackageManager;
import android.provider.Settings; import android.provider.Settings;
@@ -41,32 +45,59 @@ import org.mockito.Mock;
import org.mockito.MockitoAnnotations; import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner; import org.robolectric.RobolectricTestRunner;
import java.util.Collections;
@RunWith(RobolectricTestRunner.class) @RunWith(RobolectricTestRunner.class)
public class RolesPreferenceControllerTest { public class RolesPreferenceControllerTest {
private static final String PREFERENCE_KEY = "roles"; private static final String PREFERENCE_KEY = "roles";
private static final String DIFFERENT_PREFERENCE_KEY = "different"; private static final String DIFFERENT_PREFERENCE_KEY = "different";
private static final String PERMISSION_CONTROLLER_PACKAGE_NAME = private static final String PERMISSION_CONTROLLER_PACKAGE_NAME =
"com.android.permissioncontroller"; "com.android.permissioncontroller";
private static final String BROWSER_PACKAGE_NAME = "com.example.browser1";
private static final String DIALER_PACKAGE_NAME = "com.example.dialer1";
private static final String SMS_PACKAGE_NAME = "com.example.sms1";
@Mock @Mock
private Context mContext; private Context mContext;
@Mock @Mock
private PackageManager mPackageManager; private PackageManager mPackageManager;
@Mock
private RoleManager mRoleManager;
@Mock
private ApplicationInfo mBrowserApplicationInfo;
@Mock
private ApplicationInfo mDialerApplicationInfo;
@Mock
private ApplicationInfo mSmsApplicationInfo;
@Before @Before
public void setUp() { public void setUp() throws PackageManager.NameNotFoundException {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
when(mContext.getPackageManager()).thenReturn(mPackageManager); when(mContext.getPackageManager()).thenReturn(mPackageManager);
when(mContext.getSystemService(RoleManager.class)).thenReturn(mRoleManager);
when(mBrowserApplicationInfo.loadLabel(mPackageManager)).thenReturn("Browser1");
when(mPackageManager.getApplicationInfo(eq(BROWSER_PACKAGE_NAME), anyInt())).thenReturn(
mBrowserApplicationInfo);
when(mDialerApplicationInfo.loadLabel(mPackageManager)).thenReturn("Phone1");
when(mPackageManager.getApplicationInfo(eq(DIALER_PACKAGE_NAME), anyInt())).thenReturn(
mDialerApplicationInfo);
when(mSmsApplicationInfo.loadLabel(mPackageManager)).thenReturn("Sms1");
when(mPackageManager.getApplicationInfo(eq(SMS_PACKAGE_NAME), anyInt())).thenReturn(
mSmsApplicationInfo);
} }
@Test @Test
public void getAvailabilityStatus_noPermissionController_shouldReturnUnsupportedOnDevice() { public void getAvailabilityStatus_noPermissionController_shouldReturnUnsupportedOnDevice() {
when(mPackageManager.getPermissionControllerPackageName()).thenReturn(null); when(mPackageManager.getPermissionControllerPackageName()).thenReturn(null);
RolesPreferenceController controller = new RolesPreferenceController(mContext, RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY); PREFERENCE_KEY);
assertThat(controller.getAvailabilityStatus()) assertThat(preferenceController.getAvailabilityStatus())
.isEqualTo(BasePreferenceController.UNSUPPORTED_ON_DEVICE); .isEqualTo(BasePreferenceController.UNSUPPORTED_ON_DEVICE);
} }
@@ -74,10 +105,10 @@ public class RolesPreferenceControllerTest {
public void getAvailabilityStatus_hasPermissionController_shouldReturnAvailableUnsearchable() { public void getAvailabilityStatus_hasPermissionController_shouldReturnAvailableUnsearchable() {
when(mPackageManager.getPermissionControllerPackageName()) when(mPackageManager.getPermissionControllerPackageName())
.thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME); .thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME);
RolesPreferenceController controller = new RolesPreferenceController(mContext, RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY); PREFERENCE_KEY);
assertThat(controller.getAvailabilityStatus()) assertThat(preferenceController.getAvailabilityStatus())
.isEqualTo(BasePreferenceController.AVAILABLE_UNSEARCHABLE); .isEqualTo(BasePreferenceController.AVAILABLE_UNSEARCHABLE);
} }
@@ -85,34 +116,34 @@ public class RolesPreferenceControllerTest {
public void handlePreferenceTreeClick_differentKey_shouldReturnFalse() { public void handlePreferenceTreeClick_differentKey_shouldReturnFalse() {
when(mPackageManager.getPermissionControllerPackageName()) when(mPackageManager.getPermissionControllerPackageName())
.thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME); .thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME);
RolesPreferenceController controller = new RolesPreferenceController(mContext, RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY); PREFERENCE_KEY);
Preference preference = mock(Preference.class); Preference preference = mock(Preference.class);
when(preference.getKey()).thenReturn(DIFFERENT_PREFERENCE_KEY); when(preference.getKey()).thenReturn(DIFFERENT_PREFERENCE_KEY);
assertThat(controller.handlePreferenceTreeClick(preference)).isFalse(); assertThat(preferenceController.handlePreferenceTreeClick(preference)).isFalse();
} }
@Test @Test
public void handlePreferenceTreeClick_sameKey_shouldReturnTrue() { public void handlePreferenceTreeClick_sameKey_shouldReturnTrue() {
when(mPackageManager.getPermissionControllerPackageName()) when(mPackageManager.getPermissionControllerPackageName())
.thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME); .thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME);
RolesPreferenceController controller = new RolesPreferenceController(mContext, RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY); PREFERENCE_KEY);
Preference preference = mock(Preference.class); Preference preference = mock(Preference.class);
when(preference.getKey()).thenReturn(PREFERENCE_KEY); when(preference.getKey()).thenReturn(PREFERENCE_KEY);
assertThat(controller.handlePreferenceTreeClick(preference)).isTrue(); assertThat(preferenceController.handlePreferenceTreeClick(preference)).isTrue();
} }
@Test @Test
public void handlePreferenceTreeClick_noPermissionController_shouldNotStartActivity() { public void handlePreferenceTreeClick_noPermissionController_shouldNotStartActivity() {
when(mPackageManager.getPermissionControllerPackageName()).thenReturn(null); when(mPackageManager.getPermissionControllerPackageName()).thenReturn(null);
RolesPreferenceController controller = new RolesPreferenceController(mContext, RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY); PREFERENCE_KEY);
Preference preference = mock(Preference.class); Preference preference = mock(Preference.class);
when(preference.getKey()).thenReturn(PREFERENCE_KEY); when(preference.getKey()).thenReturn(PREFERENCE_KEY);
controller.handlePreferenceTreeClick(preference); preferenceController.handlePreferenceTreeClick(preference);
verify(mContext, never()).startActivity(any(Intent.class)); verify(mContext, never()).startActivity(any(Intent.class));
} }
@@ -121,11 +152,11 @@ public class RolesPreferenceControllerTest {
public void handlePreferenceTreeClick_hasPermissionController_shouldStartActivityWithIntent() { public void handlePreferenceTreeClick_hasPermissionController_shouldStartActivityWithIntent() {
when(mPackageManager.getPermissionControllerPackageName()) when(mPackageManager.getPermissionControllerPackageName())
.thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME); .thenReturn(PERMISSION_CONTROLLER_PACKAGE_NAME);
RolesPreferenceController controller = new RolesPreferenceController(mContext, RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY); PREFERENCE_KEY);
Preference preference = mock(Preference.class); Preference preference = mock(Preference.class);
when(preference.getKey()).thenReturn(PREFERENCE_KEY); when(preference.getKey()).thenReturn(PREFERENCE_KEY);
controller.handlePreferenceTreeClick(preference); preferenceController.handlePreferenceTreeClick(preference);
ArgumentCaptor<Intent> intent = ArgumentCaptor.forClass(Intent.class); ArgumentCaptor<Intent> intent = ArgumentCaptor.forClass(Intent.class);
verify(mContext).startActivity(intent.capture()); verify(mContext).startActivity(intent.capture());
@@ -133,4 +164,112 @@ public class RolesPreferenceControllerTest {
.isEqualTo(Settings.ACTION_MANAGE_DEFAULT_APPS_SETTINGS); .isEqualTo(Settings.ACTION_MANAGE_DEFAULT_APPS_SETTINGS);
assertThat(intent.getValue().getPackage()).isEqualTo(PERMISSION_CONTROLLER_PACKAGE_NAME); assertThat(intent.getValue().getPackage()).isEqualTo(PERMISSION_CONTROLLER_PACKAGE_NAME);
} }
@Test
public void getSummary_allAvailable_shouldReturnAll() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.singletonList(BROWSER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.singletonList(DIALER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(
Collections.singletonList(SMS_PACKAGE_NAME));
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Browser1, Phone1, and Sms1");
}
@Test
public void getSummary_browserAndDialerAvailable_shouldReturnBrowserAndDialer() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.singletonList(BROWSER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.singletonList(DIALER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(Collections.emptyList());
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Browser1 and Phone1");
}
@Test
public void getSummary_browserAndSmsAvailable_shouldReturnBrowserAndSms() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.singletonList(BROWSER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(
Collections.singletonList(SMS_PACKAGE_NAME));
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Browser1 and Sms1");
}
@Test
public void getSummary_dialerAndSmsAvailable_shouldReturnDialerAndSms() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.singletonList(DIALER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(
Collections.singletonList(SMS_PACKAGE_NAME));
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Phone1 and Sms1");
}
@Test
public void getSummary_browserAvailable_shouldReturnBrowser() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.singletonList(BROWSER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(Collections.emptyList());
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Browser1");
}
@Test
public void getSummary_dialerAvailable_shouldReturnDialer() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.singletonList(DIALER_PACKAGE_NAME));
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(Collections.emptyList());
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Phone1");
}
@Test
public void getSummary_smsAvailable_shouldReturnSms() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(
Collections.singletonList(SMS_PACKAGE_NAME));
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isEqualTo("Sms1");
}
@Test
public void getSummary_noneAvailable_shouldReturnNull() {
when(mRoleManager.getRoleHolders(RoleManager.ROLE_BROWSER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_DIALER)).thenReturn(
Collections.emptyList());
when(mRoleManager.getRoleHolders(RoleManager.ROLE_SMS)).thenReturn(Collections.emptyList());
RolesPreferenceController preferenceController = new RolesPreferenceController(mContext,
PREFERENCE_KEY);
assertThat(preferenceController.getSummary()).isNull();
}
} }