[Settings] Apply the SettingsDataService to the SIM page, calls/smscontroller

Calls/SmsDefaultSubscriptionController

Bug: 257197354
Test: atest DefaultSubscriptionControllerTest
Change-Id: I67cb2d3aa5ef3c6751d90b96db27a062071c8113
This commit is contained in:
Zoey Chen
2022-11-21 06:39:12 +00:00
parent 7292c4a017
commit 64330a235a
12 changed files with 294 additions and 262 deletions

View File

@@ -45,6 +45,7 @@ import com.android.settings.widget.SummaryUpdater;
import com.android.settings.wifi.WifiSummaryUpdater; import com.android.settings.wifi.WifiSummaryUpdater;
import com.android.settingslib.Utils; import com.android.settingslib.Utils;
import com.android.settingslib.core.AbstractPreferenceController; import com.android.settingslib.core.AbstractPreferenceController;
import com.android.settingslib.mobile.dataservice.DataServiceUtils;
import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity; import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity; import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import com.android.settingslib.mobile.dataservice.UiccInfoEntity; import com.android.settingslib.mobile.dataservice.UiccInfoEntity;
@@ -237,9 +238,7 @@ public class InternetPreferenceController extends AbstractPreferenceController i
@Override @Override
public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) { public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) {
if ((mSubInfoEntityList != null && if (DataServiceUtils.shouldUpdateEntityList(mSubInfoEntityList, subInfoEntityList)) {
(subInfoEntityList.isEmpty() || !subInfoEntityList.equals(mSubInfoEntityList)))
|| (!subInfoEntityList.isEmpty() && mSubInfoEntityList == null)) {
mSubInfoEntityList = subInfoEntityList; mSubInfoEntityList = subInfoEntityList;
updateState(mPreference); updateState(mPreference);
} }

View File

@@ -17,6 +17,8 @@ package com.android.settings.network;
import static android.telephony.UiccSlotInfo.CARD_STATE_INFO_PRESENT; import static android.telephony.UiccSlotInfo.CARD_STATE_INFO_PRESENT;
import static com.android.internal.telephony.TelephonyIntents.ACTION_DEFAULT_VOICE_SUBSCRIPTION_CHANGED;
import android.app.settings.SettingsEnums; import android.app.settings.SettingsEnums;
import android.content.BroadcastReceiver; import android.content.BroadcastReceiver;
import android.content.Context; import android.content.Context;
@@ -125,6 +127,8 @@ public class MobileNetworkRepository extends SubscriptionManager.OnSubscriptions
mAirplaneModeSettingUri = Settings.Global.getUriFor(Settings.Global.AIRPLANE_MODE_ON); mAirplaneModeSettingUri = Settings.Global.getUriFor(Settings.Global.AIRPLANE_MODE_ON);
mFilter.addAction(TelephonyManager.ACTION_DEFAULT_DATA_SUBSCRIPTION_CHANGED); mFilter.addAction(TelephonyManager.ACTION_DEFAULT_DATA_SUBSCRIPTION_CHANGED);
mFilter.addAction(SubscriptionManager.ACTION_DEFAULT_SUBSCRIPTION_CHANGED); mFilter.addAction(SubscriptionManager.ACTION_DEFAULT_SUBSCRIPTION_CHANGED);
mFilter.addAction(ACTION_DEFAULT_VOICE_SUBSCRIPTION_CHANGED);
mFilter.addAction(SubscriptionManager.ACTION_DEFAULT_SMS_SUBSCRIPTION_CHANGED);
} }
private class AirplaneModeObserver extends ContentObserver { private class AirplaneModeObserver extends ContentObserver {
@@ -152,11 +156,7 @@ public class MobileNetworkRepository extends SubscriptionManager.OnSubscriptions
private final BroadcastReceiver mDataSubscriptionChangedReceiver = new BroadcastReceiver() { private final BroadcastReceiver mDataSubscriptionChangedReceiver = new BroadcastReceiver() {
@Override @Override
public void onReceive(Context context, Intent intent) { public void onReceive(Context context, Intent intent) {
final String action = intent.getAction(); onSubscriptionsChanged();
if (action.equals(TelephonyManager.ACTION_DEFAULT_DATA_SUBSCRIPTION_CHANGED)
|| action.equals(SubscriptionManager.ACTION_DEFAULT_SUBSCRIPTION_CHANGED)) {
onSubscriptionsChanged();
}
} }
}; };
@@ -171,7 +171,6 @@ public class MobileNetworkRepository extends SubscriptionManager.OnSubscriptions
public void removeRegister() { public void removeRegister() {
mAirplaneModeObserver.unRegister(mContext); mAirplaneModeObserver.unRegister(mContext);
mContext.getContentResolver().unregisterContentObserver(mAirplaneModeObserver);
if (mDataSubscriptionChangedReceiver != null) { if (mDataSubscriptionChangedReceiver != null) {
mContext.unregisterReceiver(mDataSubscriptionChangedReceiver); mContext.unregisterReceiver(mDataSubscriptionChangedReceiver);
} }

View File

@@ -41,6 +41,7 @@ import com.android.settings.widget.AddPreference;
import com.android.settingslib.Utils; import com.android.settingslib.Utils;
import com.android.settingslib.core.AbstractPreferenceController; import com.android.settingslib.core.AbstractPreferenceController;
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider; import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
import com.android.settingslib.mobile.dataservice.DataServiceUtils;
import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity; import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity; import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import com.android.settingslib.mobile.dataservice.UiccInfoEntity; import com.android.settingslib.mobile.dataservice.UiccInfoEntity;
@@ -226,10 +227,7 @@ public class MobileNetworkSummaryController extends AbstractPreferenceController
@Override @Override
public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) { public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) {
if ((mSubInfoEntityList != null && if (DataServiceUtils.shouldUpdateEntityList(mSubInfoEntityList, subInfoEntityList)) {
(subInfoEntityList.isEmpty() || !subInfoEntityList.equals(mSubInfoEntityList)))
|| (!subInfoEntityList.isEmpty() && mSubInfoEntityList == null)) {
Log.d(TAG, "subInfo list from framework is changed, update the subInfo entity list.");
mSubInfoEntityList = subInfoEntityList; mSubInfoEntityList = subInfoEntityList;
update(); update();
} }

View File

@@ -37,6 +37,7 @@ import com.android.settingslib.RestrictedPreference;
import com.android.settingslib.Utils; import com.android.settingslib.Utils;
import com.android.settingslib.core.AbstractPreferenceController; import com.android.settingslib.core.AbstractPreferenceController;
import com.android.settingslib.core.lifecycle.Lifecycle; import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.mobile.dataservice.DataServiceUtils;
import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity; import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity; import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import com.android.settingslib.mobile.dataservice.UiccInfoEntity; import com.android.settingslib.mobile.dataservice.UiccInfoEntity;
@@ -97,7 +98,7 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
@Override @Override
public CharSequence getSummary() { public CharSequence getSummary() {
List<SubscriptionInfoEntity> list = getSubscriptionInfoList(); List<SubscriptionInfoEntity> list = getSubscriptionInfoList();
if (list == null || list .isEmpty()) { if (list == null || list.isEmpty()) {
return setSummaryResId(R.string.calls_sms_no_sim); return setSummaryResId(R.string.calls_sms_no_sim);
} else { } else {
final StringBuilder summary = new StringBuilder(); final StringBuilder summary = new StringBuilder();
@@ -223,10 +224,7 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
@Override @Override
public void onActiveSubInfoChanged(List<SubscriptionInfoEntity> activeSubInfoList) { public void onActiveSubInfoChanged(List<SubscriptionInfoEntity> activeSubInfoList) {
if ((mSubInfoEntityList != null && if (DataServiceUtils.shouldUpdateEntityList(mSubInfoEntityList, activeSubInfoList)) {
(activeSubInfoList.isEmpty() || !activeSubInfoList.equals(mSubInfoEntityList)))
|| (!activeSubInfoList.isEmpty() && mSubInfoEntityList == null)) {
Log.d(TAG, "subInfo list from framework is changed, update the subInfo entity list.");
mSubInfoEntityList = activeSubInfoList; mSubInfoEntityList = activeSubInfoList;
update(); update();
} }

View File

@@ -57,8 +57,10 @@ public class NetworkProviderCallsSmsFragment extends DashboardFragment {
@Override @Override
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) { protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
final List<AbstractPreferenceController> controllers = new ArrayList<>(); final List<AbstractPreferenceController> controllers = new ArrayList<>();
controllers.add(new CallsDefaultSubscriptionController(context, KEY_PREFERENCE_CALLS)); controllers.add(new CallsDefaultSubscriptionController(context, KEY_PREFERENCE_CALLS,
controllers.add(new SmsDefaultSubscriptionController(context, KEY_PREFERENCE_SMS)); getSettingsLifecycle(), this));
controllers.add(new SmsDefaultSubscriptionController(context, KEY_PREFERENCE_SMS,
getSettingsLifecycle(), this));
mNetworkProviderWifiCallingPreferenceController = mNetworkProviderWifiCallingPreferenceController =
new NetworkProviderWifiCallingPreferenceController(context, new NetworkProviderWifiCallingPreferenceController(context,
KEY_PREFERENCE_CATEGORY_CALLING); KEY_PREFERENCE_CATEGORY_CALLING);

View File

@@ -41,6 +41,7 @@ import com.android.settings.network.telephony.MobileNetworkUtils;
import com.android.settingslib.core.AbstractPreferenceController; import com.android.settingslib.core.AbstractPreferenceController;
import com.android.settingslib.core.lifecycle.Lifecycle; import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.core.lifecycle.LifecycleObserver; import com.android.settingslib.core.lifecycle.LifecycleObserver;
import com.android.settingslib.mobile.dataservice.DataServiceUtils;
import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity; import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity; import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import com.android.settingslib.mobile.dataservice.UiccInfoEntity; import com.android.settingslib.mobile.dataservice.UiccInfoEntity;
@@ -177,10 +178,7 @@ public class NetworkProviderSimListController extends AbstractPreferenceControll
@Override @Override
public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) { public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) {
if ((mSubInfoEntityList != null && if (DataServiceUtils.shouldUpdateEntityList(mSubInfoEntityList, subInfoEntityList)) {
(subInfoEntityList.isEmpty() || !subInfoEntityList.equals(mSubInfoEntityList)))
|| (!subInfoEntityList.isEmpty() && mSubInfoEntityList == null)) {
Log.d(TAG, "subInfo list from framework is changed, update the subInfo entity list.");
mSubInfoEntityList = subInfoEntityList; mSubInfoEntityList = subInfoEntityList;
mPreferenceCategory.setVisible(isAvailable()); mPreferenceCategory.setVisible(isAvailable());
update(); update();

View File

@@ -17,25 +17,36 @@
package com.android.settings.network.telephony; package com.android.settings.network.telephony;
import android.content.Context; import android.content.Context;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager; import android.telephony.SubscriptionManager;
import com.android.settings.Utils; import androidx.lifecycle.LifecycleOwner;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
public class CallsDefaultSubscriptionController extends DefaultSubscriptionController { public class CallsDefaultSubscriptionController extends DefaultSubscriptionController {
public CallsDefaultSubscriptionController(Context context, String preferenceKey) { private SubscriptionInfoEntity mSubscriptionInfoEntity;
super(context, preferenceKey);
public CallsDefaultSubscriptionController(Context context, String preferenceKey,
Lifecycle lifecycle, LifecycleOwner lifecycleOwner) {
super(context, preferenceKey, lifecycle, lifecycleOwner);
} }
@Override @Override
protected SubscriptionInfo getDefaultSubscriptionInfo() { protected SubscriptionInfoEntity getDefaultSubscriptionInfo() {
return mManager.getActiveSubscriptionInfo(getDefaultSubscriptionId()); return mSubscriptionInfoEntity;
} }
@Override @Override
protected int getDefaultSubscriptionId() { protected int getDefaultSubscriptionId() {
return SubscriptionManager.getDefaultVoiceSubscriptionId(); for (SubscriptionInfoEntity subInfo : mSubInfoEntityList) {
if (subInfo.isActiveSubscriptionId && subInfo.isDefaultVoiceSubscription) {
mSubscriptionInfoEntity = subInfo;
return Integer.parseInt(subInfo.subId);
}
}
return SubscriptionManager.INVALID_SUBSCRIPTION_ID;
} }
@Override @Override
@@ -45,6 +56,7 @@ public class CallsDefaultSubscriptionController extends DefaultSubscriptionContr
@Override @Override
public CharSequence getSummary() { public CharSequence getSummary() {
return MobileNetworkUtils.getPreferredStatus(isRtlMode(), mContext, mManager, true); return MobileNetworkUtils.getPreferredStatus(isRtlMode(), mContext, true,
mSubInfoEntityList);
} }
} }

View File

@@ -24,11 +24,11 @@ import android.content.Context;
import android.telecom.PhoneAccount; import android.telecom.PhoneAccount;
import android.telecom.PhoneAccountHandle; import android.telecom.PhoneAccountHandle;
import android.telecom.TelecomManager; import android.telecom.TelecomManager;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager; import android.telephony.SubscriptionManager;
import android.view.View; import android.view.View;
import androidx.lifecycle.LifecycleObserver; import androidx.lifecycle.LifecycleObserver;
import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.OnLifecycleEvent; import androidx.lifecycle.OnLifecycleEvent;
import androidx.preference.ListPreference; import androidx.preference.ListPreference;
import androidx.preference.Preference; import androidx.preference.Preference;
@@ -36,8 +36,12 @@ import androidx.preference.PreferenceScreen;
import com.android.internal.annotations.VisibleForTesting; import com.android.internal.annotations.VisibleForTesting;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.network.SubscriptionUtil; import com.android.settings.network.MobileNetworkRepository;
import com.android.settings.network.SubscriptionsChangeListener; import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.mobile.dataservice.DataServiceUtils;
import com.android.settingslib.mobile.dataservice.MobileNetworkInfoEntity;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import com.android.settingslib.mobile.dataservice.UiccInfoEntity;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@@ -49,13 +53,14 @@ import java.util.List;
*/ */
public abstract class DefaultSubscriptionController extends TelephonyBasePreferenceController public abstract class DefaultSubscriptionController extends TelephonyBasePreferenceController
implements LifecycleObserver, Preference.OnPreferenceChangeListener, implements LifecycleObserver, Preference.OnPreferenceChangeListener,
SubscriptionsChangeListener.SubscriptionsChangeListenerClient { MobileNetworkRepository.MobileNetworkCallback {
private static final String TAG = "DefaultSubController"; private static final String TAG = "DefaultSubController";
protected SubscriptionsChangeListener mChangeListener;
protected ListPreference mPreference; protected ListPreference mPreference;
protected SubscriptionManager mManager; protected SubscriptionManager mManager;
protected TelecomManager mTelecomManager; protected TelecomManager mTelecomManager;
protected MobileNetworkRepository mMobileNetworkRepository;
protected LifecycleOwner mLifecycleOwner;
private static final String EMERGENCY_ACCOUNT_HANDLE_ID = "E"; private static final String EMERGENCY_ACCOUNT_HANDLE_ID = "E";
private static final ComponentName PSTN_CONNECTION_SERVICE_COMPONENT = private static final ComponentName PSTN_CONNECTION_SERVICE_COMPONENT =
@@ -63,17 +68,24 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
"com.android.services.telephony.TelephonyConnectionService"); "com.android.services.telephony.TelephonyConnectionService");
private boolean mIsRtlMode; private boolean mIsRtlMode;
public DefaultSubscriptionController(Context context, String preferenceKey) { List<SubscriptionInfoEntity> mSubInfoEntityList = new ArrayList<>();
public DefaultSubscriptionController(Context context, String preferenceKey, Lifecycle lifecycle,
LifecycleOwner lifecycleOwner) {
super(context, preferenceKey); super(context, preferenceKey);
mManager = context.getSystemService(SubscriptionManager.class); mManager = context.getSystemService(SubscriptionManager.class);
mChangeListener = new SubscriptionsChangeListener(context, this);
mIsRtlMode = context.getResources().getConfiguration().getLayoutDirection() mIsRtlMode = context.getResources().getConfiguration().getLayoutDirection()
== View.LAYOUT_DIRECTION_RTL; == View.LAYOUT_DIRECTION_RTL;
mMobileNetworkRepository = MobileNetworkRepository.create(context, this);
mLifecycleOwner = lifecycleOwner;
if (lifecycle != null) {
lifecycle.addObserver(this);
}
} }
/** @return SubscriptionInfo for the default subscription for the service, or null if there /** @return SubscriptionInfo for the default subscription for the service, or null if there
* isn't one. */ * isn't one. */
protected abstract SubscriptionInfo getDefaultSubscriptionInfo(); protected abstract SubscriptionInfoEntity getDefaultSubscriptionInfo();
/** @return the id of the default subscription for the service, or /** @return the id of the default subscription for the service, or
* SubscriptionManager.INVALID_SUBSCRIPTION_ID if there isn't one. */ * SubscriptionManager.INVALID_SUBSCRIPTION_ID if there isn't one. */
@@ -93,13 +105,13 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
@OnLifecycleEvent(ON_RESUME) @OnLifecycleEvent(ON_RESUME)
public void onResume() { public void onResume() {
mChangeListener.start(); mMobileNetworkRepository.addRegister(mLifecycleOwner);
updateEntries(); updateEntries();
} }
@OnLifecycleEvent(ON_PAUSE) @OnLifecycleEvent(ON_PAUSE)
public void onPause() { public void onPause() {
mChangeListener.stop(); mMobileNetworkRepository.removeRegister();
} }
@Override @Override
@@ -126,10 +138,10 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
// display VoIP account in summary when configured through settings within dialer // display VoIP account in summary when configured through settings within dialer
return getLabelFromCallingAccount(handle); return getLabelFromCallingAccount(handle);
} }
final SubscriptionInfo info = getDefaultSubscriptionInfo(); final SubscriptionInfoEntity info = getDefaultSubscriptionInfo();
if (info != null) { if (info != null) {
// display subscription based account // display subscription based account
return SubscriptionUtil.getUniqueSubscriptionDisplayName(info, mContext); return info.uniqueName;
} else { } else {
if (isAskEverytimeSupported()) { if (isAskEverytimeSupported()) {
return mContext.getString(R.string.calls_and_sms_ask_every_time); return mContext.getString(R.string.calls_and_sms_ask_every_time);
@@ -139,7 +151,8 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
} }
} }
private void updateEntries() { @VisibleForTesting
void updateEntries() {
if (mPreference == null) { if (mPreference == null) {
return; return;
} }
@@ -154,30 +167,28 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
// getAvailabilityStatus returned CONDITIONALLY_UNAVAILABLE at the time. // getAvailabilityStatus returned CONDITIONALLY_UNAVAILABLE at the time.
mPreference.setOnPreferenceChangeListener(this); mPreference.setOnPreferenceChangeListener(this);
final List<SubscriptionInfo> subs = SubscriptionUtil.getActiveSubscriptions(mManager);
// We'll have one entry for each available subscription, plus one for a "ask me every // We'll have one entry for each available subscription, plus one for a "ask me every
// time" entry at the end. // time" entry at the end.
final ArrayList<CharSequence> displayNames = new ArrayList<>(); final ArrayList<CharSequence> displayNames = new ArrayList<>();
final ArrayList<CharSequence> subscriptionIds = new ArrayList<>(); final ArrayList<CharSequence> subscriptionIds = new ArrayList<>();
List<SubscriptionInfoEntity> list = getSubscriptionInfoList();
if (subs.size() == 1) { if (list.size() == 1) {
mPreference.setEnabled(false); mPreference.setEnabled(false);
mPreference.setSummaryProvider(pref -> mPreference.setSummaryProvider(pref -> list.get(0).uniqueName);
SubscriptionUtil.getUniqueSubscriptionDisplayName(subs.get(0), mContext));
return; return;
} }
final int serviceDefaultSubId = getDefaultSubscriptionId(); final int serviceDefaultSubId = getDefaultSubscriptionId();
boolean subIsAvailable = false; boolean subIsAvailable = false;
for (SubscriptionInfo sub : subs) { for (SubscriptionInfoEntity sub : list) {
if (sub.isOpportunistic()) { if (sub.isOpportunistic) {
continue; continue;
} }
displayNames.add(SubscriptionUtil.getUniqueSubscriptionDisplayName(sub, mContext)); displayNames.add(sub.uniqueName);
final int subId = sub.getSubscriptionId(); final int subId = Integer.parseInt(sub.subId);
subscriptionIds.add(Integer.toString(subId)); subscriptionIds.add(sub.subId);
if (subId == serviceDefaultSubId) { if (subId == serviceDefaultSubId) {
subIsAvailable = true; subIsAvailable = true;
} }
@@ -270,6 +281,11 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
return (label != null) ? label : ""; return (label != null) ? label : "";
} }
@VisibleForTesting
protected List<SubscriptionInfoEntity> getSubscriptionInfoList() {
return mSubInfoEntityList;
}
@Override @Override
public boolean onPreferenceChange(Preference preference, Object newValue) { public boolean onPreferenceChange(Preference preference, Object newValue) {
final int subscriptionId = Integer.parseInt((String) newValue); final int subscriptionId = Integer.parseInt((String) newValue);
@@ -282,15 +298,29 @@ public abstract class DefaultSubscriptionController extends TelephonyBasePrefere
public void onAirplaneModeChanged(boolean airplaneModeEnabled) { public void onAirplaneModeChanged(boolean airplaneModeEnabled) {
} }
boolean isRtlMode() {
return mIsRtlMode;
}
@Override @Override
public void onSubscriptionsChanged() { public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) {
if (mPreference != null) { }
@Override
public void onActiveSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) {
if (DataServiceUtils.shouldUpdateEntityList(mSubInfoEntityList, subInfoEntityList)) {
mSubInfoEntityList = subInfoEntityList;
updateEntries(); updateEntries();
refreshSummary(mPreference); refreshSummary(mPreference);
} }
} }
boolean isRtlMode() { @Override
return mIsRtlMode; public void onAllUiccInfoChanged(List<UiccInfoEntity> uiccInfoEntityList) {
}
@Override
public void onAllMobileNetworkInfoChanged(
List<MobileNetworkInfoEntity> mobileNetworkInfoEntityList) {
} }
} }

View File

@@ -77,6 +77,8 @@ public class MobileNetworkSettings extends AbstractMobileNetworkSettings impleme
static final String KEY_CLICKED_PREF = "key_clicked_pref"; static final String KEY_CLICKED_PREF = "key_clicked_pref";
private static final String KEY_ROAMING_PREF = "button_roaming_key"; private static final String KEY_ROAMING_PREF = "button_roaming_key";
private static final String KEY_CALLS_PREF = "calls_preference";
private static final String KEY_SMS_PREF = "sms_preference";
//String keys for preference lookup //String keys for preference lookup
private static final String BUTTON_CDMA_SYSTEM_SELECT_KEY = "cdma_system_select_key"; private static final String BUTTON_CDMA_SYSTEM_SELECT_KEY = "cdma_system_select_key";
@@ -169,7 +171,11 @@ public class MobileNetworkSettings extends AbstractMobileNetworkSettings impleme
new DataUsageSummaryPreferenceController(getActivity(), getSettingsLifecycle(), new DataUsageSummaryPreferenceController(getActivity(), getSettingsLifecycle(),
this, mSubId), this, mSubId),
new RoamingPreferenceController(context, KEY_ROAMING_PREF, getSettingsLifecycle(), new RoamingPreferenceController(context, KEY_ROAMING_PREF, getSettingsLifecycle(),
this, mSubId)); this, mSubId),
new CallsDefaultSubscriptionController(context, KEY_CALLS_PREF,
getSettingsLifecycle(), this),
new SmsDefaultSubscriptionController(context, KEY_SMS_PREF, getSettingsLifecycle(),
this));
} }
@Override @Override

View File

@@ -945,19 +945,15 @@ public class MobileNetworkUtils {
* Returns preferred status of Calls & SMS separately when Provider Model is enabled. * Returns preferred status of Calls & SMS separately when Provider Model is enabled.
*/ */
public static CharSequence getPreferredStatus(boolean isRtlMode, Context context, public static CharSequence getPreferredStatus(boolean isRtlMode, Context context,
SubscriptionManager subscriptionManager, boolean isPreferredCallStatus) { boolean isPreferredCallStatus, List<SubscriptionInfoEntity> entityList) {
final List<SubscriptionInfo> subs = SubscriptionUtil.getActiveSubscriptions( if (entityList != null || !entityList.isEmpty()) {
subscriptionManager);
if (!subs.isEmpty()) {
final StringBuilder summary = new StringBuilder(); final StringBuilder summary = new StringBuilder();
for (SubscriptionInfo subInfo : subs) { for (SubscriptionInfoEntity subInfo : entityList) {
int subsSize = subs.size(); int subsSize = entityList.size();
final CharSequence displayName = SubscriptionUtil.getUniqueSubscriptionDisplayName( final CharSequence displayName = subInfo.uniqueName;
subInfo, context);
// Set displayName as summary if there is only one valid SIM. // Set displayName as summary if there is only one valid SIM.
if (subsSize == 1 if (subsSize == 1 && subInfo.isValidSubscription) {
&& SubscriptionManager.isValidSubscriptionId(subInfo.getSubscriptionId())) {
return displayName; return displayName;
} }
@@ -975,7 +971,7 @@ public class MobileNetworkUtils {
.append(")"); .append(")");
} }
// Do not add ", " for the last subscription. // Do not add ", " for the last subscription.
if (subInfo != subs.get(subs.size() - 1)) { if (subInfo != entityList.get(entityList.size() - 1)) {
summary.append(", "); summary.append(", ");
} }
@@ -989,24 +985,20 @@ public class MobileNetworkUtils {
} }
} }
private static CharSequence getPreferredCallStatus(Context context, SubscriptionInfo subInfo) { private static CharSequence getPreferredCallStatus(Context context,
final int subId = subInfo.getSubscriptionId(); SubscriptionInfoEntity subInfo) {
String status = ""; String status = "";
boolean isDataPreferred = subId == SubscriptionManager.getDefaultVoiceSubscriptionId(); if (subInfo.isDefaultVoiceSubscription) {
if (isDataPreferred) {
status = setSummaryResId(context, R.string.calls_sms_preferred); status = setSummaryResId(context, R.string.calls_sms_preferred);
} }
return status; return status;
} }
private static CharSequence getPreferredSmsStatus(Context context, SubscriptionInfo subInfo) { private static CharSequence getPreferredSmsStatus(Context context,
final int subId = subInfo.getSubscriptionId(); SubscriptionInfoEntity subInfo) {
String status = ""; String status = "";
boolean isSmsPreferred = subId == SubscriptionManager.getDefaultSmsSubscriptionId(); if (subInfo.isDefaultSmsSubscription) {
if (isSmsPreferred) {
status = setSummaryResId(context, R.string.calls_sms_preferred); status = setSummaryResId(context, R.string.calls_sms_preferred);
} }
@@ -1041,7 +1033,7 @@ public class MobileNetworkUtils {
public static void launchMobileNetworkSettings(Context context, SubscriptionInfoEntity info) { public static void launchMobileNetworkSettings(Context context, SubscriptionInfoEntity info) {
final int subId = Integer.valueOf(info.subId); final int subId = Integer.valueOf(info.subId);
if (subId == SubscriptionManager.INVALID_SUBSCRIPTION_ID) { if (!info.isValidSubscription) {
Log.d(TAG, "launchMobileNetworkSettings fail, subId is invalid."); Log.d(TAG, "launchMobileNetworkSettings fail, subId is invalid.");
return; return;
} }

View File

@@ -18,29 +18,39 @@ package com.android.settings.network.telephony;
import android.content.Context; import android.content.Context;
import android.telecom.PhoneAccountHandle; import android.telecom.PhoneAccountHandle;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager; import android.telephony.SubscriptionManager;
import com.android.settings.Utils; import androidx.lifecycle.LifecycleOwner;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
public class SmsDefaultSubscriptionController extends DefaultSubscriptionController { public class SmsDefaultSubscriptionController extends DefaultSubscriptionController {
private final boolean mIsAskEverytimeSupported; private final boolean mIsAskEverytimeSupported;
private SubscriptionInfoEntity mSubscriptionInfoEntity;
public SmsDefaultSubscriptionController(Context context, String preferenceKey) { public SmsDefaultSubscriptionController(Context context, String preferenceKey,
super(context, preferenceKey); Lifecycle lifecycle, LifecycleOwner lifecycleOwner) {
super(context, preferenceKey, lifecycle, lifecycleOwner);
mIsAskEverytimeSupported = mContext.getResources() mIsAskEverytimeSupported = mContext.getResources()
.getBoolean(com.android.internal.R.bool.config_sms_ask_every_time_support); .getBoolean(com.android.internal.R.bool.config_sms_ask_every_time_support);
} }
@Override @Override
protected SubscriptionInfo getDefaultSubscriptionInfo() { protected SubscriptionInfoEntity getDefaultSubscriptionInfo() {
return mManager.getActiveSubscriptionInfo(getDefaultSubscriptionId()); return mSubscriptionInfoEntity;
} }
@Override @Override
protected int getDefaultSubscriptionId() { protected int getDefaultSubscriptionId() {
return SubscriptionManager.getDefaultSmsSubscriptionId(); for (SubscriptionInfoEntity subInfo : mSubInfoEntityList) {
if (subInfo.isActiveSubscriptionId && subInfo.isDefaultSmsSubscription) {
mSubscriptionInfoEntity = subInfo;
return Integer.parseInt(subInfo.subId);
}
}
return SubscriptionManager.INVALID_SUBSCRIPTION_ID;
} }
@Override @Override
@@ -61,6 +71,7 @@ public class SmsDefaultSubscriptionController extends DefaultSubscriptionControl
@Override @Override
public CharSequence getSummary() { public CharSequence getSummary() {
return MobileNetworkUtils.getPreferredStatus(isRtlMode(), mContext, mManager, false); return MobileNetworkUtils.getPreferredStatus(isRtlMode(), mContext, false,
mSubInfoEntityList);
} }
} }

View File

@@ -16,6 +16,8 @@
package com.android.settings.network.telephony; package com.android.settings.network.telephony;
import static androidx.lifecycle.Lifecycle.Event;
import static com.android.settings.core.BasePreferenceController.AVAILABLE; import static com.android.settings.core.BasePreferenceController.AVAILABLE;
import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_UNAVAILABLE; import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_UNAVAILABLE;
@@ -32,15 +34,21 @@ import android.os.Looper;
import android.telecom.TelecomManager; import android.telecom.TelecomManager;
import android.telephony.SubscriptionInfo; import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager; import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.LifecycleRegistry;
import androidx.preference.ListPreference; import androidx.preference.ListPreference;
import androidx.preference.PreferenceManager; import androidx.preference.PreferenceManager;
import androidx.preference.PreferenceScreen; import androidx.preference.PreferenceScreen;
import androidx.test.annotation.UiThreadTest;
import androidx.test.core.app.ApplicationProvider; import androidx.test.core.app.ApplicationProvider;
import androidx.test.ext.junit.runners.AndroidJUnit4; import androidx.test.ext.junit.runners.AndroidJUnit4;
import com.android.settings.network.SubscriptionUtil; import com.android.settings.network.SubscriptionUtil;
import com.android.settings.testutils.ResourcesUtils; import com.android.settings.testutils.ResourcesUtils;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import org.junit.After; import org.junit.After;
import org.junit.Before; import org.junit.Before;
@@ -50,39 +58,74 @@ import org.junit.runner.RunWith;
import org.mockito.Mock; import org.mockito.Mock;
import org.mockito.MockitoAnnotations; import org.mockito.MockitoAnnotations;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.List;
@RunWith(AndroidJUnit4.class) @RunWith(AndroidJUnit4.class)
public class DefaultSubscriptionControllerTest { public class DefaultSubscriptionControllerTest {
private static final String SUB_ID_1 = "1";
private static final String SUB_ID_2 = "2";
private static final String SUB_ID_3 = "3";
private static final String DISPLAY_NAME_1 = "Sub 1";
private static final String DISPLAY_NAME_2 = "Sub 2";
private static final String DISPLAY_NAME_3 = "Sub 3";
private static final String SUB_MCC_1 = "123";
private static final String SUB_MNC_1 = "456";
private static final String SUB_MCC_2 = "223";
private static final String SUB_MNC_2 = "456";
private static final String SUB_MCC_3 = "323";
private static final String SUB_MNC_3 = "456";
private static final String SUB_COUNTRY_ISO_1 = "Sub 1";
private static final String SUB_COUNTRY_ISO_2 = "Sub 2";
private static final String SUB_COUNTRY_ISO_3 = "Sub 3";
@Mock @Mock
private SubscriptionManager mSubMgr; private SubscriptionManager mSubMgr;
@Mock @Mock
private TelecomManager mTelecomManager; private TelecomManager mTelecomManager;
@Mock
private Lifecycle mLifecycle;
@Mock
private LifecycleOwner mLifecycleOwner;
@Mock
private SubscriptionInfoEntity mSubInfo1;
@Mock
private SubscriptionInfoEntity mSubInfo2;
@Mock
private SubscriptionInfoEntity mSubInfo3;
private LifecycleRegistry mLifecycleRegistry;
private PreferenceScreen mScreen; private PreferenceScreen mScreen;
private PreferenceManager mPreferenceManager; private PreferenceManager mPreferenceManager;
private ListPreference mListPreference; private ListPreference mListPreference;
private Context mContext; private Context mContext;
private DefaultSubscriptionController mController; private TestDefaultSubscriptionController mController;
private List<SubscriptionInfoEntity> mSubscriptionInfoEntityList = new ArrayList<>();
@Before @Before
public void setUp() { public void setUp() {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
if (Looper.myLooper() == null) {
Looper.prepare();
}
mContext = spy(ApplicationProvider.getApplicationContext()); mContext = spy(ApplicationProvider.getApplicationContext());
when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mSubMgr); when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mSubMgr);
when(mContext.getSystemService(TelecomManager.class)).thenReturn(mTelecomManager); when(mContext.getSystemService(TelecomManager.class)).thenReturn(mTelecomManager);
final String key = "prefkey"; final String key = "prefkey";
mController = new TestDefaultSubscriptionController(mContext, key); mController = new TestDefaultSubscriptionController(mContext, key, mLifecycle,
mLifecycleOwner);
if (Looper.myLooper() == null) {
Looper.prepare();
}
mPreferenceManager = new PreferenceManager(mContext); mPreferenceManager = new PreferenceManager(mContext);
mScreen = mPreferenceManager.createPreferenceScreen(mContext); mScreen = mPreferenceManager.createPreferenceScreen(mContext);
mListPreference = new ListPreference(mContext); mListPreference = new ListPreference(mContext);
mListPreference.setKey(key); mListPreference.setKey(key);
mScreen.addPreference(mListPreference); mScreen.addPreference(mListPreference);
mLifecycleRegistry = new LifecycleRegistry(mLifecycleOwner);
when(mLifecycleOwner.getLifecycle()).thenReturn(mLifecycleRegistry);
} }
@After @After
@@ -90,6 +133,19 @@ public class DefaultSubscriptionControllerTest {
SubscriptionUtil.setActiveSubscriptionsForTesting(null); SubscriptionUtil.setActiveSubscriptionsForTesting(null);
} }
private SubscriptionInfoEntity setupSubscriptionInfoEntity(String subId, int slotId,
int carrierId, String displayName, String mcc, String mnc, String countryIso,
int cardId, boolean isValid, boolean isActive, boolean isAvailable,
boolean isDefaultCall, boolean isDefaultSms) {
return new SubscriptionInfoEntity(subId, slotId, carrierId,
displayName, displayName, 0, mcc, mnc, countryIso, false, cardId,
TelephonyManager.DEFAULT_PORT_INDEX, false, null,
SubscriptionManager.SUBSCRIPTION_TYPE_LOCAL_SIM, displayName, false,
"1234567890", true, "default", false, isValid,
true, isActive, isAvailable, isDefaultCall,
isDefaultSms, false, false, false);
}
@Test @Test
public void getAvailabilityStatus_twoSubscriptions_isAvailable() { public void getAvailabilityStatus_twoSubscriptions_isAvailable() {
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList( SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(
@@ -105,113 +161,16 @@ public class DefaultSubscriptionControllerTest {
mController.isCallingAccountBindToSubscription(null); mController.isCallingAccountBindToSubscription(null);
} }
@Test
public void getLabelFromCallingAccount_invalidAccount_emptyString() {
doReturn(null).when(mTelecomManager).getPhoneAccount(any());
assertThat(mController.getLabelFromCallingAccount(null)).isEqualTo("");
}
@Ignore
@Test
public void displayPreference_twoSubscriptionsSub1Default_correctListPreferenceValues() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1, sub2));
mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen);
final CharSequence entry = mListPreference.getEntry();
final String value = mListPreference.getValue();
assertThat(entry).isEqualTo("sub1");
assertThat(value).isEqualTo("111");
final CharSequence[] entries = mListPreference.getEntries();
assertThat(entries.length).isEqualTo(3);
assertThat(entries[0]).isEqualTo("sub1");
assertThat(entries[1]).isEqualTo("sub2");
assertThat(entries[2]).isEqualTo(
ResourcesUtils.getResourcesString(mContext, "calls_and_sms_ask_every_time"));
final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entryValues.length).isEqualTo(3);
assertThat(entryValues[0]).isEqualTo("111");
assertThat(entryValues[1]).isEqualTo("222");
assertThat(entryValues[2]).isEqualTo(
Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
}
@Ignore
@Test
public void displayPreference_twoSubscriptionsSub2Default_correctListPreferenceValues() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1, sub2));
mController.setDefaultSubscription(sub2.getSubscriptionId());
mController.displayPreference(mScreen);
final CharSequence entry = mListPreference.getEntry();
final String value = mListPreference.getValue();
assertThat(entry).isEqualTo("sub2");
assertThat(value).isEqualTo("222");
final CharSequence[] entries = mListPreference.getEntries();
assertThat(entries.length).isEqualTo(3);
assertThat(entries[0]).isEqualTo("sub1");
assertThat(entries[1]).isEqualTo("sub2");
assertThat(entries[2]).isEqualTo(
ResourcesUtils.getResourcesString(mContext, "calls_and_sms_ask_every_time"));
final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entryValues.length).isEqualTo(3);
assertThat(entryValues[0]).isEqualTo("111");
assertThat(entryValues[1]).isEqualTo("222");
assertThat(entryValues[2]).isEqualTo(
Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
}
@Ignore
@Test
public void displayPreference_threeSubsOneIsOpportunistic_correctListPreferenceValues() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2");
final SubscriptionInfo sub3 = createMockSub(333, "sub3");
// Mark sub2 as opportunistic; then it should not appear in the list of entries/entryValues.
when(sub2.isOpportunistic()).thenReturn(true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2, sub3));
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(
Arrays.asList(sub1, sub2, sub3));
mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen);
final CharSequence[] entries = mListPreference.getEntries();
assertThat(entries.length).isEqualTo(3);
assertThat(entries[0]).isEqualTo("sub1");
assertThat(entries[1]).isEqualTo("sub3");
assertThat(entries[2]).isEqualTo(
ResourcesUtils.getResourcesString(mContext, "calls_and_sms_ask_every_time"));
final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entryValues.length).isEqualTo(3);
assertThat(entryValues[0]).isEqualTo("111");
assertThat(entryValues[1]).isEqualTo("333");
assertThat(entryValues[2]).isEqualTo(
Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
}
@Test @Test
public void onPreferenceChange_prefChangedToSub2_callbackCalledCorrectly() { public void onPreferenceChange_prefChangedToSub2_callbackCalledCorrectly() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
mController.setDefaultSubscription(sub1.getSubscriptionId()); SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mSubscriptionInfoEntityList.add(mSubInfo1);
mSubscriptionInfoEntityList.add(mSubInfo2);
mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
mListPreference.setValue("222"); mListPreference.setValue("222");
@@ -221,10 +180,14 @@ public class DefaultSubscriptionControllerTest {
@Test @Test
public void onPreferenceChange_prefChangedToAlwaysAsk_callbackCalledCorrectly() { public void onPreferenceChange_prefChangedToAlwaysAsk_callbackCalledCorrectly() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
mController.setDefaultSubscription(sub1.getSubscriptionId()); SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mSubscriptionInfoEntityList.add(mSubInfo1);
mSubscriptionInfoEntityList.add(mSubInfo2);
mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
mListPreference.setValue(Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID)); mListPreference.setValue(Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
@@ -236,61 +199,70 @@ public class DefaultSubscriptionControllerTest {
@Test @Test
public void onPreferenceChange_prefBecomesAvailable_onPreferenceChangeCallbackNotNull() { public void onPreferenceChange_prefBecomesAvailable_onPreferenceChangeCallbackNotNull() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2");
// Start with only one sub active, so the pref is not available // Start with only one sub active, so the pref is not available
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1)); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1)); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
mController.setDefaultSubscription(sub1.getSubscriptionId()); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mSubscriptionInfoEntityList.add(mSubInfo1);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
// Now make two subs be active - the pref should become available, and the // Now make two subs be active - the pref should become available, and the
// onPreferenceChange callback should be properly wired up. // onPreferenceChange callback should be properly wired up.
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); mSubscriptionInfoEntityList.add(mSubInfo2);
mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
mController.onSubscriptionsChanged();
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
mListPreference.callChangeListener("222"); mListPreference.callChangeListener(SUB_ID_2);
assertThat(mController.getDefaultSubscriptionId()).isEqualTo(222); assertThat(mController.getDefaultSubscriptionId()).isEqualTo(2);
} }
@Ignore @Ignore
@Test @Test
public void onSubscriptionsChanged_twoSubscriptionsDefaultChanges_selectedEntryGetsUpdated() { public void onSubscriptionsChanged_twoSubscriptionsDefaultChanges_selectedEntryGetsUpdated() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1, sub2)); SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
mController.setDefaultSubscription(sub1.getSubscriptionId()); mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mSubscriptionInfoEntityList.add(mSubInfo1);
mSubscriptionInfoEntityList.add(mSubInfo2);
mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mListPreference.getEntry()).isEqualTo("sub1"); assertThat(mListPreference.getEntry()).isEqualTo(DISPLAY_NAME_1);
assertThat(mListPreference.getValue()).isEqualTo("111"); assertThat(mListPreference.getValue()).isEqualTo(SUB_ID_1);
mController.setDefaultSubscription(sub2.getSubscriptionId()); mController.setDefaultSubscription(Integer.parseInt(mSubInfo2.subId));
mController.onSubscriptionsChanged(); mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
assertThat(mListPreference.getEntry()).isEqualTo("sub2"); assertThat(mListPreference.getEntry()).isEqualTo(DISPLAY_NAME_2);
assertThat(mListPreference.getValue()).isEqualTo("222"); assertThat(mListPreference.getValue()).isEqualTo(mSubInfo2);
} }
@Test @Test
public void onSubscriptionsChanged_goFromTwoSubscriptionsToOne_prefDisappears() { public void onSubscriptionsChanged_goFromTwoSubscriptionsToOne_prefDisappears() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
mController.setDefaultSubscription(sub1.getSubscriptionId()); SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
mSubscriptionInfoEntityList.add(mSubInfo1);
mSubscriptionInfoEntityList.add(mSubInfo2);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
assertThat(mListPreference.isVisible()).isTrue(); assertThat(mListPreference.isVisible()).isTrue();
assertThat(mListPreference.isEnabled()).isTrue(); assertThat(mListPreference.isEnabled()).isTrue();
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1)); mSubscriptionInfoEntityList.remove(mSubInfo2);
mController.onSubscriptionsChanged(); mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
assertThat(mListPreference.isVisible()).isTrue(); assertThat(mListPreference.isVisible()).isTrue();
@@ -298,21 +270,23 @@ public class DefaultSubscriptionControllerTest {
} }
@Test @Test
@UiThreadTest
public void onSubscriptionsChanged_goFromOneSubscriptionToTwo_prefAppears() { public void onSubscriptionsChanged_goFromOneSubscriptionToTwo_prefAppears() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1)); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1)); SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
mController.setDefaultSubscription(sub1.getSubscriptionId()); mSubscriptionInfoEntityList.add(mSubInfo1);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
assertThat(mListPreference.isVisible()).isTrue(); assertThat(mListPreference.isVisible()).isTrue();
assertThat(mListPreference.isEnabled()).isFalse(); assertThat(mListPreference.isEnabled()).isFalse();
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); mSubscriptionInfoEntityList.add(mSubInfo2);
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1, sub2)); mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
mController.onSubscriptionsChanged(); mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
assertThat(mListPreference.isVisible()).isTrue(); assertThat(mListPreference.isVisible()).isTrue();
@@ -322,34 +296,36 @@ public class DefaultSubscriptionControllerTest {
@Ignore @Ignore
@Test @Test
public void onSubscriptionsChanged_goFromTwoToThreeSubscriptions_listGetsUpdated() { public void onSubscriptionsChanged_goFromTwoToThreeSubscriptions_listGetsUpdated() {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);
final SubscriptionInfo sub3 = createMockSub(333, "sub3"); mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn(Arrays.asList(sub1, sub2)); mSubInfo3 = setupSubscriptionInfoEntity(SUB_ID_3, 1, 1, DISPLAY_NAME_3, SUB_MCC_3,
mController.setDefaultSubscription(sub1.getSubscriptionId()); SUB_MNC_3, SUB_COUNTRY_ISO_3, 1, true, true, true, false, false);
mController.setDefaultSubscription(Integer.parseInt(mSubInfo1.subId));
mSubscriptionInfoEntityList.add(mSubInfo1);
mSubscriptionInfoEntityList.add(mSubInfo2);
mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mListPreference.getEntries().length).isEqualTo(3); assertThat(mListPreference.getEntries().length).isEqualTo(3);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2, sub3)); mSubscriptionInfoEntityList.add(mSubInfo3);
when(mSubMgr.getAvailableSubscriptionInfoList()).thenReturn( mController.onActiveSubInfoChanged(mSubscriptionInfoEntityList);
Arrays.asList(sub1, sub2, sub3));
mController.onSubscriptionsChanged();
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
assertThat(mListPreference.isVisible()).isTrue(); assertThat(mListPreference.isVisible()).isTrue();
final CharSequence[] entries = mListPreference.getEntries(); final CharSequence[] entries = mListPreference.getEntries();
final CharSequence[] entryValues = mListPreference.getEntryValues(); final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entries.length).isEqualTo(4); assertThat(entries.length).isEqualTo(4);
assertThat(entries[0].toString()).isEqualTo("sub1"); assertThat(entries[0].toString()).isEqualTo(DISPLAY_NAME_1);
assertThat(entries[1].toString()).isEqualTo("sub2"); assertThat(entries[1].toString()).isEqualTo(DISPLAY_NAME_2);
assertThat(entries[2].toString()).isEqualTo("sub3"); assertThat(entries[2].toString()).isEqualTo(DISPLAY_NAME_3);
assertThat(entries[3].toString()).isEqualTo( assertThat(entries[3].toString()).isEqualTo(
ResourcesUtils.getResourcesString(mContext, "calls_and_sms_ask_every_time")); ResourcesUtils.getResourcesString(mContext, "calls_and_sms_ask_every_time"));
assertThat(entryValues[0].toString()).isEqualTo("111"); assertThat(entryValues[0].toString()).isEqualTo(SUB_ID_1);
assertThat(entryValues[1].toString()).isEqualTo("222"); assertThat(entryValues[1].toString()).isEqualTo(SUB_ID_2);
assertThat(entryValues[2].toString()).isEqualTo("333"); assertThat(entryValues[2].toString()).isEqualTo(SUB_ID_3);
assertThat(entryValues[3].toString()).isEqualTo( assertThat(entryValues[3].toString()).isEqualTo(
Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID)); Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
} }
@@ -363,13 +339,15 @@ public class DefaultSubscriptionControllerTest {
private class TestDefaultSubscriptionController extends DefaultSubscriptionController { private class TestDefaultSubscriptionController extends DefaultSubscriptionController {
int mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID; int mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID;
private List<SubscriptionInfoEntity> mSubscriptionInfoEntity;
TestDefaultSubscriptionController(Context context, String preferenceKey) { TestDefaultSubscriptionController(Context context, String preferenceKey,
super(context, preferenceKey); Lifecycle lifecycle, LifecycleOwner lifecycleOwner) {
super(context, preferenceKey, lifecycle, lifecycleOwner);
} }
@Override @Override
protected SubscriptionInfo getDefaultSubscriptionInfo() { protected SubscriptionInfoEntity getDefaultSubscriptionInfo() {
return null; return null;
} }
@@ -382,5 +360,14 @@ public class DefaultSubscriptionControllerTest {
protected void setDefaultSubscription(int subscriptionId) { protected void setDefaultSubscription(int subscriptionId) {
mSubId = subscriptionId; mSubId = subscriptionId;
} }
@Override
protected List<SubscriptionInfoEntity> getSubscriptionInfoList() {
return mSubscriptionInfoEntity;
}
public void setSubscriptionInfoList(List<SubscriptionInfoEntity> list) {
mSubscriptionInfoEntity = list;
}
} }
} }