Merge "Revert "Move the auto data switch preference into DDS sim""

This commit is contained in:
TreeHugger Robot
2022-12-02 06:41:39 +00:00
committed by Android (Google) Code Review
2 changed files with 30 additions and 130 deletions

View File

@@ -22,10 +22,8 @@ import static androidx.lifecycle.Lifecycle.Event.ON_RESUME;
import android.content.Context;
import android.os.Handler;
import android.os.Looper;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import android.util.Log;
import androidx.lifecycle.LifecycleObserver;
import androidx.lifecycle.OnLifecycleEvent;
@@ -38,8 +36,6 @@ import com.android.settings.datausage.DataUsageUtils;
import com.android.settings.network.MobileDataContentObserver;
import com.android.settings.network.SubscriptionsChangeListener;
import java.util.List;
/**
* Controls whether switch mobile data to the non-default SIM if the non-default SIM has better
* availability.
@@ -49,88 +45,39 @@ import java.util.List;
* signal/connectivity.
* If this feature is enabled, data will be temporarily enabled on the non-default data SIM,
* including during any voice calls.
*
* Showing this preference in the default data sim UI.
*/
public class AutoDataSwitchPreferenceController extends TelephonyTogglePreferenceController
implements LifecycleObserver,
SubscriptionsChangeListener.SubscriptionsChangeListenerClient {
private static final String TAG = "AutoDataSwitchPreferenceController";
private SwitchPreference mPreference;
private SubscriptionsChangeListener mChangeListener;
private TelephonyManager mManager;
private MobileDataContentObserver mMobileDataContentObserver;
private PreferenceScreen mScreen;
private SubscriptionManager mSubscriptionManager;
private List<SubscriptionInfo> mSubInfoList;
public AutoDataSwitchPreferenceController(Context context,
String preferenceKey) {
super(context, preferenceKey);
mSubscriptionManager = mContext.getSystemService(SubscriptionManager.class);
}
void init(int subId) {
this.mSubId = subId;
if (renewSubscriptionInfoList()) {
// If the subscriptionInfos are changed, then
mManager = mContext.getSystemService(TelephonyManager.class)
.createForSubscriptionId(getNonDdsSubId());
}
if (mMobileDataContentObserver == null) {
mMobileDataContentObserver = new MobileDataContentObserver(
new Handler(Looper.getMainLooper()));
mMobileDataContentObserver.setOnMobileDataChangedListener(() -> {
mManager = mContext.getSystemService(TelephonyManager.class)
.createForSubscriptionId(getNonDdsSubId());
refreshPreference();
});
}
}
private void renewTelephonyComponent() {
if (renewSubscriptionInfoList()) {
// If the subscriptionInfos are changed, then
if (mMobileDataContentObserver != null) {
mMobileDataContentObserver.unRegister(mContext);
}
}
if (mSubInfoList == null) {
Log.d(TAG, "mSubInfoList is null. Stop to register the listener");
return;
}
if (mMobileDataContentObserver != null) {
for (SubscriptionInfo subInfo : mSubInfoList) {
mMobileDataContentObserver.register(mContext, subInfo.getSubscriptionId());
}
}
mManager = mContext.getSystemService(TelephonyManager.class)
.createForSubscriptionId(getNonDdsSubId());
}
/**
* Renew the subscriptionInfoList if the subscriptionInfos are changed.
* @return true if the subscriptionInfos are changed. Otherwise, return false.
*/
private boolean renewSubscriptionInfoList() {
final List<SubscriptionInfo> newSubInfoList =
mSubscriptionManager.getActiveSubscriptionInfoList();
if ((newSubInfoList == null && mSubInfoList == null)
|| (mSubInfoList != null && mSubInfoList.equals(newSubInfoList))) {
return false;
}
mSubInfoList = newSubInfoList;
return true;
mManager = mContext.getSystemService(TelephonyManager.class).createForSubscriptionId(subId);
}
@OnLifecycleEvent(ON_RESUME)
public void onResume() {
renewTelephonyComponent();
if (mChangeListener == null) {
mChangeListener = new SubscriptionsChangeListener(mContext, this);
}
mChangeListener.start();
if (mMobileDataContentObserver == null) {
mMobileDataContentObserver = new MobileDataContentObserver(
new Handler(Looper.getMainLooper()));
mMobileDataContentObserver.setOnMobileDataChangedListener(() -> refreshPreference());
}
mMobileDataContentObserver.register(mContext, mSubId);
}
@OnLifecycleEvent(ON_PAUSE)
@@ -158,10 +105,6 @@ public class AutoDataSwitchPreferenceController extends TelephonyTogglePreferenc
@Override
public boolean setChecked(boolean isChecked) {
if (mManager == null) {
Log.d(TAG, "mManager is null.");
return false;
}
mManager.setMobileDataPolicyEnabled(
TelephonyManager.MOBILE_DATA_POLICY_AUTO_DATA_SWITCH,
isChecked);
@@ -176,8 +119,7 @@ public class AutoDataSwitchPreferenceController extends TelephonyTogglePreferenc
@Override
public int getAvailabilityStatus(int subId) {
if (!SubscriptionManager.isValidSubscriptionId(subId)
|| SubscriptionManager.getDefaultDataSubscriptionId() != subId
|| !SubscriptionManager.isValidSubscriptionId(getNonDdsSubId())
|| SubscriptionManager.getDefaultDataSubscriptionId() == subId
|| (!hasMobileData())) {
return CONDITIONALLY_UNAVAILABLE;
}
@@ -194,12 +136,10 @@ public class AutoDataSwitchPreferenceController extends TelephonyTogglePreferenc
}
@Override
public void onAirplaneModeChanged(boolean airplaneModeEnabled) {
}
public void onAirplaneModeChanged(boolean airplaneModeEnabled) {}
@Override
public void onSubscriptionsChanged() {
renewTelephonyComponent();
updateState(mPreference);
}
@@ -212,23 +152,4 @@ public class AutoDataSwitchPreferenceController extends TelephonyTogglePreferenc
super.displayPreference(mScreen);
}
}
private int getNonDdsSubId() {
int ddsSubId = SubscriptionManager.getDefaultDataSubscriptionId();
Log.d(TAG, "DDS SubId: " + ddsSubId);
if (ddsSubId == SubscriptionManager.INVALID_SUBSCRIPTION_ID) {
return SubscriptionManager.INVALID_SUBSCRIPTION_ID;
}
if (mSubInfoList == null) {
return SubscriptionManager.INVALID_SUBSCRIPTION_ID;
}
return mSubInfoList.stream()
.mapToInt(subInfo -> subInfo.getSubscriptionId())
.filter(subId -> subId != ddsSubId)
.findFirst()
.orElse(SubscriptionManager.INVALID_SUBSCRIPTION_ID);
}
}

View File

@@ -28,18 +28,13 @@ import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;
import static org.robolectric.Shadows.shadowOf;
import android.content.Context;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import androidx.preference.PreferenceScreen;
import androidx.preference.SwitchPreference;
import com.google.common.collect.ImmutableList;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
@@ -61,15 +56,10 @@ public class AutoDataSwitchPreferenceControllerTest {
private TelephonyManager mTelephonyManager;
@Mock
private PreferenceScreen mPreferenceScreen;
@Mock
private SubscriptionInfo mSubscriptionInfo1;
@Mock
private SubscriptionInfo mSubscriptionInfo2;
private Context mContext;
private SwitchPreference mSwitchPreference;
private AutoDataSwitchPreferenceController mController;
private ShadowSubscriptionManager mShadowSubscriptionManager;
@Before
public void setUp() {
@@ -79,11 +69,6 @@ public class AutoDataSwitchPreferenceControllerTest {
when(mTelephonyManager.createForSubscriptionId(anyInt())).thenReturn(mTelephonyManager);
mSwitchPreference = new SwitchPreference(mContext);
when(mPreferenceScreen.findPreference(PREF_KEY)).thenReturn(mSwitchPreference);
when(mSubscriptionInfo1.getSubscriptionId()).thenReturn(SUB_ID_1);
when(mSubscriptionInfo2.getSubscriptionId()).thenReturn(SUB_ID_2);
mShadowSubscriptionManager = shadowOf(mContext.getSystemService(SubscriptionManager.class));
mShadowSubscriptionManager.setActiveSubscriptionInfoList(ImmutableList.of(
mSubscriptionInfo1, mSubscriptionInfo2));
mController = new AutoDataSwitchPreferenceController(mContext, PREF_KEY) {
@Override
protected boolean hasMobileData() {
@@ -105,19 +90,8 @@ public class AutoDataSwitchPreferenceControllerTest {
}
@Test
public void displayPreference_defaultForData_available() {
public void displayPreference_defaultForData_notAvailable() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.init(SUB_ID_1);
mController.displayPreference(mPreferenceScreen);
assertThat(mController.isAvailable()).isTrue();
assertThat(mSwitchPreference.isVisible()).isTrue();
}
@Test
public void displayPreference_notDefaultForData_notAvailable() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_2);
mController.displayPreference(mPreferenceScreen);
@@ -126,25 +100,21 @@ public class AutoDataSwitchPreferenceControllerTest {
}
@Test
public void onSubscriptionsChanged_becomesDefaultForData_available() {
public void displayPreference_notDefaultForData_available() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_2);
mController.init(SUB_ID_1);
mController.displayPreference(mPreferenceScreen);
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.onSubscriptionsChanged();
assertThat(mController.isAvailable()).isTrue();
assertThat(mSwitchPreference.isVisible()).isTrue();
}
@Test
public void onSubscriptionsChanged_noLongerDefaultForData_notAvailable() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.init(SUB_ID_1);
public void onSubscriptionsChanged_becomesDefaultForData_notAvailable() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_2);
mController.displayPreference(mPreferenceScreen);
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_2);
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.onSubscriptionsChanged();
assertThat(mController.isAvailable()).isFalse();
@@ -152,25 +122,34 @@ public class AutoDataSwitchPreferenceControllerTest {
}
@Test
public void getAvailabilityStatus_mobileDataChangWithDefaultDataSubId_returnAvailable() {
public void onSubscriptionsChanged_noLongerDefaultForData_available() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.displayPreference(mPreferenceScreen);
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_2);
mController.onSubscriptionsChanged();
assertThat(mController.isAvailable()).isTrue();
assertThat(mSwitchPreference.isVisible()).isTrue();
}
@Test
public void getAvailabilityStatus_mobileDataChangWithDefaultDataSubId_returnUnavailable() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.init(SUB_ID_1);
mController.refreshPreference();
assertThat(mController.getAvailabilityStatus(SUB_ID_1))
.isEqualTo(AVAILABLE);
.isEqualTo(CONDITIONALLY_UNAVAILABLE);
}
@Test
public void getAvailabilityStatus_mobileDataChangWithoutDefaultDataSubId_returnUnavailable() {
public void getAvailabilityStatus_mobileDataChangWithoutDefaultDataSubId_returnAvailable() {
ShadowSubscriptionManager.setDefaultDataSubscriptionId(SUB_ID_1);
mController.init(SUB_ID_1);
mController.displayPreference(mPreferenceScreen);
mController.refreshPreference();
assertThat(mController.getAvailabilityStatus(SUB_ID_2)).isEqualTo(
CONDITIONALLY_UNAVAILABLE);
assertThat(mController.getAvailabilityStatus(SUB_ID_2)).isEqualTo(AVAILABLE);
}
}