[Settings] Fix CellDataPreferenceTest
Fix CellDataPreferenceTest Bug: 154562715 Test: make RunSettingsRoboTests -j ROBOTEST_FILTER=CellDataPreferenceTest Change-Id: Ia0ee0f5cd802ca9b6827bddcaf189c619d268074
This commit is contained in:
@@ -50,15 +50,12 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
public int mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID;
|
public int mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID;
|
||||||
public boolean mChecked;
|
public boolean mChecked;
|
||||||
public boolean mMultiSimDialog;
|
public boolean mMultiSimDialog;
|
||||||
@VisibleForTesting
|
|
||||||
ProxySubscriptionManager mProxySubscriptionMgr;
|
|
||||||
private MobileDataEnabledListener mDataStateListener;
|
private MobileDataEnabledListener mDataStateListener;
|
||||||
|
|
||||||
public CellDataPreference(Context context, AttributeSet attrs) {
|
public CellDataPreference(Context context, AttributeSet attrs) {
|
||||||
super(context, attrs, TypedArrayUtils.getAttr(context,
|
super(context, attrs, TypedArrayUtils.getAttr(context,
|
||||||
androidx.preference.R.attr.switchPreferenceStyle,
|
androidx.preference.R.attr.switchPreferenceStyle,
|
||||||
android.R.attr.switchPreferenceStyle));
|
android.R.attr.switchPreferenceStyle));
|
||||||
mProxySubscriptionMgr = ProxySubscriptionManager.getInstance(context);
|
|
||||||
mDataStateListener = new MobileDataEnabledListener(context, this);
|
mDataStateListener = new MobileDataEnabledListener(context, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -88,13 +85,15 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
public void onAttached() {
|
public void onAttached() {
|
||||||
super.onAttached();
|
super.onAttached();
|
||||||
mDataStateListener.start(mSubId);
|
mDataStateListener.start(mSubId);
|
||||||
mProxySubscriptionMgr.addActiveSubscriptionsListener(mOnSubscriptionsChangeListener);
|
getProxySubscriptionManager()
|
||||||
|
.addActiveSubscriptionsListener(mOnSubscriptionsChangeListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onDetached() {
|
public void onDetached() {
|
||||||
mDataStateListener.stop();
|
mDataStateListener.stop();
|
||||||
mProxySubscriptionMgr.removeActiveSubscriptionsListener(mOnSubscriptionsChangeListener);
|
getProxySubscriptionManager()
|
||||||
|
.removeActiveSubscriptionsListener(mOnSubscriptionsChangeListener);
|
||||||
super.onDetached();
|
super.onDetached();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -104,8 +103,8 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
throw new IllegalArgumentException("CellDataPreference needs a SubscriptionInfo");
|
throw new IllegalArgumentException("CellDataPreference needs a SubscriptionInfo");
|
||||||
}
|
}
|
||||||
|
|
||||||
mProxySubscriptionMgr = ProxySubscriptionManager.getInstance(getContext());
|
getProxySubscriptionManager()
|
||||||
mProxySubscriptionMgr.addActiveSubscriptionsListener(mOnSubscriptionsChangeListener);
|
.addActiveSubscriptionsListener(mOnSubscriptionsChangeListener);
|
||||||
|
|
||||||
if (mSubId == SubscriptionManager.INVALID_SUBSCRIPTION_ID) {
|
if (mSubId == SubscriptionManager.INVALID_SUBSCRIPTION_ID) {
|
||||||
mSubId = subId;
|
mSubId = subId;
|
||||||
@@ -115,6 +114,16 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
updateChecked();
|
updateChecked();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
ProxySubscriptionManager getProxySubscriptionManager() {
|
||||||
|
return ProxySubscriptionManager.getInstance(getContext());
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
SubscriptionInfo getActiveSubscriptionInfo(int subId) {
|
||||||
|
return getProxySubscriptionManager().getActiveSubscriptionInfo(subId);
|
||||||
|
}
|
||||||
|
|
||||||
private void updateChecked() {
|
private void updateChecked() {
|
||||||
setChecked(getContext().getSystemService(TelephonyManager.class).getDataEnabled(mSubId));
|
setChecked(getContext().getSystemService(TelephonyManager.class).getDataEnabled(mSubId));
|
||||||
}
|
}
|
||||||
@@ -122,7 +131,7 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
private void updateEnabled() {
|
private void updateEnabled() {
|
||||||
// If this subscription is not active, for example, SIM card is taken out, we disable
|
// If this subscription is not active, for example, SIM card is taken out, we disable
|
||||||
// the button.
|
// the button.
|
||||||
setEnabled(mProxySubscriptionMgr.getActiveSubscriptionInfo(mSubId) != null);
|
setEnabled(getActiveSubscriptionInfo(mSubId) != null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -130,9 +139,8 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
final Context context = getContext();
|
final Context context = getContext();
|
||||||
FeatureFactory.getFactory(context).getMetricsFeatureProvider()
|
FeatureFactory.getFactory(context).getMetricsFeatureProvider()
|
||||||
.action(context, SettingsEnums.ACTION_CELL_DATA_TOGGLE, !mChecked);
|
.action(context, SettingsEnums.ACTION_CELL_DATA_TOGGLE, !mChecked);
|
||||||
final SubscriptionInfo currentSir = mProxySubscriptionMgr.getActiveSubscriptionInfo(
|
final SubscriptionInfo currentSir = getActiveSubscriptionInfo(mSubId);
|
||||||
mSubId);
|
final SubscriptionInfo nextSir = getActiveSubscriptionInfo(
|
||||||
final SubscriptionInfo nextSir = mProxySubscriptionMgr.getActiveSubscriptionInfo(
|
|
||||||
SubscriptionManager.getDefaultDataSubscriptionId());
|
SubscriptionManager.getDefaultDataSubscriptionId());
|
||||||
if (mChecked) {
|
if (mChecked) {
|
||||||
setMobileDataEnabled(false);
|
setMobileDataEnabled(false);
|
||||||
@@ -186,9 +194,8 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
|
|
||||||
private void showMultiSimDialog(Builder builder,
|
private void showMultiSimDialog(Builder builder,
|
||||||
DialogInterface.OnClickListener listener) {
|
DialogInterface.OnClickListener listener) {
|
||||||
final SubscriptionInfo currentSir = mProxySubscriptionMgr.getActiveSubscriptionInfo(
|
final SubscriptionInfo currentSir = getActiveSubscriptionInfo(mSubId);
|
||||||
mSubId);
|
final SubscriptionInfo nextSir = getActiveSubscriptionInfo(
|
||||||
final SubscriptionInfo nextSir = mProxySubscriptionMgr.getActiveSubscriptionInfo(
|
|
||||||
SubscriptionManager.getDefaultDataSubscriptionId());
|
SubscriptionManager.getDefaultDataSubscriptionId());
|
||||||
|
|
||||||
final String previousName = (nextSir == null)
|
final String previousName = (nextSir == null)
|
||||||
@@ -205,8 +212,7 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void disableDataForOtherSubscriptions(int subId) {
|
private void disableDataForOtherSubscriptions(int subId) {
|
||||||
final SubscriptionInfo subInfo = mProxySubscriptionMgr.getActiveSubscriptionInfo(
|
final SubscriptionInfo subInfo = getActiveSubscriptionInfo(subId);
|
||||||
subId);
|
|
||||||
if (subInfo != null) {
|
if (subInfo != null) {
|
||||||
getContext().getSystemService(TelephonyManager.class).setDataEnabled(subId, false);
|
getContext().getSystemService(TelephonyManager.class).setDataEnabled(subId, false);
|
||||||
}
|
}
|
||||||
@@ -218,7 +224,7 @@ public class CellDataPreference extends CustomDialogPreferenceCompat
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (mMultiSimDialog) {
|
if (mMultiSimDialog) {
|
||||||
mProxySubscriptionMgr.get().setDefaultDataSubId(mSubId);
|
getProxySubscriptionManager().get().setDefaultDataSubId(mSubId);
|
||||||
setMobileDataEnabled(true);
|
setMobileDataEnabled(true);
|
||||||
disableDataForOtherSubscriptions(mSubId);
|
disableDataForOtherSubscriptions(mSubId);
|
||||||
} else {
|
} else {
|
||||||
|
@@ -17,11 +17,14 @@ package com.android.settings.datausage;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyInt;
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
|
import static org.mockito.Mockito.doNothing;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.telephony.SubscriptionInfo;
|
import android.telephony.SubscriptionInfo;
|
||||||
|
import android.telephony.SubscriptionManager;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
@@ -31,7 +34,6 @@ import androidx.preference.PreferenceViewHolder;
|
|||||||
import com.android.settings.network.ProxySubscriptionManager;
|
import com.android.settings.network.ProxySubscriptionManager;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
@@ -40,12 +42,13 @@ import org.robolectric.RobolectricTestRunner;
|
|||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
@Ignore
|
|
||||||
public class CellDataPreferenceTest {
|
public class CellDataPreferenceTest {
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private ProxySubscriptionManager mProxySubscriptionMgr;
|
private ProxySubscriptionManager mProxySubscriptionMgr;
|
||||||
@Mock
|
@Mock
|
||||||
|
private SubscriptionManager mSubscriptionManager;
|
||||||
|
@Mock
|
||||||
private SubscriptionInfo mSubInfo;
|
private SubscriptionInfo mSubInfo;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@@ -57,8 +60,20 @@ public class CellDataPreferenceTest {
|
|||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mPreference = new CellDataPreference(mContext, null);
|
mPreference = new CellDataPreference(mContext, null) {
|
||||||
mPreference.mProxySubscriptionMgr = mProxySubscriptionMgr;
|
@Override
|
||||||
|
ProxySubscriptionManager getProxySubscriptionManager() {
|
||||||
|
return mProxySubscriptionMgr;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
SubscriptionInfo getActiveSubscriptionInfo(int subId) {
|
||||||
|
return mSubInfo;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
doNothing().when(mSubscriptionManager).setDefaultDataSubId(anyInt());
|
||||||
|
doReturn(mSubscriptionManager).when(mProxySubscriptionMgr).get();
|
||||||
|
doNothing().when(mProxySubscriptionMgr).addActiveSubscriptionsListener(any());
|
||||||
|
doNothing().when(mProxySubscriptionMgr).removeActiveSubscriptionsListener(any());
|
||||||
|
|
||||||
final LayoutInflater inflater = LayoutInflater.from(mContext);
|
final LayoutInflater inflater = LayoutInflater.from(mContext);
|
||||||
final View view = inflater.inflate(mPreference.getLayoutResource(),
|
final View view = inflater.inflate(mPreference.getLayoutResource(),
|
||||||
@@ -69,14 +84,13 @@ public class CellDataPreferenceTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void noActiveSub_shouldDisable() {
|
public void noActiveSub_shouldDisable() {
|
||||||
doReturn(null).when(mProxySubscriptionMgr).getActiveSubscriptionInfo(anyInt());
|
mSubInfo = null;
|
||||||
mPreference.mOnSubscriptionsChangeListener.onChanged();
|
mPreference.mOnSubscriptionsChangeListener.onChanged();
|
||||||
assertThat(mPreference.isEnabled()).isFalse();
|
assertThat(mPreference.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void hasActiveSub_shouldEnable() {
|
public void hasActiveSub_shouldEnable() {
|
||||||
doReturn(mSubInfo).when(mProxySubscriptionMgr).getActiveSubscriptionInfo(anyInt());
|
|
||||||
mPreference.mOnSubscriptionsChangeListener.onChanged();
|
mPreference.mOnSubscriptionsChangeListener.onChanged();
|
||||||
assertThat(mPreference.isEnabled()).isTrue();
|
assertThat(mPreference.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user