Merge "Use IconDrawableFactory to load icons for default apps."
This commit is contained in:
committed by
Android (Google) Code Review
commit
5317e70be1
@@ -23,6 +23,7 @@ import android.app.Dialog;
|
|||||||
import android.app.DialogFragment;
|
import android.app.DialogFragment;
|
||||||
import android.app.Fragment;
|
import android.app.Fragment;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.os.Binder;
|
import android.os.Binder;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@@ -54,7 +55,8 @@ public class ShortcutServicePickerFragment extends DefaultAppPickerFragment {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<? extends DefaultAppInfo> getCandidates() {
|
protected List<? extends DefaultAppInfo> getCandidates() {
|
||||||
final AccessibilityManager accessibilityManager = getContext()
|
final Context context = getContext();
|
||||||
|
final AccessibilityManager accessibilityManager = context
|
||||||
.getSystemService(AccessibilityManager.class);
|
.getSystemService(AccessibilityManager.class);
|
||||||
final List<AccessibilityServiceInfo> installedServices =
|
final List<AccessibilityServiceInfo> installedServices =
|
||||||
accessibilityManager.getInstalledAccessibilityServiceList();
|
accessibilityManager.getInstalledAccessibilityServiceList();
|
||||||
@@ -63,7 +65,7 @@ public class ShortcutServicePickerFragment extends DefaultAppPickerFragment {
|
|||||||
List<DefaultAppInfo> candidates = new ArrayList<>(numInstalledServices);
|
List<DefaultAppInfo> candidates = new ArrayList<>(numInstalledServices);
|
||||||
for (int i = 0; i < numInstalledServices; i++) {
|
for (int i = 0; i < numInstalledServices; i++) {
|
||||||
AccessibilityServiceInfo installedServiceInfo = installedServices.get(i);
|
AccessibilityServiceInfo installedServiceInfo = installedServices.get(i);
|
||||||
candidates.add(new DefaultAppInfo(mPm,
|
candidates.add(new DefaultAppInfo(context, mPm,
|
||||||
UserHandle.myUserId(),
|
UserHandle.myUserId(),
|
||||||
installedServiceInfo.getComponentName(),
|
installedServiceInfo.getComponentName(),
|
||||||
(String) installedServiceInfo.loadSummary(mPm.getPackageManager()),
|
(String) installedServiceInfo.loadSummary(mPm.getPackageManager()),
|
||||||
|
@@ -79,7 +79,7 @@ public class DefaultAssistPicker extends DefaultAppPickerFragment {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
packages.add(packageName);
|
packages.add(packageName);
|
||||||
candidates.add(new DefaultAppInfo(mPm, mUserId, info.component));
|
candidates.add(new DefaultAppInfo(getContext(), mPm, mUserId, info.component));
|
||||||
}
|
}
|
||||||
return candidates;
|
return candidates;
|
||||||
}
|
}
|
||||||
@@ -88,7 +88,7 @@ public class DefaultAssistPicker extends DefaultAppPickerFragment {
|
|||||||
protected String getDefaultKey() {
|
protected String getDefaultKey() {
|
||||||
final ComponentName cn = getCurrentAssist();
|
final ComponentName cn = getCurrentAssist();
|
||||||
if (cn != null) {
|
if (cn != null) {
|
||||||
return new DefaultAppInfo(mPm, mUserId, cn).getKey();
|
return new DefaultAppInfo(getContext(), mPm, mUserId, cn).getKey();
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@@ -87,7 +87,7 @@ public class DefaultAssistPreferenceController extends DefaultAppPreferenceContr
|
|||||||
if (cn == null) {
|
if (cn == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return new DefaultAppInfo(mPackageManager, mUserId, cn);
|
return new DefaultAppInfo(mContext, mPackageManager, mUserId, cn);
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
|
@@ -57,17 +57,18 @@ public class DefaultVoiceInputPicker extends DefaultAppPickerFragment {
|
|||||||
@Override
|
@Override
|
||||||
protected List<VoiceInputDefaultAppInfo> getCandidates() {
|
protected List<VoiceInputDefaultAppInfo> getCandidates() {
|
||||||
final List<VoiceInputDefaultAppInfo> candidates = new ArrayList<>();
|
final List<VoiceInputDefaultAppInfo> candidates = new ArrayList<>();
|
||||||
|
final Context context = getContext();
|
||||||
boolean hasEnabled = true;
|
boolean hasEnabled = true;
|
||||||
for (VoiceInputHelper.InteractionInfo info : mHelper.mAvailableInteractionInfos) {
|
for (VoiceInputHelper.InteractionInfo info : mHelper.mAvailableInteractionInfos) {
|
||||||
final boolean enabled = TextUtils.equals(info.key, mAssistRestrict);
|
final boolean enabled = TextUtils.equals(info.key, mAssistRestrict);
|
||||||
hasEnabled |= enabled;
|
hasEnabled |= enabled;
|
||||||
candidates.add(new VoiceInputDefaultAppInfo(mPm, mUserId, info, enabled));
|
candidates.add(new VoiceInputDefaultAppInfo(context, mPm, mUserId, info, enabled));
|
||||||
}
|
}
|
||||||
|
|
||||||
final boolean assistIsService = !hasEnabled;
|
final boolean assistIsService = !hasEnabled;
|
||||||
for (VoiceInputHelper.RecognizerInfo info : mHelper.mAvailableRecognizerInfos) {
|
for (VoiceInputHelper.RecognizerInfo info : mHelper.mAvailableRecognizerInfos) {
|
||||||
final boolean enabled = !assistIsService;
|
final boolean enabled = !assistIsService;
|
||||||
candidates.add(new VoiceInputDefaultAppInfo(mPm, mUserId, info, enabled));
|
candidates.add(new VoiceInputDefaultAppInfo(context, mPm, mUserId, info, enabled));
|
||||||
}
|
}
|
||||||
return candidates;
|
return candidates;
|
||||||
}
|
}
|
||||||
@@ -132,9 +133,9 @@ public class DefaultVoiceInputPicker extends DefaultAppPickerFragment {
|
|||||||
|
|
||||||
public VoiceInputHelper.BaseInfo mInfo;
|
public VoiceInputHelper.BaseInfo mInfo;
|
||||||
|
|
||||||
public VoiceInputDefaultAppInfo(PackageManagerWrapper pm, int userId,
|
public VoiceInputDefaultAppInfo(Context context, PackageManagerWrapper pm, int userId,
|
||||||
VoiceInputHelper.BaseInfo info, boolean enabled) {
|
VoiceInputHelper.BaseInfo info, boolean enabled) {
|
||||||
super(pm, userId, info.componentName, null /* summary */, enabled);
|
super(context, pm, userId, info.componentName, null /* summary */, enabled);
|
||||||
mInfo = info;
|
mInfo = info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -104,15 +104,15 @@ public class DefaultVoiceInputPreferenceController extends DefaultAppPreferenceC
|
|||||||
}
|
}
|
||||||
for (VoiceInputHelper.InteractionInfo info : mHelper.mAvailableInteractionInfos) {
|
for (VoiceInputHelper.InteractionInfo info : mHelper.mAvailableInteractionInfos) {
|
||||||
if (TextUtils.equals(defaultKey, info.key)) {
|
if (TextUtils.equals(defaultKey, info.key)) {
|
||||||
return new DefaultVoiceInputPicker.VoiceInputDefaultAppInfo(mPackageManager,
|
return new DefaultVoiceInputPicker.VoiceInputDefaultAppInfo(mContext,
|
||||||
mUserId, info, true /* enabled */);
|
mPackageManager, mUserId, info, true /* enabled */);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (VoiceInputHelper.RecognizerInfo info : mHelper.mAvailableRecognizerInfos) {
|
for (VoiceInputHelper.RecognizerInfo info : mHelper.mAvailableRecognizerInfos) {
|
||||||
if (TextUtils.equals(defaultKey, info.key)) {
|
if (TextUtils.equals(defaultKey, info.key)) {
|
||||||
return new DefaultVoiceInputPicker.VoiceInputDefaultAppInfo(mPackageManager,
|
return new DefaultVoiceInputPicker.VoiceInputDefaultAppInfo(mContext,
|
||||||
mUserId, info, true /* enabled */);
|
mPackageManager, mUserId, info, true /* enabled */);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
@@ -18,6 +18,7 @@ package com.android.settings.applications.defaultapps;
|
|||||||
|
|
||||||
import android.app.AppGlobals;
|
import android.app.AppGlobals;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.ComponentInfo;
|
import android.content.pm.ComponentInfo;
|
||||||
import android.content.pm.PackageItemInfo;
|
import android.content.pm.PackageItemInfo;
|
||||||
@@ -25,6 +26,7 @@ import android.content.pm.PackageManager;
|
|||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.RemoteException;
|
import android.os.RemoteException;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
|
import android.util.IconDrawableFactory;
|
||||||
|
|
||||||
import com.android.settings.widget.RadioButtonPickerFragment;
|
import com.android.settings.widget.RadioButtonPickerFragment;
|
||||||
import com.android.settingslib.wrapper.PackageManagerWrapper;
|
import com.android.settingslib.wrapper.PackageManagerWrapper;
|
||||||
@@ -39,18 +41,20 @@ public class DefaultAppInfo extends RadioButtonPickerFragment.CandidateInfo {
|
|||||||
public final PackageItemInfo packageItemInfo;
|
public final PackageItemInfo packageItemInfo;
|
||||||
public final String summary;
|
public final String summary;
|
||||||
protected final PackageManagerWrapper mPm;
|
protected final PackageManagerWrapper mPm;
|
||||||
|
private final Context mContext;
|
||||||
|
|
||||||
public DefaultAppInfo(PackageManagerWrapper pm, int uid, ComponentName cn) {
|
public DefaultAppInfo(Context context, PackageManagerWrapper pm, int uid, ComponentName cn) {
|
||||||
this(pm, uid, cn, null /* summary */);
|
this(context, pm, uid, cn, null /* summary */, true /* enabled */);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DefaultAppInfo(PackageManagerWrapper pm, int uid, ComponentName cn, String summary) {
|
public DefaultAppInfo(Context context, PackageManagerWrapper pm, PackageItemInfo info) {
|
||||||
this(pm, uid, cn, summary, true /* enabled */);
|
this(context, pm, info, null /* summary */, true /* enabled */);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DefaultAppInfo(PackageManagerWrapper pm, int uid, ComponentName cn, String summary,
|
public DefaultAppInfo(Context context, PackageManagerWrapper pm, int uid, ComponentName cn,
|
||||||
boolean enabled) {
|
String summary, boolean enabled) {
|
||||||
super(enabled);
|
super(enabled);
|
||||||
|
mContext = context;
|
||||||
mPm = pm;
|
mPm = pm;
|
||||||
packageItemInfo = null;
|
packageItemInfo = null;
|
||||||
userId = uid;
|
userId = uid;
|
||||||
@@ -58,9 +62,10 @@ public class DefaultAppInfo extends RadioButtonPickerFragment.CandidateInfo {
|
|||||||
this.summary = summary;
|
this.summary = summary;
|
||||||
}
|
}
|
||||||
|
|
||||||
public DefaultAppInfo(PackageManagerWrapper pm, PackageItemInfo info, String summary,
|
public DefaultAppInfo(Context context, PackageManagerWrapper pm, PackageItemInfo info,
|
||||||
boolean enabled) {
|
String summary, boolean enabled) {
|
||||||
super(enabled);
|
super(enabled);
|
||||||
|
mContext = context;
|
||||||
mPm = pm;
|
mPm = pm;
|
||||||
userId = UserHandle.myUserId();
|
userId = UserHandle.myUserId();
|
||||||
packageItemInfo = info;
|
packageItemInfo = info;
|
||||||
@@ -68,10 +73,6 @@ public class DefaultAppInfo extends RadioButtonPickerFragment.CandidateInfo {
|
|||||||
this.summary = summary;
|
this.summary = summary;
|
||||||
}
|
}
|
||||||
|
|
||||||
public DefaultAppInfo(PackageManagerWrapper pm, PackageItemInfo info) {
|
|
||||||
this(pm, info, null /* summary */, true /* enabled */);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence loadLabel() {
|
public CharSequence loadLabel() {
|
||||||
if (componentName != null) {
|
if (componentName != null) {
|
||||||
@@ -97,22 +98,29 @@ public class DefaultAppInfo extends RadioButtonPickerFragment.CandidateInfo {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Drawable loadIcon() {
|
public Drawable loadIcon() {
|
||||||
|
final IconDrawableFactory factory = IconDrawableFactory.newInstance(mContext);
|
||||||
if (componentName != null) {
|
if (componentName != null) {
|
||||||
try {
|
try {
|
||||||
final ComponentInfo componentInfo = getComponentInfo();
|
final ComponentInfo componentInfo = getComponentInfo();
|
||||||
if (componentInfo != null) {
|
|
||||||
return componentInfo.loadIcon(mPm.getPackageManager());
|
|
||||||
} else {
|
|
||||||
final ApplicationInfo appInfo = mPm.getApplicationInfoAsUser(
|
final ApplicationInfo appInfo = mPm.getApplicationInfoAsUser(
|
||||||
componentName.getPackageName(), 0, userId);
|
componentName.getPackageName(), 0, userId);
|
||||||
return appInfo.loadIcon(mPm.getPackageManager());
|
if (componentInfo != null) {
|
||||||
|
return factory.getBadgedIcon(componentInfo, appInfo, userId);
|
||||||
|
} else {
|
||||||
|
return factory.getBadgedIcon(appInfo);
|
||||||
}
|
}
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (packageItemInfo != null) {
|
if (packageItemInfo != null) {
|
||||||
return packageItemInfo.loadIcon(mPm.getPackageManager());
|
try {
|
||||||
|
final ApplicationInfo appInfo = mPm.getApplicationInfoAsUser(
|
||||||
|
packageItemInfo.packageName, 0, userId);
|
||||||
|
return factory.getBadgedIcon(packageItemInfo, appInfo, userId);
|
||||||
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@@ -187,10 +187,11 @@ public class DefaultAutofillPicker extends DefaultAppPickerFragment {
|
|||||||
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
||||||
final List<ResolveInfo> resolveInfos = mPm.getPackageManager()
|
final List<ResolveInfo> resolveInfos = mPm.getPackageManager()
|
||||||
.queryIntentServices(AUTOFILL_PROBE, PackageManager.GET_META_DATA);
|
.queryIntentServices(AUTOFILL_PROBE, PackageManager.GET_META_DATA);
|
||||||
|
final Context context = getContext();
|
||||||
for (ResolveInfo info : resolveInfos) {
|
for (ResolveInfo info : resolveInfos) {
|
||||||
final String permission = info.serviceInfo.permission;
|
final String permission = info.serviceInfo.permission;
|
||||||
if (Manifest.permission.BIND_AUTOFILL_SERVICE.equals(permission)) {
|
if (Manifest.permission.BIND_AUTOFILL_SERVICE.equals(permission)) {
|
||||||
candidates.add(new DefaultAppInfo(mPm, mUserId, new ComponentName(
|
candidates.add(new DefaultAppInfo(context, mPm, mUserId, new ComponentName(
|
||||||
info.serviceInfo.packageName, info.serviceInfo.name)));
|
info.serviceInfo.packageName, info.serviceInfo.name)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -62,7 +62,7 @@ public class DefaultAutofillPreferenceController extends DefaultAppPreferenceCon
|
|||||||
final String flattenComponent = Settings.Secure.getString(mContext.getContentResolver(),
|
final String flattenComponent = Settings.Secure.getString(mContext.getContentResolver(),
|
||||||
DefaultAutofillPicker.SETTING);
|
DefaultAutofillPicker.SETTING);
|
||||||
if (!TextUtils.isEmpty(flattenComponent)) {
|
if (!TextUtils.isEmpty(flattenComponent)) {
|
||||||
DefaultAppInfo appInfo = new DefaultAppInfo(mPackageManager,
|
DefaultAppInfo appInfo = new DefaultAppInfo(mContext, mPackageManager,
|
||||||
mUserId, ComponentName.unflattenFromString(flattenComponent));
|
mUserId, ComponentName.unflattenFromString(flattenComponent));
|
||||||
return appInfo;
|
return appInfo;
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.applications.defaultapps;
|
package com.android.settings.applications.defaultapps;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
|
|
||||||
@@ -47,7 +48,7 @@ public class DefaultBrowserPicker extends DefaultAppPickerFragment {
|
|||||||
@Override
|
@Override
|
||||||
protected List<DefaultAppInfo> getCandidates() {
|
protected List<DefaultAppInfo> getCandidates() {
|
||||||
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
||||||
|
final Context context = getContext();
|
||||||
// Resolve that intent and check that the handleAllWebDataURI boolean is set
|
// Resolve that intent and check that the handleAllWebDataURI boolean is set
|
||||||
final List<ResolveInfo> list = mPm.queryIntentActivitiesAsUser(
|
final List<ResolveInfo> list = mPm.queryIntentActivitiesAsUser(
|
||||||
DefaultBrowserPreferenceController.BROWSE_PROBE, PackageManager.MATCH_ALL, mUserId);
|
DefaultBrowserPreferenceController.BROWSE_PROBE, PackageManager.MATCH_ALL, mUserId);
|
||||||
@@ -59,7 +60,7 @@ public class DefaultBrowserPicker extends DefaultAppPickerFragment {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
candidates.add(new DefaultAppInfo(mPm,
|
candidates.add(new DefaultAppInfo(context, mPm,
|
||||||
mPm.getApplicationInfoAsUser(info.activityInfo.packageName, 0, mUserId)));
|
mPm.getApplicationInfoAsUser(info.activityInfo.packageName, 0, mUserId)));
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
// Skip unknown packages.
|
// Skip unknown packages.
|
||||||
|
@@ -67,7 +67,7 @@ public class DefaultBrowserPreferenceController extends DefaultAppPreferenceCont
|
|||||||
try {
|
try {
|
||||||
final String packageName = mPackageManager.getDefaultBrowserPackageNameAsUser(mUserId);
|
final String packageName = mPackageManager.getDefaultBrowserPackageNameAsUser(mUserId);
|
||||||
Log.d(TAG, "Get default browser package: " + packageName);
|
Log.d(TAG, "Get default browser package: " + packageName);
|
||||||
return new DefaultAppInfo(mPackageManager,
|
return new DefaultAppInfo(mContext, mPackageManager,
|
||||||
mPackageManager.getPackageManager().getApplicationInfo(packageName, 0));
|
mPackageManager.getPackageManager().getApplicationInfo(packageName, 0));
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
return null;
|
return null;
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
package com.android.settings.applications.defaultapps;
|
package com.android.settings.applications.defaultapps;
|
||||||
|
|
||||||
import android.content.ContentResolver;
|
import android.content.ContentResolver;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
@@ -44,12 +45,13 @@ public class DefaultEmergencyPicker extends DefaultAppPickerFragment {
|
|||||||
final List<ResolveInfo> infos = mPm.getPackageManager().queryIntentActivities(
|
final List<ResolveInfo> infos = mPm.getPackageManager().queryIntentActivities(
|
||||||
DefaultEmergencyPreferenceController.QUERY_INTENT, 0);
|
DefaultEmergencyPreferenceController.QUERY_INTENT, 0);
|
||||||
PackageInfo bestMatch = null;
|
PackageInfo bestMatch = null;
|
||||||
|
final Context context = getContext();
|
||||||
for (ResolveInfo info : infos) {
|
for (ResolveInfo info : infos) {
|
||||||
try {
|
try {
|
||||||
final PackageInfo packageInfo =
|
final PackageInfo packageInfo =
|
||||||
mPm.getPackageManager().getPackageInfo(info.activityInfo.packageName, 0);
|
mPm.getPackageManager().getPackageInfo(info.activityInfo.packageName, 0);
|
||||||
final ApplicationInfo appInfo = packageInfo.applicationInfo;
|
final ApplicationInfo appInfo = packageInfo.applicationInfo;
|
||||||
candidates.add(new DefaultAppInfo(mPm, appInfo));
|
candidates.add(new DefaultAppInfo(context, mPm, appInfo));
|
||||||
// Get earliest installed system app.
|
// Get earliest installed system app.
|
||||||
if (isSystemApp(appInfo) && (bestMatch == null ||
|
if (isSystemApp(appInfo) && (bestMatch == null ||
|
||||||
bestMatch.firstInstallTime > packageInfo.firstInstallTime)) {
|
bestMatch.firstInstallTime > packageInfo.firstInstallTime)) {
|
||||||
|
@@ -53,6 +53,7 @@ public class DefaultHomePicker extends DefaultAppPickerFragment {
|
|||||||
final boolean mustSupportManagedProfile = hasManagedProfile();
|
final boolean mustSupportManagedProfile = hasManagedProfile();
|
||||||
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
||||||
final List<ResolveInfo> homeActivities = new ArrayList<>();
|
final List<ResolveInfo> homeActivities = new ArrayList<>();
|
||||||
|
final Context context = getContext();
|
||||||
mPm.getHomeActivities(homeActivities);
|
mPm.getHomeActivities(homeActivities);
|
||||||
|
|
||||||
for (ResolveInfo resolveInfo : homeActivities) {
|
for (ResolveInfo resolveInfo : homeActivities) {
|
||||||
@@ -71,7 +72,7 @@ public class DefaultHomePicker extends DefaultAppPickerFragment {
|
|||||||
summary = null;
|
summary = null;
|
||||||
}
|
}
|
||||||
final DefaultAppInfo candidate =
|
final DefaultAppInfo candidate =
|
||||||
new DefaultAppInfo(mPm, mUserId, activityName, summary, enabled);
|
new DefaultAppInfo(context, mPm, mUserId, activityName, summary, enabled);
|
||||||
candidates.add(candidate);
|
candidates.add(candidate);
|
||||||
}
|
}
|
||||||
return candidates;
|
return candidates;
|
||||||
|
@@ -61,11 +61,12 @@ public class DefaultHomePreferenceController extends DefaultAppPreferenceControl
|
|||||||
final ArrayList<ResolveInfo> homeActivities = new ArrayList<>();
|
final ArrayList<ResolveInfo> homeActivities = new ArrayList<>();
|
||||||
final ComponentName currentDefaultHome = mPackageManager.getHomeActivities(homeActivities);
|
final ComponentName currentDefaultHome = mPackageManager.getHomeActivities(homeActivities);
|
||||||
if (currentDefaultHome != null) {
|
if (currentDefaultHome != null) {
|
||||||
return new DefaultAppInfo(mPackageManager, mUserId, currentDefaultHome);
|
return new DefaultAppInfo(mContext, mPackageManager, mUserId, currentDefaultHome);
|
||||||
}
|
}
|
||||||
final ActivityInfo onlyAppInfo = getOnlyAppInfo();
|
final ActivityInfo onlyAppInfo = getOnlyAppInfo();
|
||||||
if (onlyAppInfo != null) {
|
if (onlyAppInfo != null) {
|
||||||
return new DefaultAppInfo(mPackageManager, mUserId, onlyAppInfo.getComponentName());
|
return new DefaultAppInfo(mContext, mPackageManager, mUserId,
|
||||||
|
onlyAppInfo.getComponentName());
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@@ -48,9 +48,10 @@ public class DefaultPhonePicker extends DefaultAppPickerFragment {
|
|||||||
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
final List<DefaultAppInfo> candidates = new ArrayList<>();
|
||||||
final List<String> dialerPackages =
|
final List<String> dialerPackages =
|
||||||
DefaultDialerManager.getInstalledDialerApplications(getContext(), mUserId);
|
DefaultDialerManager.getInstalledDialerApplications(getContext(), mUserId);
|
||||||
|
final Context context = getContext();
|
||||||
for (String packageName : dialerPackages) {
|
for (String packageName : dialerPackages) {
|
||||||
try {
|
try {
|
||||||
candidates.add(new DefaultAppInfo(mPm,
|
candidates.add(new DefaultAppInfo(context, mPm,
|
||||||
mPm.getApplicationInfoAsUser(packageName, 0, mUserId)));
|
mPm.getApplicationInfoAsUser(packageName, 0, mUserId)));
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
// Skip unknown packages.
|
// Skip unknown packages.
|
||||||
|
@@ -57,7 +57,7 @@ public class DefaultPhonePreferenceController extends DefaultAppPreferenceContro
|
|||||||
@Override
|
@Override
|
||||||
protected DefaultAppInfo getDefaultAppInfo() {
|
protected DefaultAppInfo getDefaultAppInfo() {
|
||||||
try {
|
try {
|
||||||
return new DefaultAppInfo(mPackageManager,
|
return new DefaultAppInfo(mContext, mPackageManager,
|
||||||
mPackageManager.getPackageManager().getApplicationInfo(
|
mPackageManager.getPackageManager().getApplicationInfo(
|
||||||
DefaultDialerManager.getDefaultDialerApplication(mContext, mUserId),
|
DefaultDialerManager.getDefaultDialerApplication(mContext, mUserId),
|
||||||
0));
|
0));
|
||||||
|
@@ -41,13 +41,14 @@ public class DefaultSmsPicker extends DefaultAppPickerFragment {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<DefaultAppInfo> getCandidates() {
|
protected List<DefaultAppInfo> getCandidates() {
|
||||||
|
final Context context = getContext();
|
||||||
final Collection<SmsApplication.SmsApplicationData> smsApplications =
|
final Collection<SmsApplication.SmsApplicationData> smsApplications =
|
||||||
SmsApplication.getApplicationCollection(getContext());
|
SmsApplication.getApplicationCollection(context);
|
||||||
final List<DefaultAppInfo> candidates = new ArrayList<>(smsApplications.size());
|
final List<DefaultAppInfo> candidates = new ArrayList<>(smsApplications.size());
|
||||||
|
|
||||||
for (SmsApplication.SmsApplicationData smsApplicationData : smsApplications) {
|
for (SmsApplication.SmsApplicationData smsApplicationData : smsApplications) {
|
||||||
try {
|
try {
|
||||||
candidates.add(new DefaultAppInfo(mPm,
|
candidates.add(new DefaultAppInfo(context, mPm,
|
||||||
mPm.getApplicationInfoAsUser(smsApplicationData.mPackageName, 0, mUserId)));
|
mPm.getApplicationInfoAsUser(smsApplicationData.mPackageName, 0, mUserId)));
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
} catch (PackageManager.NameNotFoundException e) {
|
||||||
// Skip unknown packages.
|
// Skip unknown packages.
|
||||||
|
@@ -47,7 +47,7 @@ public class DefaultSmsPreferenceController extends DefaultAppPreferenceControll
|
|||||||
protected DefaultAppInfo getDefaultAppInfo() {
|
protected DefaultAppInfo getDefaultAppInfo() {
|
||||||
final ComponentName app = SmsApplication.getDefaultSmsApplication(mContext, true);
|
final ComponentName app = SmsApplication.getDefaultSmsApplication(mContext, true);
|
||||||
if (app != null) {
|
if (app != null) {
|
||||||
return new DefaultAppInfo(mPackageManager, mUserId, app);
|
return new DefaultAppInfo(mContext, mPackageManager, mUserId, app);
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@@ -85,7 +85,7 @@ public class WebViewAppPreferenceControllerV2 extends
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
DefaultAppInfo getDefaultAppInfo() {
|
DefaultAppInfo getDefaultAppInfo() {
|
||||||
final PackageInfo currentPackage = mWebViewUpdateServiceWrapper.getCurrentWebViewPackage();
|
final PackageInfo currentPackage = mWebViewUpdateServiceWrapper.getCurrentWebViewPackage();
|
||||||
return new DefaultAppInfo(mPackageManager,
|
return new DefaultAppInfo(mContext, mPackageManager,
|
||||||
currentPackage == null ? null : currentPackage.applicationInfo);
|
currentPackage == null ? null : currentPackage.applicationInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -60,12 +60,13 @@ public class WebViewAppPicker extends DefaultAppPickerFragment {
|
|||||||
@Override
|
@Override
|
||||||
protected List<DefaultAppInfo> getCandidates() {
|
protected List<DefaultAppInfo> getCandidates() {
|
||||||
final List<DefaultAppInfo> packageInfoList = new ArrayList<DefaultAppInfo>();
|
final List<DefaultAppInfo> packageInfoList = new ArrayList<DefaultAppInfo>();
|
||||||
List<ApplicationInfo> pkgs =
|
final Context context = getContext();
|
||||||
getWebViewUpdateServiceWrapper().getValidWebViewApplicationInfos(getContext());
|
final WebViewUpdateServiceWrapper webViewUpdateService = getWebViewUpdateServiceWrapper();
|
||||||
|
final List<ApplicationInfo> pkgs =
|
||||||
|
webViewUpdateService.getValidWebViewApplicationInfos(context);
|
||||||
for (ApplicationInfo ai : pkgs) {
|
for (ApplicationInfo ai : pkgs) {
|
||||||
packageInfoList.add(createDefaultAppInfo(mPm, ai,
|
packageInfoList.add(createDefaultAppInfo(context, mPm, ai,
|
||||||
getDisabledReason(getWebViewUpdateServiceWrapper(),
|
getDisabledReason(webViewUpdateService, context, ai.packageName)));
|
||||||
getContext(), ai.packageName)));
|
|
||||||
}
|
}
|
||||||
return packageInfoList;
|
return packageInfoList;
|
||||||
}
|
}
|
||||||
@@ -112,9 +113,9 @@ public class WebViewAppPicker extends DefaultAppPickerFragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static class WebViewAppInfo extends DefaultAppInfo {
|
private static class WebViewAppInfo extends DefaultAppInfo {
|
||||||
public WebViewAppInfo(PackageManagerWrapper pm, PackageItemInfo packageItemInfo,
|
public WebViewAppInfo(Context context, PackageManagerWrapper pm,
|
||||||
String summary, boolean enabled) {
|
PackageItemInfo packageItemInfo, String summary, boolean enabled) {
|
||||||
super(pm, packageItemInfo, summary, enabled);
|
super(context, pm, packageItemInfo, summary, enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -131,9 +132,9 @@ public class WebViewAppPicker extends DefaultAppPickerFragment {
|
|||||||
|
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
DefaultAppInfo createDefaultAppInfo(PackageManagerWrapper pm, PackageItemInfo packageItemInfo,
|
DefaultAppInfo createDefaultAppInfo(Context context, PackageManagerWrapper pm,
|
||||||
String disabledReason) {
|
PackageItemInfo packageItemInfo, String disabledReason) {
|
||||||
return new WebViewAppInfo(pm, packageItemInfo, disabledReason,
|
return new WebViewAppInfo(context, pm, packageItemInfo, disabledReason,
|
||||||
TextUtils.isEmpty(disabledReason) /* enabled */);
|
TextUtils.isEmpty(disabledReason) /* enabled */);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -46,7 +46,7 @@ public class WebViewAppPreferenceController extends DefaultAppPreferenceControll
|
|||||||
@Override
|
@Override
|
||||||
public DefaultAppInfo getDefaultAppInfo() {
|
public DefaultAppInfo getDefaultAppInfo() {
|
||||||
PackageInfo currentPackage = mWebViewUpdateServiceWrapper.getCurrentWebViewPackage();
|
PackageInfo currentPackage = mWebViewUpdateServiceWrapper.getCurrentWebViewPackage();
|
||||||
return new DefaultAppInfo(mPackageManager,
|
return new DefaultAppInfo(mContext, mPackageManager,
|
||||||
currentPackage == null ? null : currentPackage.applicationInfo);
|
currentPackage == null ? null : currentPackage.applicationInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -21,11 +21,13 @@ import static org.mockito.Mockito.verify;
|
|||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.pm.PackageItemInfo;
|
import android.content.pm.PackageItemInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
|
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
|
||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settingslib.wrapper.PackageManagerWrapper;
|
import com.android.settingslib.wrapper.PackageManagerWrapper;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -33,6 +35,7 @@ import org.junit.Test;
|
|||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
@@ -48,31 +51,33 @@ public class DefaultAppInfoTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private PackageManagerWrapper mPackageManagerWrapper;
|
private PackageManagerWrapper mPackageManagerWrapper;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
private DefaultAppInfo mInfo;
|
private DefaultAppInfo mInfo;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = RuntimeEnvironment.application;
|
||||||
when(mPackageManagerWrapper.getPackageManager()).thenReturn(mPackageManager);
|
when(mPackageManagerWrapper.getPackageManager()).thenReturn(mPackageManager);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void initInfoWithActivityInfo_shouldLoadInfo() {
|
public void initInfoWithActivityInfo_shouldLoadInfo() {
|
||||||
mPackageItemInfo.packageName = "test";
|
mPackageItemInfo.packageName = "test";
|
||||||
mInfo = new DefaultAppInfo(mPackageManagerWrapper, mPackageItemInfo);
|
mInfo = new DefaultAppInfo(mContext, mPackageManagerWrapper, mPackageItemInfo);
|
||||||
mInfo.loadLabel();
|
mInfo.loadLabel();
|
||||||
mInfo.loadIcon();
|
Drawable icon = mInfo.loadIcon();
|
||||||
|
|
||||||
assertThat(mInfo.getKey()).isEqualTo(mPackageItemInfo.packageName);
|
assertThat(mInfo.getKey()).isEqualTo(mPackageItemInfo.packageName);
|
||||||
|
assertThat(icon).isNotNull();
|
||||||
verify(mPackageItemInfo).loadLabel(mPackageManager);
|
verify(mPackageItemInfo).loadLabel(mPackageManager);
|
||||||
verify(mPackageItemInfo).loadIcon(mPackageManager);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void initInfoWithComponent_shouldLoadInfo() {
|
public void initInfoWithComponent_shouldLoadInfo() {
|
||||||
when(mComponentName.getPackageName()).thenReturn("com.android.settings");
|
when(mComponentName.getPackageName()).thenReturn("com.android.settings");
|
||||||
|
|
||||||
mInfo = new DefaultAppInfo(mPackageManagerWrapper, 0 /* uid */, mComponentName);
|
mInfo = new DefaultAppInfo(mContext, mPackageManagerWrapper, 0 /* uid */, mComponentName);
|
||||||
mInfo.getKey();
|
mInfo.getKey();
|
||||||
|
|
||||||
verify(mComponentName).flattenToString();
|
verify(mComponentName).flattenToString();
|
||||||
|
@@ -16,38 +16,6 @@
|
|||||||
|
|
||||||
package com.android.settings.webview;
|
package com.android.settings.webview;
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.content.pm.ApplicationInfo;
|
|
||||||
import android.content.pm.PackageInfo;
|
|
||||||
import android.content.pm.PackageItemInfo;
|
|
||||||
import android.content.pm.PackageManager;
|
|
||||||
import android.content.pm.UserInfo;
|
|
||||||
import android.os.UserManager;
|
|
||||||
|
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
|
||||||
import com.android.settings.TestConfig;
|
|
||||||
import com.android.settings.applications.defaultapps.DefaultAppInfo;
|
|
||||||
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
|
||||||
import com.android.settings.widget.RadioButtonPreference;
|
|
||||||
import com.android.settings.wrapper.UserPackageWrapper;
|
|
||||||
import com.android.settingslib.wrapper.PackageManagerWrapper;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.BeforeClass;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.mockito.Answers;
|
|
||||||
import org.mockito.Mock;
|
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.robolectric.RuntimeEnvironment;
|
|
||||||
import org.robolectric.annotation.Config;
|
|
||||||
import org.robolectric.util.ReflectionHelpers;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
import static android.provider.Settings.ACTION_WEBVIEW_SETTINGS;
|
import static android.provider.Settings.ACTION_WEBVIEW_SETTINGS;
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
@@ -62,22 +30,47 @@ import static org.mockito.Mockito.times;
|
|||||||
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.Activity;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.content.pm.PackageInfo;
|
||||||
|
import android.content.pm.PackageItemInfo;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.content.pm.UserInfo;
|
||||||
|
import android.os.UserManager;
|
||||||
|
|
||||||
|
import com.android.settings.TestConfig;
|
||||||
|
import com.android.settings.applications.defaultapps.DefaultAppInfo;
|
||||||
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
|
import com.android.settings.widget.RadioButtonPreference;
|
||||||
|
import com.android.settings.wrapper.UserPackageWrapper;
|
||||||
|
import com.android.settingslib.wrapper.PackageManagerWrapper;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Answers;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.util.ReflectionHelpers;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
||||||
public class WebViewAppPickerTest {
|
public class WebViewAppPickerTest {
|
||||||
private Context mContext = RuntimeEnvironment.application;
|
private Context mContext = RuntimeEnvironment.application;
|
||||||
|
|
||||||
private static UserInfo sFirstUser;
|
private UserInfo mFirstUser;
|
||||||
private static UserInfo sSecondUser;
|
private UserInfo mSecondUser;
|
||||||
|
|
||||||
private final static String DEFAULT_PACKAGE_NAME = "DEFAULT_PACKAGE_NAME";
|
private final static String DEFAULT_PACKAGE_NAME = "DEFAULT_PACKAGE_NAME";
|
||||||
|
|
||||||
@BeforeClass
|
|
||||||
public static void beforeClass() {
|
|
||||||
sFirstUser = new UserInfo(0, "FIRST_USER", 0);
|
|
||||||
sSecondUser = new UserInfo(0, "SECOND_USER", 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
private Activity mActivity;
|
private Activity mActivity;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -99,7 +92,8 @@ public class WebViewAppPickerTest {
|
|||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
FakeFeatureFactory.setupForTest(mActivity);
|
FakeFeatureFactory.setupForTest(mActivity);
|
||||||
when(mActivity.getSystemService(Context.USER_SERVICE)).thenReturn(mUserManager);
|
when(mActivity.getSystemService(Context.USER_SERVICE)).thenReturn(mUserManager);
|
||||||
|
mFirstUser = new UserInfo(0, "FIRST_USER", 0);
|
||||||
|
mSecondUser = new UserInfo(0, "SECOND_USER", 0);
|
||||||
mPicker = new WebViewAppPicker();
|
mPicker = new WebViewAppPicker();
|
||||||
mPicker = spy(mPicker);
|
mPicker = spy(mPicker);
|
||||||
doNothing().when(mPicker).updateCandidates();
|
doNothing().when(mPicker).updateCandidates();
|
||||||
@@ -174,7 +168,7 @@ public class WebViewAppPickerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testDisabledPackageShownAsDisabled() {
|
public void testDisabledPackageShownAsDisabled() {
|
||||||
String disabledReason = "disabled";
|
String disabledReason = "disabled";
|
||||||
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mPackageManager,
|
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mActivity, mPackageManager,
|
||||||
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
||||||
|
|
||||||
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
||||||
@@ -189,7 +183,7 @@ public class WebViewAppPickerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testEnabledPackageShownAsEnabled() {
|
public void testEnabledPackageShownAsEnabled() {
|
||||||
String disabledReason = "";
|
String disabledReason = "";
|
||||||
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mPackageManager,
|
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mActivity, mPackageManager,
|
||||||
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
||||||
|
|
||||||
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
||||||
@@ -204,7 +198,7 @@ public class WebViewAppPickerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testDisabledPackageShowsDisabledReasonSummary() {
|
public void testDisabledPackageShowsDisabledReasonSummary() {
|
||||||
String disabledReason = "disabled";
|
String disabledReason = "disabled";
|
||||||
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mPackageManager,
|
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mActivity, mPackageManager,
|
||||||
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
||||||
|
|
||||||
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
||||||
@@ -220,7 +214,7 @@ public class WebViewAppPickerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testEnabledPackageShowsEmptySummary() {
|
public void testEnabledPackageShowsEmptySummary() {
|
||||||
String disabledReason = null;
|
String disabledReason = null;
|
||||||
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mPackageManager,
|
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mActivity, mPackageManager,
|
||||||
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
createApplicationInfo(DEFAULT_PACKAGE_NAME), disabledReason);
|
||||||
|
|
||||||
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
RadioButtonPreference mockPreference = mock(RadioButtonPreference.class);
|
||||||
@@ -268,14 +262,14 @@ public class WebViewAppPickerTest {
|
|||||||
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
||||||
when(packageForFirstUser.isEnabledPackage()).thenReturn(false);
|
when(packageForFirstUser.isEnabledPackage()).thenReturn(false);
|
||||||
when(packageForFirstUser.isInstalledPackage()).thenReturn(true);
|
when(packageForFirstUser.isInstalledPackage()).thenReturn(true);
|
||||||
when(packageForFirstUser.getUserInfo()).thenReturn(sFirstUser);
|
when(packageForFirstUser.getUserInfo()).thenReturn(mFirstUser);
|
||||||
|
|
||||||
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
||||||
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
||||||
.thenReturn(Arrays.asList(packageForFirstUser));
|
.thenReturn(Arrays.asList(packageForFirstUser));
|
||||||
|
|
||||||
final String EXPECTED_DISABLED_REASON = String.format(
|
final String EXPECTED_DISABLED_REASON = String.format(
|
||||||
"(disabled for user %s)", sFirstUser.name);
|
"(disabled for user %s)", mFirstUser.name);
|
||||||
assertThat(mPicker.getDisabledReason(wvusWrapper, mContext,
|
assertThat(mPicker.getDisabledReason(wvusWrapper, mContext,
|
||||||
DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
||||||
}
|
}
|
||||||
@@ -285,14 +279,14 @@ public class WebViewAppPickerTest {
|
|||||||
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
||||||
when(packageForFirstUser.isEnabledPackage()).thenReturn(true);
|
when(packageForFirstUser.isEnabledPackage()).thenReturn(true);
|
||||||
when(packageForFirstUser.isInstalledPackage()).thenReturn(false);
|
when(packageForFirstUser.isInstalledPackage()).thenReturn(false);
|
||||||
when(packageForFirstUser.getUserInfo()).thenReturn(sFirstUser);
|
when(packageForFirstUser.getUserInfo()).thenReturn(mFirstUser);
|
||||||
|
|
||||||
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
||||||
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
||||||
.thenReturn(Arrays.asList(packageForFirstUser));
|
.thenReturn(Arrays.asList(packageForFirstUser));
|
||||||
|
|
||||||
final String EXPECTED_DISABLED_REASON = String.format(
|
final String EXPECTED_DISABLED_REASON = String.format(
|
||||||
"(uninstalled for user %s)", sFirstUser.name);
|
"(uninstalled for user %s)", mFirstUser.name);
|
||||||
assertThat(mPicker.getDisabledReason(wvusWrapper, mContext,
|
assertThat(mPicker.getDisabledReason(wvusWrapper, mContext,
|
||||||
DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
||||||
}
|
}
|
||||||
@@ -302,19 +296,19 @@ public class WebViewAppPickerTest {
|
|||||||
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
||||||
when(packageForFirstUser.isEnabledPackage()).thenReturn(false);
|
when(packageForFirstUser.isEnabledPackage()).thenReturn(false);
|
||||||
when(packageForFirstUser.isInstalledPackage()).thenReturn(true);
|
when(packageForFirstUser.isInstalledPackage()).thenReturn(true);
|
||||||
when(packageForFirstUser.getUserInfo()).thenReturn(sFirstUser);
|
when(packageForFirstUser.getUserInfo()).thenReturn(mFirstUser);
|
||||||
|
|
||||||
UserPackageWrapper packageForSecondUser = mock(UserPackageWrapper.class);
|
UserPackageWrapper packageForSecondUser = mock(UserPackageWrapper.class);
|
||||||
when(packageForSecondUser.isEnabledPackage()).thenReturn(true);
|
when(packageForSecondUser.isEnabledPackage()).thenReturn(true);
|
||||||
when(packageForSecondUser.isInstalledPackage()).thenReturn(false);
|
when(packageForSecondUser.isInstalledPackage()).thenReturn(false);
|
||||||
when(packageForSecondUser.getUserInfo()).thenReturn(sSecondUser);
|
when(packageForSecondUser.getUserInfo()).thenReturn(mSecondUser);
|
||||||
|
|
||||||
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
||||||
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
||||||
.thenReturn(Arrays.asList(packageForFirstUser, packageForSecondUser));
|
.thenReturn(Arrays.asList(packageForFirstUser, packageForSecondUser));
|
||||||
|
|
||||||
final String EXPECTED_DISABLED_REASON = String.format(
|
final String EXPECTED_DISABLED_REASON = String.format(
|
||||||
"(disabled for user %s)", sFirstUser.name);
|
"(disabled for user %s)", mFirstUser.name);
|
||||||
assertThat(mPicker.getDisabledReason(
|
assertThat(mPicker.getDisabledReason(
|
||||||
wvusWrapper, mContext, DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
wvusWrapper, mContext, DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
||||||
}
|
}
|
||||||
@@ -328,19 +322,19 @@ public class WebViewAppPickerTest {
|
|||||||
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
UserPackageWrapper packageForFirstUser = mock(UserPackageWrapper.class);
|
||||||
when(packageForFirstUser.isEnabledPackage()).thenReturn(false);
|
when(packageForFirstUser.isEnabledPackage()).thenReturn(false);
|
||||||
when(packageForFirstUser.isInstalledPackage()).thenReturn(false);
|
when(packageForFirstUser.isInstalledPackage()).thenReturn(false);
|
||||||
when(packageForFirstUser.getUserInfo()).thenReturn(sFirstUser);
|
when(packageForFirstUser.getUserInfo()).thenReturn(mFirstUser);
|
||||||
|
|
||||||
UserPackageWrapper packageForSecondUser = mock(UserPackageWrapper.class);
|
UserPackageWrapper packageForSecondUser = mock(UserPackageWrapper.class);
|
||||||
when(packageForSecondUser.isEnabledPackage()).thenReturn(true);
|
when(packageForSecondUser.isEnabledPackage()).thenReturn(true);
|
||||||
when(packageForSecondUser.isInstalledPackage()).thenReturn(true);
|
when(packageForSecondUser.isInstalledPackage()).thenReturn(true);
|
||||||
when(packageForSecondUser.getUserInfo()).thenReturn(sSecondUser);
|
when(packageForSecondUser.getUserInfo()).thenReturn(mSecondUser);
|
||||||
|
|
||||||
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
||||||
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
when(wvusWrapper.getPackageInfosAllUsers(any(), eq(DEFAULT_PACKAGE_NAME)))
|
||||||
.thenReturn(Arrays.asList(packageForFirstUser, packageForSecondUser));
|
.thenReturn(Arrays.asList(packageForFirstUser, packageForSecondUser));
|
||||||
|
|
||||||
final String EXPECTED_DISABLED_REASON = String.format(
|
final String EXPECTED_DISABLED_REASON = String.format(
|
||||||
"(uninstalled for user %s)", sFirstUser.name);
|
"(uninstalled for user %s)", mFirstUser.name);
|
||||||
assertThat(mPicker.getDisabledReason(wvusWrapper, mContext,
|
assertThat(mPicker.getDisabledReason(wvusWrapper, mContext,
|
||||||
DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
DEFAULT_PACKAGE_NAME)).isEqualTo(EXPECTED_DISABLED_REASON);
|
||||||
}
|
}
|
||||||
@@ -354,7 +348,7 @@ public class WebViewAppPickerTest {
|
|||||||
PackageItemInfo mockPackageItemInfo = mock(PackageItemInfo.class);
|
PackageItemInfo mockPackageItemInfo = mock(PackageItemInfo.class);
|
||||||
mockPackageItemInfo.packageName = DEFAULT_PACKAGE_NAME;
|
mockPackageItemInfo.packageName = DEFAULT_PACKAGE_NAME;
|
||||||
when(mockPackageItemInfo.loadLabel(any())).thenReturn("myPackage");
|
when(mockPackageItemInfo.loadLabel(any())).thenReturn("myPackage");
|
||||||
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mPackageManager,
|
DefaultAppInfo webviewAppInfo = mPicker.createDefaultAppInfo(mActivity, mPackageManager,
|
||||||
mockPackageItemInfo, "" /* disabledReason */);
|
mockPackageItemInfo, "" /* disabledReason */);
|
||||||
|
|
||||||
PackageInfo packageInfo = new PackageInfo();
|
PackageInfo packageInfo = new PackageInfo();
|
||||||
|
Reference in New Issue
Block a user