Merge "Fix the summary format problem of the installed apps" into sc-v2-dev am: e65b3dae22

Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/15939313

Change-Id: I0c0cdfb10b68a9776dd6a5f2db6157baecd76d09
This commit is contained in:
TreeHugger Robot
2021-09-29 13:19:18 +00:00
committed by Automerger Merge Worker
2 changed files with 41 additions and 25 deletions

View File

@@ -17,27 +17,26 @@
package com.android.settings.applications.managedomainurls; package com.android.settings.applications.managedomainurls;
import android.content.Context; import android.content.Context;
import android.content.pm.PackageManager; import android.content.pm.verify.domain.DomainVerificationManager;
import android.os.UserHandle; import android.content.pm.verify.domain.DomainVerificationUserState;
import android.util.ArraySet;
import android.util.IconDrawableFactory; import android.util.IconDrawableFactory;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.Utils; import com.android.settings.applications.intentpicker.IntentPickerUtils;
import com.android.settingslib.applications.ApplicationsState.AppEntry; import com.android.settingslib.applications.ApplicationsState.AppEntry;
import com.android.settingslib.widget.AppPreference; import com.android.settingslib.widget.AppPreference;
public class DomainAppPreference extends AppPreference { public class DomainAppPreference extends AppPreference {
private final AppEntry mEntry; private final AppEntry mEntry;
private final PackageManager mPm; private final DomainVerificationManager mDomainVerificationManager;
private final IconDrawableFactory mIconDrawableFactory; private final IconDrawableFactory mIconDrawableFactory;
public DomainAppPreference(final Context context, IconDrawableFactory iconFactory, public DomainAppPreference(final Context context, IconDrawableFactory iconFactory,
AppEntry entry) { AppEntry entry) {
super(context); super(context);
mIconDrawableFactory = iconFactory; mIconDrawableFactory = iconFactory;
mPm = context.getPackageManager(); mDomainVerificationManager = context.getSystemService(DomainVerificationManager.class);
mEntry = entry; mEntry = entry;
mEntry.ensureLabel(getContext()); mEntry.ensureLabel(getContext());
@@ -60,22 +59,14 @@ public class DomainAppPreference extends AppPreference {
} }
private CharSequence getDomainsSummary(String packageName) { private CharSequence getDomainsSummary(String packageName) {
// If the user has explicitly said "no" for this package, that's the return getContext().getText(isLinkHandlingAllowed(packageName)
// string we should show. ? R.string.app_link_open_always : R.string.app_link_open_never);
int domainStatus = }
mPm.getIntentVerificationStatusAsUser(packageName, UserHandle.myUserId());
if (domainStatus == PackageManager.INTENT_FILTER_DOMAIN_VERIFICATION_STATUS_NEVER) { private boolean isLinkHandlingAllowed(String packageName) {
return getContext().getText(R.string.domain_urls_summary_none); final DomainVerificationUserState userState =
} IntentPickerUtils.getDomainVerificationUserState(mDomainVerificationManager,
// Otherwise, ask package manager for the domains for this package, packageName);
// and show the first one (or none if there aren't any). return userState == null ? false : userState.isLinkHandlingAllowed();
final ArraySet<String> result = Utils.getHandledDomains(mPm, packageName);
if (result.isEmpty()) {
return getContext().getText(R.string.domain_urls_summary_none);
} else if (result.size() == 1) {
return getContext().getString(R.string.domain_urls_summary_one, result.valueAt(0));
} else {
return getContext().getString(R.string.domain_urls_summary_some, result.valueAt(0));
}
} }
} }

View File

@@ -18,8 +18,17 @@ package com.android.settings.applications.managedomainurls;
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.Mockito.doReturn;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;
import android.content.Context; import android.content.Context;
import android.content.pm.ApplicationInfo; import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
import android.content.pm.verify.domain.DomainVerificationManager;
import android.content.pm.verify.domain.DomainVerificationUserState;
import android.util.IconDrawableFactory; import android.util.IconDrawableFactory;
import com.android.settings.R; import com.android.settings.R;
@@ -28,6 +37,8 @@ import com.android.settingslib.applications.ApplicationsState;
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.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner; import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment; import org.robolectric.RuntimeEnvironment;
@@ -40,16 +51,30 @@ public class DomainAppPreferenceControllerTest {
private Context mContext; private Context mContext;
private IconDrawableFactory mIconDrawableFactory; private IconDrawableFactory mIconDrawableFactory;
@Mock
private DomainVerificationManager mDomainVerificationManager;
@Mock
private DomainVerificationUserState mDomainVerificationUserState;
@Before @Before
public void setUp() { public void setUp() {
mContext = RuntimeEnvironment.application; MockitoAnnotations.initMocks(this);
mContext = spy(RuntimeEnvironment.application);
mIconDrawableFactory = IconDrawableFactory.newInstance(mContext); mIconDrawableFactory = IconDrawableFactory.newInstance(mContext);
mAppEntry = new ApplicationsState.AppEntry( mAppEntry = new ApplicationsState.AppEntry(
mContext, createApplicationInfo(mContext.getPackageName()), 0); mContext, createApplicationInfo(mContext.getPackageName()), 0);
when(mContext.getSystemService(DomainVerificationManager.class)).thenReturn(
mDomainVerificationManager);
} }
@Test @Test
public void getLayoutResource_shouldUseAppPreferenceLayout() { public void getLayoutResource_shouldUseAppPreferenceLayout()
throws PackageManager.NameNotFoundException {
final DomainVerificationUserState domainVerificationUserState = mock(
DomainVerificationUserState.class);
doReturn(domainVerificationUserState).when(
mDomainVerificationManager).getDomainVerificationUserState(anyString());
doReturn(true).when(domainVerificationUserState).isLinkHandlingAllowed();
final DomainAppPreference pref = new DomainAppPreference( final DomainAppPreference pref = new DomainAppPreference(
mContext, mIconDrawableFactory, mAppEntry); mContext, mIconDrawableFactory, mAppEntry);