Remove custom robotest utils in favor of framework support.

Bug: 111195450
Fixes: 111195167
Test: robotests
Change-Id: I8bea43fd86f9ae5ce40eb16dabf733b0fbe89aae
This commit is contained in:
Fan Zhang
2018-09-26 16:47:57 -07:00
parent 9f3cd7a621
commit 67793945f0
11 changed files with 34 additions and 461 deletions

View File

@@ -28,7 +28,6 @@ import androidx.fragment.app.FragmentActivity;
import com.android.settings.R;
import com.android.settings.deviceinfo.PrivateVolumeForget.ForgetConfirmFragment;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.testutils.shadow.SettingsShadowResourcesImpl;
import com.android.settings.testutils.shadow.ShadowStorageManager;
@@ -38,6 +37,7 @@ import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.robolectric.annotation.Config;
import org.robolectric.shadows.androidx.fragment.FragmentController;
@RunWith(SettingsRobolectricTestRunner.class)
@Config(shadows = {ShadowStorageManager.class, SettingsShadowResourcesImpl.class})
@@ -50,8 +50,12 @@ public class PrivateVolumeForgetTest {
public void setUp() {
final Bundle bundle = new Bundle();
bundle.putString(VolumeRecord.EXTRA_FS_UUID, "id");
mFragment = Robolectric.buildFragment(PrivateVolumeForget.class,
bundle).create().start().resume().get();
mFragment = FragmentController.of(new PrivateVolumeForget(), bundle)
.create()
.start()
.resume()
.visible()
.get();
mActivity = mFragment.getActivity();
}

View File

@@ -25,7 +25,6 @@ import android.os.storage.VolumeInfo;
import android.widget.Button;
import com.android.settings.R;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.testutils.shadow.ShadowStorageManager;
@@ -36,6 +35,7 @@ import org.robolectric.RuntimeEnvironment;
import org.robolectric.Shadows;
import org.robolectric.annotation.Config;
import org.robolectric.shadows.ShadowActivity;
import org.robolectric.shadows.androidx.fragment.FragmentController;
@RunWith(SettingsRobolectricTestRunner.class)
@@ -49,8 +49,12 @@ public class PrivateVolumeFormatTest {
public void setUp() {
final Bundle bundle = new Bundle();
bundle.putString(VolumeInfo.EXTRA_VOLUME_ID, "id");
mFragment = Robolectric.buildFragment(PrivateVolumeFormat.class,
bundle).create().start().resume().get();
mFragment = FragmentController.of(new PrivateVolumeFormat(), bundle)
.create()
.start()
.resume()
.visible()
.get();
mShadowActivity = Shadows.shadowOf(mFragment.getActivity());
}

View File

@@ -23,7 +23,6 @@ import android.os.storage.VolumeInfo;
import android.widget.Button;
import com.android.settings.R;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.testutils.shadow.ShadowStorageManager;
@@ -32,6 +31,7 @@ import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.robolectric.annotation.Config;
import org.robolectric.shadows.androidx.fragment.FragmentController;
@RunWith(SettingsRobolectricTestRunner.class)
@@ -44,8 +44,12 @@ public class PrivateVolumeUnmountTest {
public void setUp() {
Bundle bundle = new Bundle();
bundle.putString(VolumeInfo.EXTRA_VOLUME_ID, "id");
mFragment = Robolectric.buildFragment(PrivateVolumeUnmount.class,
bundle).create().start().resume().get();
mFragment = FragmentController.of(new PrivateVolumeUnmount(), bundle)
.create()
.start()
.resume()
.visible()
.get();
}
@After
@@ -57,7 +61,7 @@ public class PrivateVolumeUnmountTest {
public void OnClickListener_shouldCallUnmount() {
assertThat(ShadowStorageManager.isUnmountCalled()).isFalse();
Button confirm = (Button) mFragment.getView().findViewById(R.id.confirm);
final Button confirm = mFragment.getView().findViewById(R.id.confirm);
confirm.performClick();

View File

@@ -1,7 +1,6 @@
package com.android.settings.deviceinfo.deviceinfo;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
@@ -9,12 +8,11 @@ import android.content.DialogInterface;
import com.android.settings.deviceinfo.aboutphone.DeviceNameWarningDialog;
import com.android.settings.deviceinfo.aboutphone.MyDeviceInfoFragment;
import com.android.settings.testutils.FragmentController;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.robolectric.shadows.androidx.fragment.FragmentController;
@RunWith(SettingsRobolectricTestRunner.class)
public class DeviceNameWarningDialogTest {
@@ -23,7 +21,7 @@ public class DeviceNameWarningDialogTest {
@Test
public void onClick_okSetsName() {
final FragmentController<DeviceNameWarningDialog> fragmentController =
Robolectric.buildFragment(DeviceNameWarningDialog.class);
FragmentController.of(new DeviceNameWarningDialog());
final DeviceNameWarningDialog fragment = spy(fragmentController.get());
final MyDeviceInfoFragment deviceInfoFragment = mock(MyDeviceInfoFragment.class);
fragment.setTargetFragment(deviceInfoFragment, 0);
@@ -36,7 +34,7 @@ public class DeviceNameWarningDialogTest {
@Test
public void onClick_cancelDoesNothing() {
final FragmentController<DeviceNameWarningDialog> fragmentController =
Robolectric.buildFragment(DeviceNameWarningDialog.class);
FragmentController.of(new DeviceNameWarningDialog());
final DeviceNameWarningDialog fragment = spy(fragmentController.get());
final MyDeviceInfoFragment deviceInfoFragment = mock(MyDeviceInfoFragment.class);
fragment.setTargetFragment(deviceInfoFragment, 0);

View File

@@ -44,7 +44,6 @@ import androidx.preference.SwitchPreference;
import com.android.settings.R;
import com.android.settings.network.ApnEditor.ApnData;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import org.junit.Before;
@@ -55,6 +54,7 @@ import org.mockito.Captor;
import org.mockito.Mock;
import org.mockito.Mockito;
import org.mockito.MockitoAnnotations;
import org.robolectric.Robolectric;
@RunWith(SettingsRobolectricTestRunner.class)
public class ApnEditorTest {

View File

@@ -22,12 +22,11 @@ import static org.mockito.Mockito.verify;
import android.content.DialogInterface;
import com.android.settings.testutils.FragmentController;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.robolectric.shadows.androidx.fragment.FragmentController;
@RunWith(SettingsRobolectricTestRunner.class)
@@ -36,7 +35,7 @@ public class ConfigureKeyGuardDialogTest {
@Test
public void displayDialog_clickPositiveButton_launchSetNewPassword() {
final FragmentController<ConfigureKeyGuardDialog> fragmentController =
Robolectric.buildFragment(ConfigureKeyGuardDialog.class);
FragmentController.of(new ConfigureKeyGuardDialog());
final ConfigureKeyGuardDialog fragment = spy(fragmentController.get());
doNothing().when(fragment).startPasswordSetup();
fragmentController.create().start().resume();

View File

@@ -1,210 +0,0 @@
/*
* Copyright (C) 2018 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.Intent;
import android.os.Bundle;
import android.widget.LinearLayout;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentActivity;
import org.robolectric.android.controller.ActivityController;
import org.robolectric.android.controller.ComponentController;
import org.robolectric.util.ReflectionHelpers;
/**
* Controller class for driving fragment lifecycles, similar to {@link ActivityController}.
*/
// TODO(b/111195167) - Duplicated from org.robolectric.android.controller.FragmentController.
@Deprecated
public class FragmentController<F extends Fragment> extends
ComponentController<FragmentController<F>, F> {
private final F fragment;
private final ActivityController<? extends FragmentActivity> activityController;
public static <F extends Fragment> FragmentController<F> of(F fragment) {
return of(fragment, FragmentControllerActivity.class, null, null);
}
public static <F extends Fragment> FragmentController<F> of(F fragment,
Class<? extends FragmentActivity> activityClass) {
return of(fragment, activityClass, null, null);
}
public static <F extends Fragment> FragmentController<F> of(F fragment, Intent intent) {
return new FragmentController<>(fragment, FragmentControllerActivity.class, intent);
}
public static <F extends Fragment> FragmentController<F> of(F fragment, Bundle arguments) {
return new FragmentController<>(fragment, FragmentControllerActivity.class, arguments);
}
public static <F extends Fragment> FragmentController<F> of(F fragment, Intent intent,
Bundle arguments) {
return new FragmentController<>(fragment, FragmentControllerActivity.class, intent,
arguments);
}
public static <F extends Fragment> FragmentController<F> of(F fragment,
Class<? extends FragmentActivity> activityClass, Intent intent) {
return new FragmentController<>(fragment, activityClass, intent);
}
public static <F extends Fragment> FragmentController<F> of(F fragment,
Class<? extends FragmentActivity> activityClass, Bundle arguments) {
return new FragmentController<>(fragment, activityClass, arguments);
}
public static <F extends Fragment> FragmentController<F> of(F fragment,
Class<? extends FragmentActivity> activityClass,
Intent intent, Bundle arguments) {
return new FragmentController<>(fragment, activityClass, intent, arguments);
}
private FragmentController(F fragment, Class<? extends FragmentActivity> activityClass,
Intent intent) {
this(fragment, activityClass, intent, null);
}
private FragmentController(F fragment, Class<? extends FragmentActivity> activityClass,
Bundle arguments) {
this(fragment, activityClass, null, arguments);
}
private FragmentController(F fragment, Class<? extends FragmentActivity> activityClass,
Intent intent, Bundle arguments) {
super(fragment, intent);
this.fragment = fragment;
if (arguments != null) {
this.fragment.setArguments(arguments);
}
this.activityController = ActivityController.of(
ReflectionHelpers.callConstructor(activityClass), intent);
}
/**
* Creates the activity with {@link Bundle} and adds the fragment to the view with ID {@code
* contentViewId}.
*/
public FragmentController<F> create(final int contentViewId, final Bundle bundle) {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.create(
bundle).get().getSupportFragmentManager().beginTransaction().add(
contentViewId, fragment).commit();
}
});
return this;
}
/**
* Creates the activity with {@link Bundle} and adds the fragment to it. Note that the fragment
* will be added to the view with ID 1.
*/
public FragmentController<F> create(Bundle bundle) {
return create(1, bundle);
}
@Override
public FragmentController<F> create() {
return create(null);
}
@Override
public FragmentController<F> destroy() {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.destroy();
}
});
return this;
}
public FragmentController<F> start() {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.start();
}
});
return this;
}
public FragmentController<F> resume() {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.resume();
}
});
return this;
}
public FragmentController<F> pause() {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.pause();
}
});
return this;
}
public FragmentController<F> visible() {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.visible();
}
});
return this;
}
public FragmentController<F> stop() {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.stop();
}
});
return this;
}
public FragmentController<F> saveInstanceState(final Bundle outState) {
shadowMainLooper.runPaused(new Runnable() {
@Override
public void run() {
activityController.saveInstanceState(outState);
}
});
return this;
}
private static class FragmentControllerActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout view = new LinearLayout(this);
view.setId(1);
setContentView(view);
}
}
}

View File

@@ -17,36 +17,12 @@
package com.android.settings.testutils;
import android.app.IntentService;
import android.app.Service;
import android.app.backup.BackupAgent;
import android.content.ContentProvider;
import android.content.Intent;
import android.os.Bundle;
import android.util.AttributeSet;
import android.view.View;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentActivity;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.android.XmlResourceParserImpl;
import org.robolectric.android.controller.ActivityController;
import org.robolectric.android.controller.BackupAgentController;
import org.robolectric.android.controller.ContentProviderController;
import org.robolectric.android.controller.IntentServiceController;
import org.robolectric.android.controller.ServiceController;
import org.robolectric.res.ResName;
import org.robolectric.res.ResourceTable;
import org.robolectric.shadows.ShadowApplication;
import org.robolectric.util.ReflectionHelpers;
import org.robolectric.util.Scheduler;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
// TODO(b/111195450) - Duplicated from org.robolectric.Robolectric.
@Deprecated
@@ -60,51 +36,6 @@ public class Robolectric {
// No-op- is now handled in the test runner. Users should not be calling this method anyway.
}
public static <T extends Service> ServiceController<T> buildService(Class<T> serviceClass) {
return buildService(serviceClass, null);
}
public static <T extends Service> ServiceController<T> buildService(Class<T> serviceClass,
Intent intent) {
return ServiceController.of(ReflectionHelpers.callConstructor(serviceClass), intent);
}
public static <T extends Service> T setupService(Class<T> serviceClass) {
return buildService(serviceClass).create().get();
}
public static <T extends IntentService> IntentServiceController<T> buildIntentService(
Class<T> serviceClass) {
return buildIntentService(serviceClass, null);
}
public static <T extends IntentService> IntentServiceController<T> buildIntentService(
Class<T> serviceClass, Intent intent) {
return IntentServiceController.of(ReflectionHelpers.callConstructor(serviceClass,
new ReflectionHelpers.ClassParameter<String>(String.class, "IntentService")),
intent);
}
public static <T extends IntentService> T setupIntentService(Class<T> serviceClass) {
return buildIntentService(serviceClass).create().get();
}
public static <T extends ContentProvider> ContentProviderController<T> buildContentProvider(
Class<T> contentProviderClass) {
return ContentProviderController.of(
ReflectionHelpers.callConstructor(contentProviderClass));
}
public static <T extends ContentProvider> T setupContentProvider(
Class<T> contentProviderClass) {
return buildContentProvider(contentProviderClass).create().get();
}
public static <T extends ContentProvider> T setupContentProvider(Class<T> contentProviderClass,
String authority) {
return buildContentProvider(contentProviderClass).create(authority).get();
}
public static <T extends FragmentActivity> ActivityController<T> buildActivity(
Class<T> activityClass) {
return buildActivity(activityClass, null);
@@ -118,161 +49,5 @@ public class Robolectric {
public static <T extends FragmentActivity> T setupActivity(Class<T> activityClass) {
return buildActivity(activityClass).setup().get();
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass));
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Bundle arguments) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass), arguments);
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Class<? extends FragmentActivity> activityClass) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass),
activityClass);
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Intent intent) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass), intent);
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Intent intent,
Bundle arguments) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass), intent,
arguments);
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Class<? extends FragmentActivity> activityClass,
Intent intent) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass),
activityClass, intent);
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Class<? extends FragmentActivity> activityClass,
Bundle arguments) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass),
activityClass, arguments);
}
public static <T extends Fragment> FragmentController<T> buildFragment(Class<T> fragmentClass,
Class<? extends FragmentActivity> activityClass,
Intent intent,
Bundle arguments) {
return FragmentController.of(ReflectionHelpers.callConstructor(fragmentClass),
activityClass, intent, arguments);
}
public static <T extends BackupAgent> BackupAgentController<T> buildBackupAgent(
Class<T> backupAgentClass) {
return BackupAgentController.of(ReflectionHelpers.callConstructor(backupAgentClass));
}
public static <T extends BackupAgent> T setupBackupAgent(Class<T> backupAgentClass) {
return buildBackupAgent(backupAgentClass).create().get();
}
/**
* Allows for the programatic creation of an {@link AttributeSet} useful for testing
* {@link View} classes without
* the need for creating XML snippets.
*/
public static AttributeSetBuilder buildAttributeSet() {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setNamespaceAware(true);
factory.setIgnoringComments(true);
factory.setIgnoringElementContentWhitespace(true);
Document document;
try {
DocumentBuilder documentBuilder = factory.newDocumentBuilder();
document = documentBuilder.newDocument();
Element dummy = document.createElementNS("http://schemas.android.com/apk/res/" +
RuntimeEnvironment.application.getPackageName(), "dummy");
document.appendChild(dummy);
} catch (ParserConfigurationException e) {
throw new RuntimeException(e);
}
return new AttributeSetBuilder(document, RuntimeEnvironment.getCompileTimeResourceTable());
}
public static class AttributeSetBuilder {
private Document doc;
private ResourceTable appResourceTable;
AttributeSetBuilder(Document doc, ResourceTable resourceTable) {
this.doc = doc;
this.appResourceTable = resourceTable;
}
public AttributeSetBuilder addAttribute(int resId, String value) {
ResName resName = appResourceTable.getResName(resId);
if ("style".equals(resName.name)) {
((Element) doc.getFirstChild()).setAttribute(resName.name, value);
} else {
((Element) doc.getFirstChild()).setAttributeNS(resName.getNamespaceUri(),
resName.packageName + ":" + resName.name, value);
}
return this;
}
public AttributeSetBuilder setStyleAttribute(String value) {
((Element) doc.getFirstChild()).setAttribute("style", value);
return this;
}
public AttributeSet build() {
XmlResourceParserImpl parser = new XmlResourceParserImpl(doc, null,
RuntimeEnvironment.application.getPackageName(),
RuntimeEnvironment.application.getPackageName(), appResourceTable);
try {
parser.next(); // Root document element
parser.next(); // "dummy" element
} catch (Exception e) {
throw new IllegalStateException(
"Expected single dummy element in the document to contain the attributes.",
e);
}
return parser;
}
}
/**
* Return the foreground scheduler (e.g. the UI thread scheduler).
*
* @return Foreground scheduler.
*/
public static Scheduler getForegroundThreadScheduler() {
return ShadowApplication.getInstance().getForegroundThreadScheduler();
}
/**
* Execute all runnables that have been enqueued on the foreground scheduler.
*/
public static void flushForegroundThreadScheduler() {
getForegroundThreadScheduler().advanceToLastPostedRunnable();
}
/**
* Return the background scheduler.
*
* @return Background scheduler.
*/
public static Scheduler getBackgroundThreadScheduler() {
return ShadowApplication.getInstance().getBackgroundThreadScheduler();
}
/**
* Execute all runnables that have been enqueued on the background scheduler.
*/
public static void flushBackgroundThreadScheduler() {
getBackgroundThreadScheduler().advanceToLastPostedRunnable();
}
}

View File

@@ -39,7 +39,6 @@ import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentActivity;
import com.android.settings.R;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.testutils.shadow.ShadowUserManager;
@@ -50,6 +49,7 @@ import org.junit.runner.RunWith;
import org.mockito.Answers;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.android.controller.ActivityController;
import org.robolectric.annotation.Config;
@RunWith(SettingsRobolectricTestRunner.class)
@@ -94,7 +94,7 @@ public class EditUserInfoControllerTest {
MockitoAnnotations.initMocks(this);
mUserManager = ShadowUserManager.getShadow();
mUserManager.setUserInfo(0, mUserInfo);
mActivity = spy(Robolectric.buildActivity(FragmentActivity.class).get());
mActivity = spy(ActivityController.of(new FragmentActivity()).get());
when(mFragment.getActivity()).thenReturn(mActivity);
when(mActivity.getLayoutInflater()).thenReturn(mInflater);
when(mInflater.inflate(eq(R.layout.edit_user_info_dialog_content), any())).thenReturn(

View File

@@ -29,7 +29,6 @@ import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import android.app.admin.DevicePolicyManager;
import android.content.ComponentName;
import android.content.Context;
import android.content.SharedPreferences;
@@ -52,7 +51,6 @@ import androidx.preference.PreferenceScreen;
import com.android.settings.R;
import com.android.settings.dashboard.SummaryLoader;
import com.android.settings.testutils.Robolectric;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.testutils.shadow.ShadowDevicePolicyManager;
import com.android.settings.testutils.shadow.ShadowUserManager;
@@ -66,6 +64,7 @@ import org.mockito.AdditionalMatchers;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.android.controller.ActivityController;
import org.robolectric.annotation.Config;
import org.robolectric.util.ReflectionHelpers;
@@ -103,7 +102,7 @@ public class UserSettingsTest {
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
mActivity = spy(Robolectric.buildActivity(FragmentActivity.class).get());
mActivity = spy(ActivityController.of(new FragmentActivity()).get());
mContext = spy(RuntimeEnvironment.application);
mFragment = spy(new UserSettings());
ReflectionHelpers.setField(mFragment, "mAddUserWhenLockedPreferenceController",

View File

@@ -26,13 +26,13 @@ import android.view.View;
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
import com.android.settings.testutils.shadow.ShadowConnectivityManager;
import com.android.settingslib.testutils.FragmentTestUtils;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.MockitoAnnotations;
import org.robolectric.annotation.Config;
import org.robolectric.shadows.androidx.fragment.FragmentController;
@RunWith(SettingsRobolectricTestRunner.class)
@Config(shadows = ShadowConnectivityManager.class)
@@ -44,7 +44,7 @@ public class AddNetworkFragmentTest {
public void setUp() {
MockitoAnnotations.initMocks(this);
mAddNetworkFragment = spy(new AddNetworkFragment());
FragmentTestUtils.startFragment(mAddNetworkFragment);
FragmentController.setupFragment(mAddNetworkFragment);
}
@Test