[Testing] To migration DefaultSubscriptionControllerTest

1. Use AndroidJunit4 instead of RobolectricTestRunner
2. Use ApplicationProvider instead of RuntimeEnvironment to get context
3. Change Copy Right
4. Create new class and add a function which loads the Settings Resource.
5. remove getOnPreferenceChangeListener. Becasue the error:
java.lang.NoSuchMethodError: No virtual method getOnPreferenceChangeListener()

Bug: 173004787
Test: atest -c DefaultSubscriptionControllerTest
Change-Id: Iac9834f2a47bd8b50234646197a31058ffacaa4b
This commit is contained in:
SongFerngWang
2020-11-12 10:28:09 +08:00
parent d682b2cc57
commit aa941c91b7
2 changed files with 84 additions and 38 deletions

View File

@@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2019 The Android Open Source Project * Copyright (C) 2020 The Android Open Source Project
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@@ -22,22 +22,25 @@ import static com.android.settings.core.BasePreferenceController.CONDITIONALLY_U
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.any;
import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.doReturn; import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
import android.content.Context; import android.content.Context;
import android.os.Looper;
import android.telecom.TelecomManager;
import android.telephony.SubscriptionInfo; import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager; import android.telephony.SubscriptionManager;
import androidx.preference.ListPreference; import androidx.preference.ListPreference;
import androidx.preference.PreferenceManager;
import androidx.preference.PreferenceScreen; import androidx.preference.PreferenceScreen;
import androidx.test.core.app.ApplicationProvider;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import com.android.settings.R;
import com.android.settings.network.SubscriptionUtil; import com.android.settings.network.SubscriptionUtil;
import com.android.settings.testutils.Utils;
import org.junit.After; import org.junit.After;
import org.junit.Before; import org.junit.Before;
@@ -45,18 +48,18 @@ import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.mockito.Mock; import org.mockito.Mock;
import org.mockito.MockitoAnnotations; import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;
import java.util.Arrays; import java.util.Arrays;
@RunWith(RobolectricTestRunner.class) @RunWith(AndroidJUnit4.class)
public class DefaultSubscriptionControllerTest { public class DefaultSubscriptionControllerTest {
@Mock @Mock
private SubscriptionManager mManager; private SubscriptionManager mManager;
@Mock @Mock
private PreferenceScreen mScreen; private TelecomManager mTelecomManager;
private PreferenceScreen mScreen;
private PreferenceManager mPreferenceManager;
private ListPreference mListPreference; private ListPreference mListPreference;
private Context mContext; private Context mContext;
private DefaultSubscriptionController mController; private DefaultSubscriptionController mController;
@@ -64,12 +67,21 @@ public class DefaultSubscriptionControllerTest {
@Before @Before
public void setUp() { public void setUp() {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
mContext = spy(RuntimeEnvironment.application); mContext = spy(ApplicationProvider.getApplicationContext());
when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mManager); when(mContext.getSystemService(SubscriptionManager.class)).thenReturn(mManager);
when(mContext.getSystemService(TelecomManager.class)).thenReturn(mTelecomManager);
final String key = "prefkey"; final String key = "prefkey";
mController = spy(new TestDefaultSubscriptionController(mContext, key)); mController = new TestDefaultSubscriptionController(mContext, key);
mListPreference = spy(new ListPreference(mContext));
when(mScreen.findPreference(key)).thenReturn(mListPreference); if (Looper.myLooper() == null) {
Looper.prepare();
}
mPreferenceManager = new PreferenceManager(mContext);
mScreen = mPreferenceManager.createPreferenceScreen(mContext);
mListPreference = new ListPreference(mContext);
mListPreference.setKey(key);
mScreen.addPreference(mListPreference);
} }
@After @After
@@ -94,14 +106,14 @@ public class DefaultSubscriptionControllerTest {
@Test @Test
public void isCallingAccountBindToSubscription_invalidAccount_withoutCrash() { public void isCallingAccountBindToSubscription_invalidAccount_withoutCrash() {
doReturn(null).when(mController).getPhoneAccount(any()); doReturn(null).when(mTelecomManager).getPhoneAccount(any());
mController.isCallingAccountBindToSubscription(null); mController.isCallingAccountBindToSubscription(null);
} }
@Test @Test
public void getLabelFromCallingAccount_invalidAccount_emptyString() { public void getLabelFromCallingAccount_invalidAccount_emptyString() {
doReturn(null).when(mController).getPhoneAccount(any()); doReturn(null).when(mTelecomManager).getPhoneAccount(any());
assertThat(mController.getLabelFromCallingAccount(null)).isEqualTo(""); assertThat(mController.getLabelFromCallingAccount(null)).isEqualTo("");
} }
@@ -111,7 +123,7 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
@@ -124,7 +136,8 @@ public class DefaultSubscriptionControllerTest {
assertThat(entries.length).isEqualTo(3); assertThat(entries.length).isEqualTo(3);
assertThat(entries[0]).isEqualTo("sub1"); assertThat(entries[0]).isEqualTo("sub1");
assertThat(entries[1]).isEqualTo("sub2"); assertThat(entries[1]).isEqualTo("sub2");
assertThat(entries[2]).isEqualTo(mContext.getString(R.string.calls_and_sms_ask_every_time)); assertThat(entries[2]).isEqualTo(
Utils.getResourceString(mContext, "calls_and_sms_ask_every_time"));
final CharSequence[] entryValues = mListPreference.getEntryValues(); final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entryValues.length).isEqualTo(3); assertThat(entryValues.length).isEqualTo(3);
@@ -139,7 +152,7 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub2.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub2.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
@@ -152,7 +165,8 @@ public class DefaultSubscriptionControllerTest {
assertThat(entries.length).isEqualTo(3); assertThat(entries.length).isEqualTo(3);
assertThat(entries[0]).isEqualTo("sub1"); assertThat(entries[0]).isEqualTo("sub1");
assertThat(entries[1]).isEqualTo("sub2"); assertThat(entries[1]).isEqualTo("sub2");
assertThat(entries[2]).isEqualTo(mContext.getString(R.string.calls_and_sms_ask_every_time)); assertThat(entries[2]).isEqualTo(
Utils.getResourceString(mContext, "calls_and_sms_ask_every_time"));
final CharSequence[] entryValues = mListPreference.getEntryValues(); final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entryValues.length).isEqualTo(3); assertThat(entryValues.length).isEqualTo(3);
@@ -172,7 +186,7 @@ public class DefaultSubscriptionControllerTest {
when(sub2.isOpportunistic()).thenReturn(true); when(sub2.isOpportunistic()).thenReturn(true);
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2, sub3)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2, sub3));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
@@ -180,7 +194,8 @@ public class DefaultSubscriptionControllerTest {
assertThat(entries.length).isEqualTo(3); assertThat(entries.length).isEqualTo(3);
assertThat(entries[0]).isEqualTo("sub1"); assertThat(entries[0]).isEqualTo("sub1");
assertThat(entries[1]).isEqualTo("sub3"); assertThat(entries[1]).isEqualTo("sub3");
assertThat(entries[2]).isEqualTo(mContext.getString(R.string.calls_and_sms_ask_every_time)); assertThat(entries[2]).isEqualTo(
Utils.getResourceString(mContext, "calls_and_sms_ask_every_time"));
final CharSequence[] entryValues = mListPreference.getEntryValues(); final CharSequence[] entryValues = mListPreference.getEntryValues();
assertThat(entryValues.length).isEqualTo(3); assertThat(entryValues.length).isEqualTo(3);
@@ -195,12 +210,12 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
mListPreference.setValue("222"); mListPreference.setValue("222");
mController.onPreferenceChange(mListPreference, "222"); mController.onPreferenceChange(mListPreference, "222");
verify(mController).setDefaultSubscription(eq(222)); assertThat(mController.getDefaultSubscriptionId()).isEqualTo(222);
} }
@Test @Test
@@ -208,14 +223,14 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
mListPreference.setValue(Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID)); mListPreference.setValue(Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
mController.onPreferenceChange(mListPreference, mController.onPreferenceChange(mListPreference,
Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID)); Integer.toString(SubscriptionManager.INVALID_SUBSCRIPTION_ID));
verify(mController).setDefaultSubscription( assertThat(mController.getDefaultSubscriptionId()).isEqualTo(
eq(SubscriptionManager.INVALID_SUBSCRIPTION_ID)); SubscriptionManager.INVALID_SUBSCRIPTION_ID);
} }
@Test @Test
@@ -225,7 +240,7 @@ public class DefaultSubscriptionControllerTest {
// 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)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mController.isAvailable()).isFalse(); assertThat(mController.isAvailable()).isFalse();
@@ -233,11 +248,12 @@ public class DefaultSubscriptionControllerTest {
// 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)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
mController.onSubscriptionsChanged(); mController.onSubscriptionsChanged();
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
assertThat(mListPreference.getOnPreferenceChangeListener()).isEqualTo(mController);
mListPreference.callChangeListener("222"); mListPreference.callChangeListener("222");
verify(mController).setDefaultSubscription(eq(222)); assertThat(mController.getDefaultSubscriptionId()).isEqualTo(222);
} }
@Test @Test
@@ -245,15 +261,15 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat( mListPreference.getEntry()).isEqualTo("sub1"); assertThat(mListPreference.getEntry()).isEqualTo("sub1");
assertThat(mListPreference.getValue()).isEqualTo("111"); assertThat(mListPreference.getValue()).isEqualTo("111");
doReturn(sub2.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub2.getSubscriptionId());
mController.onSubscriptionsChanged(); mController.onSubscriptionsChanged();
assertThat( mListPreference.getEntry()).isEqualTo("sub2"); assertThat(mListPreference.getEntry()).isEqualTo("sub2");
assertThat(mListPreference.getValue()).isEqualTo("222"); assertThat(mListPreference.getValue()).isEqualTo("222");
} }
@@ -262,7 +278,7 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
@@ -280,7 +296,7 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub1 = createMockSub(111, "sub1"); final SubscriptionInfo sub1 = createMockSub(111, "sub1");
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mController.isAvailable()).isFalse(); assertThat(mController.isAvailable()).isFalse();
@@ -299,7 +315,7 @@ public class DefaultSubscriptionControllerTest {
final SubscriptionInfo sub2 = createMockSub(222, "sub2"); final SubscriptionInfo sub2 = createMockSub(222, "sub2");
final SubscriptionInfo sub3 = createMockSub(333, "sub3"); final SubscriptionInfo sub3 = createMockSub(333, "sub3");
SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2)); SubscriptionUtil.setActiveSubscriptionsForTesting(Arrays.asList(sub1, sub2));
doReturn(sub1.getSubscriptionId()).when(mController).getDefaultSubscriptionId(); mController.setDefaultSubscription(sub1.getSubscriptionId());
mController.displayPreference(mScreen); mController.displayPreference(mScreen);
assertThat(mListPreference.getEntries().length).isEqualTo(3); assertThat(mListPreference.getEntries().length).isEqualTo(3);
@@ -316,7 +332,7 @@ public class DefaultSubscriptionControllerTest {
assertThat(entries[1].toString()).isEqualTo("sub2"); assertThat(entries[1].toString()).isEqualTo("sub2");
assertThat(entries[2].toString()).isEqualTo("sub3"); assertThat(entries[2].toString()).isEqualTo("sub3");
assertThat(entries[3].toString()).isEqualTo( assertThat(entries[3].toString()).isEqualTo(
mContext.getString(R.string.calls_and_sms_ask_every_time)); Utils.getResourceString(mContext, "calls_and_sms_ask_every_time"));
assertThat(entryValues[0].toString()).isEqualTo("111"); assertThat(entryValues[0].toString()).isEqualTo("111");
assertThat(entryValues[1].toString()).isEqualTo("222"); assertThat(entryValues[1].toString()).isEqualTo("222");
assertThat(entryValues[2].toString()).isEqualTo("333"); assertThat(entryValues[2].toString()).isEqualTo("333");
@@ -332,8 +348,9 @@ public class DefaultSubscriptionControllerTest {
} }
private class TestDefaultSubscriptionController extends DefaultSubscriptionController { private class TestDefaultSubscriptionController extends DefaultSubscriptionController {
int mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID;
public TestDefaultSubscriptionController(Context context, String preferenceKey) { TestDefaultSubscriptionController(Context context, String preferenceKey) {
super(context, preferenceKey); super(context, preferenceKey);
} }
@@ -344,11 +361,12 @@ public class DefaultSubscriptionControllerTest {
@Override @Override
protected int getDefaultSubscriptionId() { protected int getDefaultSubscriptionId() {
return 0; return mSubId;
} }
@Override @Override
protected void setDefaultSubscription(int subscriptionId) { protected void setDefaultSubscription(int subscriptionId) {
mSubId = subscriptionId;
} }
} }
} }

View File

@@ -0,0 +1,28 @@
/*
* Copyright (C) 2020 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.settings.testutils;
import android.content.Context;
public final class Utils {
public static int getResourceId(Context context, String type, String name) {
return context.getResources().getIdentifier(name, type, context.getPackageName());
}
public static String getResourceString(Context context, String name) {
return context.getResources().getString(getResourceId(context, "string", name));
}
}