Merge "Fix the summary format problem of the installed apps" into sc-v2-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
e65b3dae22
@@ -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));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user