Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 605754ef authored by Zoey Chen's avatar Zoey Chen
Browse files

[Settings] Change the way in NetworkProviderCallsSmsController for getting the...

[Settings] Change the way in NetworkProviderCallsSmsController for getting the subscription info from room db part2

Bug: 236919685
Test: atest NetworkProviderCallsSmsControllerTest
Change-Id: Ibbfa1fed15ea4fa38cff38d78855326e3d74fe0e
parent a87affdb
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -121,7 +121,7 @@ public class NetworkDashboardFragment extends DashboardFragment implements
            controllers.add(internetPreferenceController);
            controllers.add(internetPreferenceController);
        }
        }
        controllers.add(privateDnsPreferenceController);
        controllers.add(privateDnsPreferenceController);
        controllers.add(new NetworkProviderCallsSmsController(context, lifecycle));
        controllers.add(new NetworkProviderCallsSmsController(context, lifecycle, lifecycleOwner));
        return controllers;
        return controllers;
    }
    }


+56 −42
Original line number Original line Diff line number Diff line
@@ -21,13 +21,13 @@ import static androidx.lifecycle.Lifecycle.Event;
import android.content.Context;
import android.content.Context;
import android.os.UserManager;
import android.os.UserManager;
import android.telephony.ServiceState;
import android.telephony.ServiceState;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import android.telephony.TelephonyManager;
import android.util.Log;
import android.view.View;
import android.view.View;


import androidx.annotation.VisibleForTesting;
import androidx.annotation.VisibleForTesting;
import androidx.lifecycle.LifecycleObserver;
import androidx.lifecycle.LifecycleObserver;
import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.OnLifecycleEvent;
import androidx.lifecycle.OnLifecycleEvent;
import androidx.preference.Preference;
import androidx.preference.Preference;
import androidx.preference.PreferenceScreen;
import androidx.preference.PreferenceScreen;
@@ -37,50 +37,55 @@ 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.MobileNetworkInfoEntity;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;
import com.android.settingslib.mobile.dataservice.UiccInfoEntity;


import java.util.List;
import java.util.List;


public class NetworkProviderCallsSmsController extends AbstractPreferenceController implements
public class NetworkProviderCallsSmsController extends AbstractPreferenceController implements
        SubscriptionsChangeListener.SubscriptionsChangeListenerClient, LifecycleObserver {
        LifecycleObserver, MobileNetworkRepository.MobileNetworkCallback {


    private static final String TAG = "NetworkProviderCallsSmsController";
    private static final String TAG = "NetworkProviderCallsSmsController";
    private static final String KEY = "calls_and_sms";
    private static final String KEY = "calls_and_sms";
    private static final String RTL_MARK = "\u200F";
    private static final String RTL_MARK = "\u200F";


    private UserManager mUserManager;
    private UserManager mUserManager;
    private SubscriptionManager mSubscriptionManager;
    private SubscriptionsChangeListener mSubscriptionsChangeListener;
    private TelephonyManager mTelephonyManager;
    private TelephonyManager mTelephonyManager;
    private RestrictedPreference mPreference;
    private RestrictedPreference mPreference;
    private boolean mIsRtlMode;
    private boolean mIsRtlMode;
    private LifecycleOwner mLifecycleOwner;
    private MobileNetworkRepository mMobileNetworkRepository;
    private List<SubscriptionInfoEntity> mSubInfoEntityList;


    /**
    /**
     * The summary text and click behavior of the "Calls & SMS" item on the
     * The summary text and click behavior of the "Calls & SMS" item on the
     * Network & internet page.
     * Network & internet page.
     */
     */
    public NetworkProviderCallsSmsController(Context context, Lifecycle lifecycle) {
    public NetworkProviderCallsSmsController(Context context, Lifecycle lifecycle,
            LifecycleOwner lifecycleOwner) {
        super(context);
        super(context);


        mUserManager = context.getSystemService(UserManager.class);
        mUserManager = context.getSystemService(UserManager.class);
        mSubscriptionManager = context.getSystemService(SubscriptionManager.class);
        mTelephonyManager = mContext.getSystemService(TelephonyManager.class);
        mTelephonyManager = mContext.getSystemService(TelephonyManager.class);
        mIsRtlMode = context.getResources().getConfiguration().getLayoutDirection()
        mIsRtlMode = context.getResources().getConfiguration().getLayoutDirection()
                == View.LAYOUT_DIRECTION_RTL;
                == View.LAYOUT_DIRECTION_RTL;
        mLifecycleOwner = lifecycleOwner;
        mMobileNetworkRepository = new MobileNetworkRepository(context, this);
        if (lifecycle != null) {
        if (lifecycle != null) {
            mSubscriptionsChangeListener = new SubscriptionsChangeListener(context, this);
            lifecycle.addObserver(this);
            lifecycle.addObserver(this);
        }
        }
    }
    }


    @OnLifecycleEvent(Event.ON_RESUME)
    @OnLifecycleEvent(Event.ON_RESUME)
    public void onResume() {
    public void onResume() {
        mSubscriptionsChangeListener.start();
        mMobileNetworkRepository.addRegister(mLifecycleOwner);
        update();
        update();
    }
    }


    @OnLifecycleEvent(Event.ON_PAUSE)
    @OnLifecycleEvent(Event.ON_PAUSE)
    public void onPause() {
    public void onPause() {
        mSubscriptionsChangeListener.stop();
        mMobileNetworkRepository.removeRegister();
    }
    }


    @Override
    @Override
@@ -91,27 +96,24 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl


    @Override
    @Override
    public CharSequence getSummary() {
    public CharSequence getSummary() {
        final List<SubscriptionInfo> subs = SubscriptionUtil.getActiveSubscriptions(
        List<SubscriptionInfoEntity> list = getSubscriptionInfoList();
                mSubscriptionManager);
        if (list == null || list .isEmpty()) {

        if (subs.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();
            for (SubscriptionInfo subInfo : subs) {
            for (SubscriptionInfoEntity subInfo : list) {
                int subsSize = subs.size();
                int subsSize = list.size();
                int subId = subInfo.getSubscriptionId();
                int subId = Integer.parseInt(subInfo.subId);
                final CharSequence displayName = SubscriptionUtil.getUniqueSubscriptionDisplayName(
                final CharSequence displayName = subInfo.uniqueName;
                        subInfo, mContext);


                // 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
                        && SubscriptionManager.isValidSubscriptionId(subId)
                        && list.get(0).isValidSubscription
                        && isInService(subId)) {
                        && isInService(subId)) {
                    return displayName;
                    return displayName;
                }
                }


                CharSequence status = getPreferredStatus(subsSize, subId);
                CharSequence status = getPreferredStatus(subInfo, subsSize, subId);
                if (status.toString().isEmpty()) {
                if (status.toString().isEmpty()) {
                    // If there are 2 or more SIMs and one of these has no preferred status,
                    // If there are 2 or more SIMs and one of these has no preferred status,
                    // set only its displayName as summary.
                    // set only its displayName as summary.
@@ -123,7 +125,7 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
                            .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.equals(list.get(list.size() - 1))) {
                    summary.append(", ");
                    summary.append(", ");
                }
                }


@@ -136,12 +138,13 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
    }
    }


    @VisibleForTesting
    @VisibleForTesting
    protected CharSequence getPreferredStatus(int subsSize, int subId) {
    protected CharSequence getPreferredStatus(SubscriptionInfoEntity subInfo, int subsSize,
            int subId) {
        String status = "";
        String status = "";
        boolean isDataPreferred = subId == getDefaultVoiceSubscriptionId();
        boolean isDataPreferred = subInfo.isDefaultVoiceSubscription;
        boolean isSmsPreferred = subId == getDefaultSmsSubscriptionId();
        boolean isSmsPreferred = subInfo.isDefaultSmsSubscription;


        if (!SubscriptionManager.isValidSubscriptionId(subId) || !isInService(subId)) {
        if (!subInfo.isValidSubscription || !isInService(subId)) {
            status = setSummaryResId(subsSize > 1 ? R.string.calls_sms_unavailable :
            status = setSummaryResId(subsSize > 1 ? R.string.calls_sms_unavailable :
                    R.string.calls_sms_temp_unavailable);
                    R.string.calls_sms_temp_unavailable);
        } else {
        } else {
@@ -161,13 +164,8 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
    }
    }


    @VisibleForTesting
    @VisibleForTesting
    protected int getDefaultVoiceSubscriptionId() {
    protected List<SubscriptionInfoEntity> getSubscriptionInfoList() {
        return SubscriptionManager.getDefaultVoiceSubscriptionId();
        return mSubInfoEntityList;
    }

    @VisibleForTesting
    protected int getDefaultSmsSubscriptionId() {
        return SubscriptionManager.getDefaultSmsSubscriptionId();
    }
    }


    private void update() {
    private void update() {
@@ -178,9 +176,7 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
        mPreference.setOnPreferenceClickListener(null);
        mPreference.setOnPreferenceClickListener(null);
        mPreference.setFragment(null);
        mPreference.setFragment(null);


        final List<SubscriptionInfo> subs = SubscriptionUtil.getActiveSubscriptions(
        if (mSubInfoEntityList == null || mSubInfoEntityList.isEmpty()) {
                mSubscriptionManager);
        if (subs.isEmpty()) {
            mPreference.setEnabled(false);
            mPreference.setEnabled(false);
        } else {
        } else {
            mPreference.setEnabled(true);
            mPreference.setEnabled(true);
@@ -213,16 +209,34 @@ public class NetworkProviderCallsSmsController extends AbstractPreferenceControl
        update();
        update();
    }
    }


    @Override
    public void onSubscriptionsChanged() {
        refreshSummary(mPreference);
        update();
    }

    @VisibleForTesting
    @VisibleForTesting
    protected boolean isInService(int subId) {
    protected boolean isInService(int subId) {
        ServiceState serviceState =
        ServiceState serviceState =
                mTelephonyManager.createForSubscriptionId(subId).getServiceState();
                mTelephonyManager.createForSubscriptionId(subId).getServiceState();
        return Utils.isInService(serviceState);
        return Utils.isInService(serviceState);
    }
    }

    @Override
    public void onAvailableSubInfoChanged(List<SubscriptionInfoEntity> subInfoEntityList) {
    }

    @Override
    public void onActiveSubInfoChanged(List<SubscriptionInfoEntity> activeSubInfoList) {
        if ((mSubInfoEntityList != null &&
                (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;
            update();
        }
    }

    @Override
    public void onAllUiccInfoChanged(List<UiccInfoEntity> uiccInfoEntityList) {
    }

    @Override
    public void onAllMobileNetworkInfoChanged(
            List<MobileNetworkInfoEntity> mobileNetworkInfoEntityList) {
    }
}
}
+93 −92
Original line number Original line Diff line number Diff line
@@ -21,7 +21,6 @@ import static androidx.lifecycle.Lifecycle.Event;
import static com.google.common.truth.Truth.assertThat;
import static com.google.common.truth.Truth.assertThat;


import static org.junit.Assert.assertTrue;
import static org.junit.Assert.assertTrue;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;
import static org.mockito.Mockito.when;


@@ -29,6 +28,7 @@ import android.content.Context;
import android.os.Looper;
import android.os.Looper;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager;
import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import android.text.TextUtils;
import android.text.TextUtils;


import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.LifecycleOwner;
@@ -42,6 +42,7 @@ import androidx.test.ext.junit.runners.AndroidJUnit4;
import com.android.settings.testutils.ResourcesUtils;
import com.android.settings.testutils.ResourcesUtils;
import com.android.settingslib.RestrictedPreference;
import com.android.settingslib.RestrictedPreference;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.mobile.dataservice.SubscriptionInfoEntity;


import org.junit.Before;
import org.junit.Before;
import org.junit.Test;
import org.junit.Test;
@@ -50,58 +51,63 @@ import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.mockito.MockitoAnnotations;


import java.util.ArrayList;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;




@RunWith(AndroidJUnit4.class)
@RunWith(AndroidJUnit4.class)
public class NetworkProviderCallsSmsControllerTest {
public class NetworkProviderCallsSmsControllerTest {


    private static final int SUB_ID_1 = 1;
    private static final String SUB_ID_1 = "1";
    private static final int SUB_ID_2 = 2;
    private static final String SUB_ID_2 = "2";
    private static final String INVALID_SUB_ID = "-1";
    private static final String KEY_PREFERENCE_CALLS_SMS = "calls_and_sms";
    private static final String KEY_PREFERENCE_CALLS_SMS = "calls_and_sms";
    private static final String DISPLAY_NAME_1 = "Sub 1";
    private static final String DISPLAY_NAME_1 = "Sub 1";
    private static final String DISPLAY_NAME_2 = "Sub 2";
    private static final String DISPLAY_NAME_2 = "Sub 2";
    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_COUNTRY_ISO_1 = "Sub 1";
    private static final String SUB_COUNTRY_ISO_2 = "Sub 2";


    @Mock
    @Mock
    private SubscriptionManager mSubscriptionManager;
    private SubscriptionInfoEntity mSubInfo1;
    @Mock
    @Mock
    private SubscriptionInfo mSubscriptionInfo1;
    private SubscriptionInfoEntity mSubInfo2;
    @Mock
    private SubscriptionInfo mSubscriptionInfo2;
    @Mock
    @Mock
    private Lifecycle mLifecycle;
    private Lifecycle mLifecycle;
    @Mock
    @Mock
    private LifecycleOwner mLifecycleOwner;
    private LifecycleOwner mLifecycleOwner;
    private LifecycleRegistry mLifecycleRegistry;


    private LifecycleRegistry mLifecycleRegistry;
    private MockNetworkProviderCallsSmsController mController;
    private MockNetworkProviderCallsSmsController mController;
    private PreferenceManager mPreferenceManager;
    private PreferenceManager mPreferenceManager;
    private PreferenceScreen mPreferenceScreen;
    private PreferenceScreen mPreferenceScreen;
    private RestrictedPreference mPreference;
    private RestrictedPreference mPreference;

    private Context mContext;
    private Context mContext;
    private List<SubscriptionInfoEntity> mSubscriptionInfoEntityList = new ArrayList<>();


    /**
    /**
     * Mock the NetworkProviderCallsSmsController that allows allows one to set a default voice
     * Mock the NetworkProviderCallsSmsController that allows one to set a default voice
     * and SMS subscription ID.
     * and SMS subscription ID.
     */
     */
    private class MockNetworkProviderCallsSmsController extends
    private class MockNetworkProviderCallsSmsController extends
            com.android.settings.network.NetworkProviderCallsSmsController {
            com.android.settings.network.NetworkProviderCallsSmsController {
        public MockNetworkProviderCallsSmsController(Context context, Lifecycle lifecycle) {
        public MockNetworkProviderCallsSmsController(Context context, Lifecycle lifecycle,
            super(context, lifecycle);
                LifecycleOwner lifecycleOwner) {
            super(context, lifecycle, lifecycleOwner);
        }
        }


        private int mDefaultVoiceSubscriptionId;
        private List<SubscriptionInfoEntity> mSubscriptionInfoEntity;
        private int mDefaultSmsSubscriptionId;
        private boolean mIsInService;
        private boolean mIsInService;

        @Override
        @Override
        protected int getDefaultVoiceSubscriptionId() {
        protected List<SubscriptionInfoEntity> getSubscriptionInfoList() {
            return mDefaultVoiceSubscriptionId;
            return mSubscriptionInfoEntity;
        }
        }


        @Override
        public void setSubscriptionInfoList(List<SubscriptionInfoEntity> list) {
        protected int getDefaultSmsSubscriptionId() {
            mSubscriptionInfoEntity = list;
            return mDefaultSmsSubscriptionId;
        }
        }


        @Override
        @Override
@@ -109,14 +115,6 @@ public class NetworkProviderCallsSmsControllerTest {
            return mIsInService;
            return mIsInService;
        }
        }


        public void setDefaultVoiceSubscriptionId(int subscriptionId) {
            mDefaultVoiceSubscriptionId = subscriptionId;
        }

        public void setDefaultSmsSubscriptionId(int subscriptionId) {
            mDefaultSmsSubscriptionId = subscriptionId;
        }

        public void setInService(boolean inService) {
        public void setInService(boolean inService) {
            mIsInService = inService;
            mIsInService = inService;
        }
        }
@@ -126,7 +124,6 @@ public class NetworkProviderCallsSmsControllerTest {
    public void setUp() {
    public void setUp() {
        MockitoAnnotations.initMocks(this);
        MockitoAnnotations.initMocks(this);
        mContext = spy(ApplicationProvider.getApplicationContext());
        mContext = spy(ApplicationProvider.getApplicationContext());
        when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mSubscriptionManager);


        if (Looper.myLooper() == null) {
        if (Looper.myLooper() == null) {
            Looper.prepare();
            Looper.prepare();
@@ -136,7 +133,8 @@ public class NetworkProviderCallsSmsControllerTest {
        mPreferenceScreen = mPreferenceManager.createPreferenceScreen(mContext);
        mPreferenceScreen = mPreferenceManager.createPreferenceScreen(mContext);
        mPreference = new RestrictedPreference(mContext);
        mPreference = new RestrictedPreference(mContext);
        mPreference.setKey(KEY_PREFERENCE_CALLS_SMS);
        mPreference.setKey(KEY_PREFERENCE_CALLS_SMS);
        mController = new MockNetworkProviderCallsSmsController(mContext, mLifecycle);
        mController = new MockNetworkProviderCallsSmsController(mContext, mLifecycle,
                mLifecycleOwner);
        mController.setInService(true);
        mController.setInService(true);
        mLifecycleRegistry = new LifecycleRegistry(mLifecycleOwner);
        mLifecycleRegistry = new LifecycleRegistry(mLifecycleOwner);
        when(mLifecycleOwner.getLifecycle()).thenReturn(mLifecycleRegistry);
        when(mLifecycleOwner.getLifecycle()).thenReturn(mLifecycleRegistry);
@@ -149,13 +147,6 @@ public class NetworkProviderCallsSmsControllerTest {
        mLifecycleRegistry.handleLifecycleEvent(Event.ON_RESUME);
        mLifecycleRegistry.handleLifecycleEvent(Event.ON_RESUME);
    }
    }


    private void setupSubscriptionInfoList(int subId, String displayName,
                                           SubscriptionInfo subscriptionInfo) {
        when(subscriptionInfo.getSubscriptionId()).thenReturn(subId);
        doReturn(subscriptionInfo).when(mSubscriptionManager).getActiveSubscriptionInfo(subId);
        when(subscriptionInfo.getDisplayName()).thenReturn(displayName);
    }

    private String setSummaryResId(String resName) {
    private String setSummaryResId(String resName) {
        return ResourcesUtils.getResourcesString(mContext, resName);
        return ResourcesUtils.getResourcesString(mContext, resName);
    }
    }
@@ -163,23 +154,36 @@ public class NetworkProviderCallsSmsControllerTest {
    @Test
    @Test
    @UiThreadTest
    @UiThreadTest
    public void getSummary_noSim_returnNoSim() {
    public void getSummary_noSim_returnNoSim() {
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(new ArrayList<>());
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(new ArrayList<>());
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        assertTrue(TextUtils.equals(mController.getSummary(),
        assertTrue(TextUtils.equals(mController.getSummary(),
                setSummaryResId("calls_sms_no_sim")));
                setSummaryResId("calls_sms_no_sim")));
    }
    }


    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);
    }

    @Test
    @Test
    @UiThreadTest
    @UiThreadTest
    public void getSummary_invalidSubId_returnUnavailable() {
    public void getSummary_invalidSubId_returnUnavailable() {
        setupSubscriptionInfoList(SubscriptionManager.INVALID_SUBSCRIPTION_ID, DISPLAY_NAME_1,

                mSubscriptionInfo1);
        mSubInfo1 = setupSubscriptionInfoEntity(INVALID_SUB_ID,
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
                SubscriptionManager.INVALID_SIM_SLOT_INDEX, TelephonyManager.UNKNOWN_CARRIER_ID,
                Arrays.asList(mSubscriptionInfo1));
                DISPLAY_NAME_1, SUB_MCC_1, SUB_MNC_1, SUB_COUNTRY_ISO_1,
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
                TelephonyManager.UNINITIALIZED_CARD_ID, false, true, true, false, false);
                Arrays.asList(mSubscriptionInfo1));
        mSubscriptionInfoEntityList.add(mSubInfo1);
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        final StringBuilder summary = new StringBuilder();
        final StringBuilder summary = new StringBuilder();
@@ -194,13 +198,16 @@ public class NetworkProviderCallsSmsControllerTest {
    @Test
    @Test
    @UiThreadTest
    @UiThreadTest
    public void getSummary_oneIsInvalidSubIdTwoIsValidSubId_returnOneIsUnavailable() {
    public void getSummary_oneIsInvalidSubIdTwoIsValidSubId_returnOneIsUnavailable() {
        setupSubscriptionInfoList(SubscriptionManager.INVALID_SUBSCRIPTION_ID, DISPLAY_NAME_1,

                mSubscriptionInfo1);
        mSubInfo1 = setupSubscriptionInfoEntity(INVALID_SUB_ID,
        setupSubscriptionInfoList(SUB_ID_2, DISPLAY_NAME_2, mSubscriptionInfo2);
                SubscriptionManager.INVALID_SIM_SLOT_INDEX, TelephonyManager.UNKNOWN_CARRIER_ID,
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
                DISPLAY_NAME_1, SUB_MCC_1, SUB_MNC_1, SUB_COUNTRY_ISO_1,
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
                TelephonyManager.UNINITIALIZED_CARD_ID, false, true, true, false, false);
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
        mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
                SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
        mSubscriptionInfoEntityList.add(mSubInfo1);
        mSubscriptionInfoEntityList.add(mSubInfo2);
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        final StringBuilder summary = new StringBuilder();
        final StringBuilder summary = new StringBuilder();
@@ -214,16 +221,14 @@ public class NetworkProviderCallsSmsControllerTest {
        assertTrue(TextUtils.equals(mController.getSummary(), summary));
        assertTrue(TextUtils.equals(mController.getSummary(), summary));
    }
    }




    @Test
    @Test
    @UiThreadTest
    @UiThreadTest
    public void getSummary_oneSubscription_returnDisplayName() {
    public void getSummary_oneSubscription_returnDisplayName() {
        setupSubscriptionInfoList(SUB_ID_1, DISPLAY_NAME_1, mSubscriptionInfo1);

        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
        mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
                Arrays.asList(mSubscriptionInfo1));
                SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, false, false);
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
        mSubscriptionInfoEntityList.add(mSubInfo1);
                Arrays.asList(mSubscriptionInfo1));
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        assertThat(mPreference.getSummary()).isEqualTo(DISPLAY_NAME_1);
        assertThat(mPreference.getSummary()).isEqualTo(DISPLAY_NAME_1);
@@ -232,12 +237,14 @@ public class NetworkProviderCallsSmsControllerTest {
    @Test
    @Test
    @UiThreadTest
    @UiThreadTest
    public void getSummary_allSubscriptionsHaveNoPreferredStatus_returnDisplayName() {
    public void getSummary_allSubscriptionsHaveNoPreferredStatus_returnDisplayName() {
        setupSubscriptionInfoList(SUB_ID_1, DISPLAY_NAME_1, mSubscriptionInfo1);

        setupSubscriptionInfoList(SUB_ID_2, DISPLAY_NAME_2, mSubscriptionInfo2);
        mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
                SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, false, false);
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
                SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        mSubscriptionInfoEntityList.add(mSubInfo1);
        mSubscriptionInfoEntityList.add(mSubInfo2);
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        final StringBuilder summary = new StringBuilder();
        final StringBuilder summary = new StringBuilder();
@@ -250,15 +257,13 @@ public class NetworkProviderCallsSmsControllerTest {
    @UiThreadTest
    @UiThreadTest
    public void getSummary_oneSubscriptionsIsCallPreferredTwoIsSmsPreferred_returnStatus() {
    public void getSummary_oneSubscriptionsIsCallPreferredTwoIsSmsPreferred_returnStatus() {


        mController.setDefaultVoiceSubscriptionId(SUB_ID_1);
        mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
        mController.setDefaultSmsSubscriptionId(SUB_ID_2);
                SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, false);

        mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
        setupSubscriptionInfoList(SUB_ID_1, DISPLAY_NAME_1, mSubscriptionInfo1);
                SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, true);
        setupSubscriptionInfoList(SUB_ID_2, DISPLAY_NAME_2, mSubscriptionInfo2);
        mSubscriptionInfoEntityList.add(mSubInfo1);
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
        mSubscriptionInfoEntityList.add(mSubInfo2);
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        final StringBuilder summary = new StringBuilder();
        final StringBuilder summary = new StringBuilder();
@@ -279,15 +284,13 @@ public class NetworkProviderCallsSmsControllerTest {
    @UiThreadTest
    @UiThreadTest
    public void getSummary_oneSubscriptionsIsSmsPreferredTwoIsCallPreferred_returnStatus() {
    public void getSummary_oneSubscriptionsIsSmsPreferredTwoIsCallPreferred_returnStatus() {


        mController.setDefaultVoiceSubscriptionId(SUB_ID_2);
        mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
        mController.setDefaultSmsSubscriptionId(SUB_ID_1);
                SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, false, true);

        mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
        setupSubscriptionInfoList(SUB_ID_1, DISPLAY_NAME_1, mSubscriptionInfo1);
                SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, true, false);
        setupSubscriptionInfoList(SUB_ID_2, DISPLAY_NAME_2, mSubscriptionInfo2);
        mSubscriptionInfoEntityList.add(mSubInfo1);
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
        mSubscriptionInfoEntityList.add(mSubInfo2);
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        final StringBuilder summary = new StringBuilder();
        final StringBuilder summary = new StringBuilder();
@@ -308,15 +311,13 @@ public class NetworkProviderCallsSmsControllerTest {
    @UiThreadTest
    @UiThreadTest
    public void getSummary_oneSubscriptionsIsSmsPreferredAndIsCallPreferred_returnStatus() {
    public void getSummary_oneSubscriptionsIsSmsPreferredAndIsCallPreferred_returnStatus() {


        mController.setDefaultVoiceSubscriptionId(SUB_ID_1);
        mSubInfo1 = setupSubscriptionInfoEntity(SUB_ID_1, 1, 1, DISPLAY_NAME_1, SUB_MCC_1,
        mController.setDefaultSmsSubscriptionId(SUB_ID_1);
                SUB_MNC_1, SUB_COUNTRY_ISO_1, 1, true, true, true, true, true);

        mSubInfo2 = setupSubscriptionInfoEntity(SUB_ID_2, 1, 1, DISPLAY_NAME_2, SUB_MCC_2,
        setupSubscriptionInfoList(SUB_ID_1, DISPLAY_NAME_1, mSubscriptionInfo1);
                SUB_MNC_2, SUB_COUNTRY_ISO_2, 1, true, true, true, false, false);
        setupSubscriptionInfoList(SUB_ID_2, DISPLAY_NAME_2, mSubscriptionInfo2);
        mSubscriptionInfoEntityList.add(mSubInfo1);
        when(mSubscriptionManager.getActiveSubscriptionInfoList()).thenReturn(
        mSubscriptionInfoEntityList.add(mSubInfo2);
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        mController.setSubscriptionInfoList(mSubscriptionInfoEntityList);
        when(mSubscriptionManager.getAvailableSubscriptionInfoList()).thenReturn(
                Arrays.asList(mSubscriptionInfo1, mSubscriptionInfo2));
        displayPreferenceWithLifecycle();
        displayPreferenceWithLifecycle();


        final StringBuilder summary = new StringBuilder();
        final StringBuilder summary = new StringBuilder();