Limit the number of permissions being displayed.
am: 922064ed69
Change-Id: I55fcc111d5d67e0e67c327894abb7fa9150c5346
This commit is contained in:
@@ -35,6 +35,9 @@ public class AppPermissionsPreferenceController extends BasePreferenceController
|
|||||||
private static final String TAG = "AppPermissionPrefCtrl";
|
private static final String TAG = "AppPermissionPrefCtrl";
|
||||||
private static int NUM_PACKAGE_TO_CHECK = 3;
|
private static int NUM_PACKAGE_TO_CHECK = 3;
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
static int NUM_PERMISSIONS_TO_SHOW = 3;
|
||||||
|
|
||||||
private final PackageManager mPackageManager;
|
private final PackageManager mPackageManager;
|
||||||
private final Set<CharSequence> mPermissionGroups;
|
private final Set<CharSequence> mPermissionGroups;
|
||||||
|
|
||||||
@@ -95,9 +98,13 @@ public class AppPermissionsPreferenceController extends BasePreferenceController
|
|||||||
if (mNumPackageChecked < NUM_PACKAGE_TO_CHECK) {
|
if (mNumPackageChecked < NUM_PACKAGE_TO_CHECK) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final CharSequence summary = !mPermissionGroups.isEmpty()
|
|
||||||
|
final List<CharSequence> permissionsToShow = mPermissionGroups.stream()
|
||||||
|
.limit(NUM_PERMISSIONS_TO_SHOW)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
final CharSequence summary = !permissionsToShow.isEmpty()
|
||||||
? mContext.getString(R.string.app_permissions_summary,
|
? mContext.getString(R.string.app_permissions_summary,
|
||||||
ListFormatter.getInstance().format(mPermissionGroups).toLowerCase())
|
ListFormatter.getInstance().format(permissionsToShow).toLowerCase())
|
||||||
: null;
|
: null;
|
||||||
mPreference.setSummary(summary);
|
mPreference.setSummary(summary);
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package com.android.settings.applications;
|
package com.android.settings.applications;
|
||||||
|
|
||||||
|
import static com.android.settings.applications.AppPermissionsPreferenceController.NUM_PERMISSIONS_TO_SHOW;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.anyString;
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
@@ -32,11 +34,11 @@ import androidx.preference.Preference;
|
|||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class AppPermissionsPreferenceControllerTest {
|
public class AppPermissionsPreferenceControllerTest {
|
||||||
@@ -47,7 +49,6 @@ public class AppPermissionsPreferenceControllerTest {
|
|||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws NameNotFoundException {
|
public void setUp() throws NameNotFoundException {
|
||||||
MockitoAnnotations.initMocks(this);
|
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mPreference = spy(new Preference(mContext));
|
mPreference = spy(new Preference(mContext));
|
||||||
mController = spy(new AppPermissionsPreferenceController(mContext, "pref_key"));
|
mController = spy(new AppPermissionsPreferenceController(mContext, "pref_key"));
|
||||||
@@ -106,4 +107,29 @@ public class AppPermissionsPreferenceControllerTest {
|
|||||||
|
|
||||||
verify(mPreference, never()).setSummary(anyString());
|
verify(mPreference, never()).setSummary(anyString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateSummary_hasFiveItems_shouldShowCertainNumItems() {
|
||||||
|
doNothing().when(mController).queryPermissionSummary();
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
mController.mNumPackageChecked = 2;
|
||||||
|
|
||||||
|
mController.updateSummary(getPermissionGroupsSet());
|
||||||
|
|
||||||
|
final CharSequence summary = mPreference.getSummary();
|
||||||
|
final int items = summary.toString().split(",").length;
|
||||||
|
assertThat(items).isEqualTo(NUM_PERMISSIONS_TO_SHOW);
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<CharSequence> getPermissionGroupsSet() {
|
||||||
|
final List<CharSequence> labels = new ArrayList<>();
|
||||||
|
labels.add("Phone");
|
||||||
|
labels.add("SMS");
|
||||||
|
labels.add("Microphone");
|
||||||
|
labels.add("Contacts");
|
||||||
|
labels.add("Camera");
|
||||||
|
labels.add("Location");
|
||||||
|
|
||||||
|
return labels;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user