BuildNumberPreferenceControllerTest converted to JUnit

UserManager spy used instead of ShadowUserManager.
ArgumentCaptor used for ClipData rather than getting the primary clip.
Test: atest -c BuildNumberPreferenceControllerTest

Change-Id: Idd9e93371f1abda7bf9169ee86116fb7efb9ca09
This commit is contained in:
Jeremy Goldman
2021-02-23 17:13:51 +08:00
parent fb00d1c5b3
commit 22241eb25f
2 changed files with 54 additions and 43 deletions

View File

@@ -17,6 +17,7 @@
package com.android.settings.deviceinfo; package com.android.settings.deviceinfo;
import android.app.Activity; import android.app.Activity;
import android.app.ActivityManager;
import android.app.settings.SettingsEnums; import android.app.settings.SettingsEnums;
import android.content.ComponentName; import android.content.ComponentName;
import android.content.Context; import android.content.Context;
@@ -29,6 +30,7 @@ import android.text.BidiFormatter;
import android.text.TextUtils; import android.text.TextUtils;
import android.widget.Toast; import android.widget.Toast;
import androidx.annotation.VisibleForTesting;
import androidx.preference.Preference; import androidx.preference.Preference;
import com.android.internal.logging.nano.MetricsProto.MetricsEvent; import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
@@ -112,7 +114,7 @@ public class BuildNumberPreferenceController extends BasePreferenceController im
if (!TextUtils.equals(preference.getKey(), getPreferenceKey())) { if (!TextUtils.equals(preference.getKey(), getPreferenceKey())) {
return false; return false;
} }
if (Utils.isMonkeyRunning()) { if (isUserAMonkey()) {
return false; return false;
} }
// Don't enable developer options for secondary non-demo users. // Don't enable developer options for secondary non-demo users.
@@ -245,4 +247,9 @@ public class BuildNumberPreferenceController extends BasePreferenceController im
Toast.LENGTH_LONG); Toast.LENGTH_LONG);
mDevHitToast.show(); mDevHitToast.show();
} }
@VisibleForTesting
protected boolean isUserAMonkey() {
return ActivityManager.isUserAMonkey();
}
} }

View File

@@ -22,52 +22,51 @@ 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.ArgumentMatchers.eq;
import static org.mockito.Mockito.doNothing;
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.verify; import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import android.app.Activity; import android.app.Activity;
import android.content.ClipData;
import android.content.ClipboardManager; import android.content.ClipboardManager;
import android.content.Context; import android.content.Context;
import android.content.pm.UserInfo; import android.os.Looper;
import android.os.Process;
import android.os.UserHandle;
import android.os.UserManager; import android.os.UserManager;
import android.provider.Settings; import android.provider.Settings;
import androidx.lifecycle.LifecycleOwner; import androidx.lifecycle.LifecycleOwner;
import androidx.preference.Preference; import androidx.preference.Preference;
import androidx.test.annotation.UiThreadTest;
import androidx.test.core.app.ApplicationProvider;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import com.android.internal.logging.nano.MetricsProto; import com.android.internal.logging.nano.MetricsProto;
import com.android.settings.core.InstrumentedPreferenceFragment; import com.android.settings.core.InstrumentedPreferenceFragment;
import com.android.settings.testutils.FakeFeatureFactory; import com.android.settings.testutils.FakeFeatureFactory;
import com.android.settings.testutils.shadow.ShadowUtils;
import com.android.settingslib.core.lifecycle.Lifecycle; import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.development.DevelopmentSettingsEnabler; import com.android.settingslib.development.DevelopmentSettingsEnabler;
import org.junit.After;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.mockito.Answers; import org.mockito.Answers;
import org.mockito.ArgumentCaptor;
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 org.robolectric.Shadows;
import org.robolectric.annotation.Config;
import org.robolectric.shadows.ShadowUserManager;
@RunWith(RobolectricTestRunner.class) @RunWith(AndroidJUnit4.class)
@Config(shadows = ShadowUtils.class)
public class BuildNumberPreferenceControllerTest { public class BuildNumberPreferenceControllerTest {
private static final String KEY_BUILD_NUMBER = "build_number"; private static final String KEY_BUILD_NUMBER = "build_number";
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
private InstrumentedPreferenceFragment mFragment; private InstrumentedPreferenceFragment mFragment;
private ShadowUserManager mShadowUserManager;
private Context mContext; private Context mContext;
private UserManager mUserManager;
private ClipboardManager mClipboardManager;
private LifecycleOwner mLifecycleOwner; private LifecycleOwner mLifecycleOwner;
private Lifecycle mLifecycle; private Lifecycle mLifecycle;
private FakeFeatureFactory mFactory; private FakeFeatureFactory mFactory;
@@ -75,15 +74,23 @@ public class BuildNumberPreferenceControllerTest {
private BuildNumberPreferenceController mController; private BuildNumberPreferenceController mController;
@Before @Before
@UiThreadTest
public void setUp() { public void setUp() {
if (Looper.myLooper() == null) {
Looper.prepare();
}
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
mContext = RuntimeEnvironment.application;
mShadowUserManager = Shadows.shadowOf( mContext = spy(ApplicationProvider.getApplicationContext());
RuntimeEnvironment.application.getSystemService(UserManager.class)); mUserManager = (UserManager) spy(mContext.getSystemService(Context.USER_SERVICE));
doReturn(mUserManager).when(mContext).getSystemService(Context.USER_SERVICE);
mClipboardManager = (ClipboardManager) spy(mContext.getSystemService(CLIPBOARD_SERVICE));
doReturn(mClipboardManager).when(mContext).getSystemService(CLIPBOARD_SERVICE);
mFactory = FakeFeatureFactory.setupForTest(); mFactory = FakeFeatureFactory.setupForTest();
mLifecycleOwner = () -> mLifecycle; mLifecycleOwner = () -> mLifecycle;
mLifecycle = new Lifecycle(mLifecycleOwner); mLifecycle = new Lifecycle(mLifecycleOwner);
mController = new BuildNumberPreferenceController(mContext, KEY_BUILD_NUMBER); mController = spy(new BuildNumberPreferenceController(mContext, KEY_BUILD_NUMBER));
mController.setHost(mFragment); mController.setHost(mFragment);
mPreference = new Preference(mContext); mPreference = new Preference(mContext);
@@ -93,11 +100,6 @@ public class BuildNumberPreferenceControllerTest {
Settings.Global.DEVICE_PROVISIONED, 1); Settings.Global.DEVICE_PROVISIONED, 1);
} }
@After
public void tearDown() {
ShadowUtils.reset();
}
@Test @Test
public void handlePrefTreeClick_onlyHandleBuildNumberPref() { public void handlePrefTreeClick_onlyHandleBuildNumberPref() {
assertThat(mController.handlePreferenceTreeClick(mock(Preference.class))).isFalse(); assertThat(mController.handlePreferenceTreeClick(mock(Preference.class))).isFalse();
@@ -105,32 +107,32 @@ public class BuildNumberPreferenceControllerTest {
@Test @Test
public void handlePrefTreeClick_notAdminUser_notDemoUser_doNothing() { public void handlePrefTreeClick_notAdminUser_notDemoUser_doNothing() {
mShadowUserManager.setIsAdminUser(false); when(mUserManager.isAdminUser()).thenReturn(false);
mShadowUserManager.setIsDemoUser(false); when(mUserManager.isDemoUser()).thenReturn(false);
assertThat(mController.handlePreferenceTreeClick(mPreference)).isFalse(); assertThat(mController.handlePreferenceTreeClick(mPreference)).isFalse();
} }
@Test @Test
public void handlePrefTreeClick_isAdminUser_notDemoUser_handleBuildNumberPref() { public void handlePrefTreeClick_isAdminUser_notDemoUser_handleBuildNumberPref() {
mShadowUserManager.setIsAdminUser(true); when(mUserManager.isAdminUser()).thenReturn(true);
mShadowUserManager.setIsDemoUser(false); when(mUserManager.isDemoUser()).thenReturn(false);
assertThat(mController.handlePreferenceTreeClick(mPreference)).isTrue(); assertThat(mController.handlePreferenceTreeClick(mPreference)).isTrue();
} }
@Test @Test
public void handlePrefTreeClick_notAdminUser_isDemoUser_handleBuildNumberPref() { public void handlePrefTreeClick_notAdminUser_isDemoUser_handleBuildNumberPref() {
mShadowUserManager.setIsAdminUser(false); when(mUserManager.isAdminUser()).thenReturn(false);
mShadowUserManager.addUser(UserHandle.myUserId(), "test", UserInfo.FLAG_DEMO); when(mUserManager.isDemoUser()).thenReturn(true);
assertThat(mController.handlePreferenceTreeClick(mPreference)).isTrue(); assertThat(mController.handlePreferenceTreeClick(mPreference)).isTrue();
} }
@Test @Test
public void handlePrefTreeClick_deviceNotProvisioned_doNothing() { public void handlePrefTreeClick_deviceNotProvisioned_doNothing() {
mShadowUserManager.setIsAdminUser(true); when(mUserManager.isAdminUser()).thenReturn(true);
mShadowUserManager.setIsDemoUser(false); when(mUserManager.isDemoUser()).thenReturn(false);
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.DEVICE_PROVISIONED, Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.DEVICE_PROVISIONED,
0); 0);
@@ -143,17 +145,16 @@ public class BuildNumberPreferenceControllerTest {
@Test @Test
public void handlePrefTreeClick_isMonkeyRun_doNothing() { public void handlePrefTreeClick_isMonkeyRun_doNothing() {
ShadowUtils.setIsUserAMonkey(true); when(mController.isUserAMonkey()).thenReturn(true);
assertThat(mController.handlePreferenceTreeClick(mPreference)).isFalse(); assertThat(mController.handlePreferenceTreeClick(mPreference)).isFalse();
} }
@Test @Test
public void handlePrefTreeClick_userHasRestriction_doNothing() { public void handlePrefTreeClick_userHasRestriction_doNothing() {
mShadowUserManager.setIsAdminUser(true); when(mUserManager.isAdminUser()).thenReturn(true);
mShadowUserManager.setIsDemoUser(false); when(mUserManager.isDemoUser()).thenReturn(false);
when(mUserManager.hasUserRestriction(UserManager.DISALLOW_DEBUGGING_FEATURES))
mShadowUserManager.setUserRestriction(Process.myUserHandle(), .thenReturn(true);
UserManager.DISALLOW_DEBUGGING_FEATURES, true);
assertThat(mController.handlePreferenceTreeClick(mPreference)).isFalse(); assertThat(mController.handlePreferenceTreeClick(mPreference)).isFalse();
verify(mFactory.metricsFeatureProvider).action( verify(mFactory.metricsFeatureProvider).action(
@@ -184,8 +185,9 @@ public class BuildNumberPreferenceControllerTest {
} }
@Test @Test
@UiThreadTest
public void onActivityResult_confirmPasswordRequestCompleted_enableDevPref() { public void onActivityResult_confirmPasswordRequestCompleted_enableDevPref() {
mShadowUserManager.setIsAdminUser(true); when(mUserManager.isAdminUser()).thenReturn(true);
final boolean activityResultHandled = mController.onActivityResult( final boolean activityResultHandled = mController.onActivityResult(
BuildNumberPreferenceController.REQUEST_CONFIRM_PASSWORD_FOR_DEV_PREF, BuildNumberPreferenceController.REQUEST_CONFIRM_PASSWORD_FOR_DEV_PREF,
@@ -197,12 +199,14 @@ public class BuildNumberPreferenceControllerTest {
} }
@Test @Test
@UiThreadTest
public void copy_shouldCopyBuildNumberToClipboard() { public void copy_shouldCopyBuildNumberToClipboard() {
ArgumentCaptor<ClipData> captor = ArgumentCaptor.forClass(ClipData.class);
doNothing().when(mClipboardManager).setPrimaryClip(captor.capture());
mController.copy(); mController.copy();
final ClipboardManager clipboard = (ClipboardManager) mContext.getSystemService( final ClipData data = captor.getValue();
CLIPBOARD_SERVICE); assertThat(data.getItemAt(0).getText().toString()).isEqualTo(mController.getSummary());
final CharSequence data = clipboard.getPrimaryClip().getItemAt(0).getText();
assertThat(data.toString()).isEqualTo(mController.getSummary());
} }
} }