Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 922064ed authored by Yi-Ling Chuang's avatar Yi-Ling Chuang
Browse files

Limit the number of permissions being displayed.

To avoid a long permission summary, let's limit the number to three.

Fixes: 117978938
Test: robotests
Change-Id: Id83fac7ad91140b22757d3e6e8eb72d86ad6ad42
parent 1dfc4387
Loading
Loading
Loading
Loading
+9 −2
Original line number Diff line number Diff line
@@ -35,6 +35,9 @@ public class AppPermissionsPreferenceController extends BasePreferenceController
    private static final String TAG = "AppPermissionPrefCtrl";
    private static int NUM_PACKAGE_TO_CHECK = 3;

    @VisibleForTesting
    static int NUM_PERMISSIONS_TO_SHOW = 3;

    private final PackageManager mPackageManager;
    private final Set<CharSequence> mPermissionGroups;

@@ -95,9 +98,13 @@ public class AppPermissionsPreferenceController extends BasePreferenceController
        if (mNumPackageChecked < NUM_PACKAGE_TO_CHECK) {
            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,
                ListFormatter.getInstance().format(mPermissionGroups).toLowerCase())
                ListFormatter.getInstance().format(permissionsToShow).toLowerCase())
                : null;
        mPreference.setSummary(summary);
    }
+28 −2
Original line number Diff line number Diff line
@@ -16,6 +16,8 @@

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 org.mockito.ArgumentMatchers.anyString;
@@ -32,11 +34,11 @@ import androidx.preference.Preference;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;

import java.util.ArrayList;
import java.util.List;

@RunWith(RobolectricTestRunner.class)
public class AppPermissionsPreferenceControllerTest {
@@ -47,7 +49,6 @@ public class AppPermissionsPreferenceControllerTest {

    @Before
    public void setUp() throws NameNotFoundException {
        MockitoAnnotations.initMocks(this);
        mContext = RuntimeEnvironment.application;
        mPreference = spy(new Preference(mContext));
        mController = spy(new AppPermissionsPreferenceController(mContext, "pref_key"));
@@ -106,4 +107,29 @@ public class AppPermissionsPreferenceControllerTest {

        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;
    }
}