Added WifiSettings Espresso tests.
Added test cases for toggling Wi-Fi state, connected access points, and saved network preferences. Bug: 35322629 Bug: 35322690 Bug: 35322875 Test: runtest --path packages/apps/Settings/tests/unit/src/com/android/settings/wifi/WifiSettingsUiTest.java Change-Id: Iaba7fb2fa90cf0f37538c4b1ef141cf6b15d7f52
This commit is contained in:
@@ -16,25 +16,37 @@
|
|||||||
package com.android.settings.wifi;
|
package com.android.settings.wifi;
|
||||||
|
|
||||||
import static android.support.test.espresso.Espresso.onView;
|
import static android.support.test.espresso.Espresso.onView;
|
||||||
import static android.support.test.espresso.action.ViewActions.click;
|
import static android.support.test.espresso.assertion.ViewAssertions.doesNotExist;
|
||||||
|
import static android.support.test.espresso.assertion.ViewAssertions.matches;
|
||||||
|
import static android.support.test.espresso.matcher.ViewMatchers.Visibility.VISIBLE;
|
||||||
|
import static android.support.test.espresso.matcher.ViewMatchers.isDisplayed;
|
||||||
|
import static android.support.test.espresso.matcher.ViewMatchers.withEffectiveVisibility;
|
||||||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.hamcrest.Matchers.allOf;
|
||||||
|
import static org.hamcrest.Matchers.not;
|
||||||
|
import static org.hamcrest.Matchers.startsWith;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.Fragment;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.net.ConnectivityManager;
|
||||||
|
import android.net.NetworkInfo;
|
||||||
|
import android.net.wifi.WifiConfiguration;
|
||||||
|
import android.net.wifi.WifiInfo;
|
||||||
import android.net.wifi.WifiManager;
|
import android.net.wifi.WifiManager;
|
||||||
|
import android.net.wifi.WifiSsid;
|
||||||
import android.support.test.InstrumentationRegistry;
|
import android.support.test.InstrumentationRegistry;
|
||||||
import android.support.test.rule.ActivityTestRule;
|
import android.support.test.rule.ActivityTestRule;
|
||||||
import android.support.test.runner.AndroidJUnit4;
|
import android.support.test.runner.AndroidJUnit4;
|
||||||
|
|
||||||
import com.android.settings.Settings.WifiSettingsActivity;
|
import com.android.settings.Settings.WifiSettingsActivity;
|
||||||
import com.android.settingslib.wifi.AccessPoint;
|
import com.android.settingslib.wifi.AccessPoint;
|
||||||
import com.android.settingslib.wifi.WifiTracker;
|
import com.android.settingslib.wifi.WifiTracker;
|
||||||
|
import com.android.settingslib.wifi.WifiTracker.WifiListener;
|
||||||
import com.android.settingslib.wifi.WifiTrackerFactory;
|
import com.android.settingslib.wifi.WifiTrackerFactory;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -42,18 +54,32 @@ import org.junit.runner.RunWith;
|
|||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@RunWith(AndroidJUnit4.class)
|
@RunWith(AndroidJUnit4.class)
|
||||||
public class WifiSettingsUiTest {
|
public class WifiSettingsUiTest {
|
||||||
|
|
||||||
// TODO(sghuman): Investigate why resource ids are not resolving correctly in the test apk,
|
// TODO(b/37714546): Investigate why resource ids are not resolving correctly in the test apk,
|
||||||
// then remove this manual string entry
|
// then remove this manual string entry
|
||||||
|
/** R.string.wifi_configure_settings_preference_title */
|
||||||
private static final String WIFI_PREFERENCES = "Wi\u2011Fi preferences";
|
private static final String WIFI_PREFERENCES = "Wi\u2011Fi preferences";
|
||||||
|
/** R.string.wifi_saved_access_points_label */
|
||||||
|
private static final String SAVED_NETWORKS = "Saved networks";
|
||||||
|
/** R.string.wifi_empty_list_wifi_off */
|
||||||
|
private static final String WIFI_OFF_MESSAGE = "To see available networks, turn Wi\u2011Fi on.";
|
||||||
|
/** R.string.wifi_display_status_connected */
|
||||||
|
private static final String CONNECTED = "Connected";
|
||||||
|
|
||||||
@Mock private AccessPoint mockAccessPoint;
|
private static final String TEST_SSID = "\"Test Ssid\"";
|
||||||
@Mock private WifiTracker mockWifiTracker;
|
private static final String TEST_UNQUOTED_SSID = "Test Ssid";
|
||||||
@Mock private WifiManager mockWifiManager;
|
private static final String TEST_BSSID = "0a:08:5c:67:89:00";
|
||||||
|
private static final int TEST_RSSI = 123;
|
||||||
|
private static final int TEST_NETWORK_ID = 1;
|
||||||
|
|
||||||
|
@Mock private WifiTracker mWifiTracker;
|
||||||
|
@Mock private WifiManager mWifiManager;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
private WifiListener mWifiListener;
|
||||||
|
|
||||||
@Rule
|
@Rule
|
||||||
public ActivityTestRule<WifiSettingsActivity> mActivityRule =
|
public ActivityTestRule<WifiSettingsActivity> mActivityRule =
|
||||||
@@ -63,17 +89,54 @@ public class WifiSettingsUiTest {
|
|||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = InstrumentationRegistry.getTargetContext();
|
mContext = InstrumentationRegistry.getTargetContext();
|
||||||
|
WifiTrackerFactory.setTestingWifiTracker(mWifiTracker);
|
||||||
|
when(mWifiTracker.getManager()).thenReturn(mWifiManager);
|
||||||
|
}
|
||||||
|
|
||||||
WifiTrackerFactory.setTestingWifiTracker(mockWifiTracker);
|
private void setupConnectedAccessPoint() {
|
||||||
when(mockWifiTracker.getManager()).thenReturn(mockWifiManager);
|
WifiConfiguration config = new WifiConfiguration();
|
||||||
when(mockWifiTracker.getAccessPoints()).thenReturn(
|
config.SSID = TEST_SSID;
|
||||||
Lists.asList(mockAccessPoint, new AccessPoint[]{}));
|
config.BSSID = TEST_BSSID;
|
||||||
|
config.networkId = TEST_NETWORK_ID;
|
||||||
|
WifiInfo wifiInfo = new WifiInfo();
|
||||||
|
wifiInfo.setSSID(WifiSsid.createFromAsciiEncoded(TEST_UNQUOTED_SSID));
|
||||||
|
wifiInfo.setBSSID(TEST_BSSID);
|
||||||
|
wifiInfo.setRssi(TEST_RSSI);
|
||||||
|
wifiInfo.setNetworkId(TEST_NETWORK_ID);
|
||||||
|
NetworkInfo networkInfo = new NetworkInfo(ConnectivityManager.TYPE_WIFI, 0, null, null);
|
||||||
|
networkInfo.setDetailedState(NetworkInfo.DetailedState.CONNECTED, null, null);
|
||||||
|
AccessPoint accessPoint = new AccessPoint(mContext, config);
|
||||||
|
accessPoint.update(config, wifiInfo, networkInfo);
|
||||||
|
|
||||||
when(mockWifiManager.isWifiEnabled()).thenReturn(true);
|
assertThat(accessPoint.getSsidStr()).isEqualTo(TEST_UNQUOTED_SSID);
|
||||||
|
assertThat(accessPoint.getBssid()).isEqualTo(TEST_BSSID);
|
||||||
|
assertThat(accessPoint.getNetworkInfo()).isNotNull();
|
||||||
|
assertThat(accessPoint.isActive()).isTrue();
|
||||||
|
assertThat(accessPoint.getSettingsSummary()).isEqualTo(CONNECTED);
|
||||||
|
|
||||||
|
when(mWifiTracker.getAccessPoints()).thenReturn(
|
||||||
|
Lists.asList(accessPoint, new AccessPoint[]{}));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void launchActivity() {
|
private void launchActivity() {
|
||||||
mActivityRule.launchActivity(new Intent("android.settings.WIFI_SETTINGS"));
|
mActivityRule.launchActivity(new Intent("android.settings.WIFI_SETTINGS"));
|
||||||
|
|
||||||
|
verify(mWifiTracker).getManager();
|
||||||
|
|
||||||
|
List<Fragment> fragments = mActivityRule.getActivity().getFragmentManager().getFragments();
|
||||||
|
assertThat(fragments.size()).isEqualTo(1);
|
||||||
|
mWifiListener = (WifiSettings) fragments.get(0);
|
||||||
|
assertThat(mWifiListener).isNotNull();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setWifiState(int wifiState) {
|
||||||
|
when(mWifiManager.getWifiState()).thenReturn(wifiState);
|
||||||
|
when(mWifiManager.isWifiEnabled()).thenReturn(wifiState == WifiManager.WIFI_STATE_ENABLED);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void callOnWifiStateChanged(int state) {
|
||||||
|
mActivityRule.getActivity().getMainThreadHandler()
|
||||||
|
.post( () -> mWifiListener.onWifiStateChanged(state) );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -84,6 +147,59 @@ public class WifiSettingsUiTest {
|
|||||||
@Test
|
@Test
|
||||||
public void shouldShowWifiPreferences() {
|
public void shouldShowWifiPreferences() {
|
||||||
launchActivity();
|
launchActivity();
|
||||||
onView(withText(WIFI_PREFERENCES)).perform(click());
|
|
||||||
|
onView(withText(WIFI_PREFERENCES)).check(matches(isDisplayed()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void noSavedNetworks_shouldNotShowSavedNetworksButton() {
|
||||||
|
setWifiState(WifiManager.WIFI_STATE_ENABLED);
|
||||||
|
when(mWifiTracker.getNumSavedNetworks()).thenReturn(0);
|
||||||
|
|
||||||
|
launchActivity();
|
||||||
|
|
||||||
|
onView(withText(SAVED_NETWORKS)).check(matches(not(isDisplayed())));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void savedNetworksExist_shouldShowSavedNetworksButton() {
|
||||||
|
setWifiState(WifiManager.WIFI_STATE_ENABLED);
|
||||||
|
when(mWifiTracker.getNumSavedNetworks()).thenReturn(1);
|
||||||
|
|
||||||
|
launchActivity();
|
||||||
|
|
||||||
|
onView(allOf(withText(SAVED_NETWORKS),
|
||||||
|
withEffectiveVisibility(VISIBLE))).check(matches(isDisplayed()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onDisableWifi_seeOffMessage() {
|
||||||
|
setWifiState(WifiManager.WIFI_STATE_DISABLED);
|
||||||
|
|
||||||
|
launchActivity();
|
||||||
|
callOnWifiStateChanged(WifiManager.WIFI_STATE_DISABLED);
|
||||||
|
|
||||||
|
onView(withText(startsWith(WIFI_OFF_MESSAGE))).check(matches(isDisplayed()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onEnableWifi_shouldNotSeeOffMessage() {
|
||||||
|
setWifiState(WifiManager.WIFI_STATE_ENABLED);
|
||||||
|
|
||||||
|
launchActivity();
|
||||||
|
callOnWifiStateChanged(WifiManager.WIFI_STATE_ENABLED);
|
||||||
|
|
||||||
|
onView(withText(startsWith(WIFI_OFF_MESSAGE))).check(doesNotExist());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onConnected_shouldSeeConnectedMessage() {
|
||||||
|
setWifiState(WifiManager.WIFI_STATE_ENABLED);
|
||||||
|
setupConnectedAccessPoint();
|
||||||
|
when(mWifiTracker.isConnected()).thenReturn(true);
|
||||||
|
|
||||||
|
launchActivity();
|
||||||
|
|
||||||
|
onView(withText(CONNECTED)).check(matches(isDisplayed()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user