summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorGlen Kuhne <kuh@google.com>2016-03-30 19:02:08 -0700
committerGlen Kuhne <kuh@google.com>2016-04-08 11:14:12 -0700
commit0efd09fea566f4445807b6aff60b18e127e72d38 (patch)
tree383ddd010645047e7c983af1054f49719e5a3410 /tests
parentf37079e3d8f4aca3242a971cbaef732fe1b75bde (diff)
Added buffering of filtered ScanDetails to QNS
Added logic to buffer the scanDetails considered by QualifiedNetworkSelection as potential candidates (has a saved config, and signal strength over threshold). And a getter to access these. BUG=27932650 Change-Id: I4e04194c944f7d8a18719d7dfc7b66cbf42eb5af
Diffstat (limited to 'tests')
-rw-r--r--tests/wifitests/src/com/android/server/wifi/WifiQualifiedNetworkSelectorTest.java165
1 files changed, 164 insertions, 1 deletions
diff --git a/tests/wifitests/src/com/android/server/wifi/WifiQualifiedNetworkSelectorTest.java b/tests/wifitests/src/com/android/server/wifi/WifiQualifiedNetworkSelectorTest.java
index cc42a9d61..3d7aa65f1 100644
--- a/tests/wifitests/src/com/android/server/wifi/WifiQualifiedNetworkSelectorTest.java
+++ b/tests/wifitests/src/com/android/server/wifi/WifiQualifiedNetworkSelectorTest.java
@@ -23,7 +23,6 @@ import static com.android.server.wifi.WifiConfigurationTestUtil.generateWifiConf
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertSame;
-import static org.junit.Assert.assertTrue;
import static org.mockito.Matchers.any;
import static org.mockito.Matchers.anyBoolean;
import static org.mockito.Matchers.anyInt;
@@ -258,6 +257,13 @@ public class WifiQualifiedNetworkSelectorTest {
when(mScoreCache.hasScoreCurve(scanResult)).thenReturn(true);
when(mScoreCache.getNetworkScore(eq(scanResult), anyBoolean())).thenReturn(score);
when(mScoreCache.getNetworkScore(scanResult)).thenReturn(score);
+ } else {
+ when(mScoreCache.isScoredNetwork(scanResult)).thenReturn(false);
+ when(mScoreCache.hasScoreCurve(scanResult)).thenReturn(false);
+ when(mScoreCache.getNetworkScore(eq(scanResult), anyBoolean())).thenReturn(
+ WifiNetworkScoreCache.INVALID_NETWORK_SCORE);
+ when(mScoreCache.getNetworkScore(scanResult)).thenReturn(
+ WifiNetworkScoreCache.INVALID_NETWORK_SCORE);
}
when(mScoreCache.getMeteredHint(scanResult)).thenReturn(meteredHints[i]);
}
@@ -1075,6 +1081,8 @@ public class WifiQualifiedNetworkSelectorTest {
WifiConfiguration candidate = mWifiQualifiedNetworkSelector.selectQualifiedNetwork(false,
false, scanDetails, false, true, false, false);
assertEquals("choose the wrong BSSID", null, candidate);
+ assertEquals("Should receive zero filteredScanDetails", 0,
+ mWifiQualifiedNetworkSelector.getFilteredScanDetails().size());
}
/**
@@ -1645,4 +1653,159 @@ public class WifiQualifiedNetworkSelectorTest {
assertSame(candidate, unTrustedNetworkCandidate);
assertEquals(meteredHints[1], candidate.meteredHint);
}
+
+ /**
+ * Case #34 Test Filtering of potential candidate scanDetails (Untrusted allowed)
+ *
+ * In this test. we simulate following scenario
+ * WifiStateMachine is under disconnected state
+ * test1 is @ 2GHz with RSSI -60
+ * test2 is @ 5Ghz with RSSI -86, (below minimum threshold)
+ * test3 is @ 5Ghz with RSSI -50, however it has no associated saved config
+ * test4 is @ 2Ghz with RSSI -62, no associated config, but is Ephemeral
+ *
+ * Expected behavior: test1 is chosen due to 5GHz signal is too weak (5GHz bonus can not
+ * compensate).
+ * test1 & test4's scanDetails are returned by 'getFilteredScanDetail()'
+ */
+ @Test
+ public void testGetFilteredScanDetailsReturnsOnlyConsideredScanDetails_untrustedAllowed() {
+ String[] ssids = {"\"test1\"", "\"test2\"", "\"test3\"", "\"test4\""};
+ String[] bssids = {"6c:f3:7f:ae:8c:f3", "6c:f3:7f:ae:8c:f4", "de:ad:ba:b1:e5:55",
+ "c0:ff:ee:ee:e3:ee"};
+ int[] frequencies = {2437, 5180, 5180, 2437};
+ String[] caps = {"[WPA2-EAP-CCMP][ESS]", "[WPA2-EAP-CCMP][ESS]", "[WPA2-EAP-CCMP][ESS]",
+ "[WPA2-EAP-CCMP][ESS]"};
+ int[] levels = {-60, -86, -50, -62};
+ int[] security = {SECURITY_PSK, SECURITY_PSK, SECURITY_PSK, SECURITY_PSK};
+ boolean[] meteredHints = {false, false, false, true};
+ Integer[] scores = {null, null, null, 120};
+
+ //Create all 4 scanDetails
+ List<ScanDetail> scanDetails = getScanDetails(ssids, bssids, frequencies, caps, levels);
+
+ //Setup NetworkScoreCache for detecting ephemeral networks ("test4")
+ configureScoreCache(scanDetails, scores, meteredHints);
+ WifiConfiguration unTrustedNetworkCandidate = mock(WifiConfiguration.class);
+ unTrustedNetworkCandidate.SSID = null;
+ unTrustedNetworkCandidate.networkId = WifiConfiguration.INVALID_NETWORK_ID;
+ ScanResult untrustedScanResult = scanDetails.get(3).getScanResult();
+ when(mWifiConfigManager
+ .wifiConfigurationFromScanResult(untrustedScanResult))
+ .thenReturn(unTrustedNetworkCandidate);
+ WifiConfiguration.NetworkSelectionStatus selectionStatus =
+ mock(WifiConfiguration.NetworkSelectionStatus.class);
+ when(unTrustedNetworkCandidate.getNetworkSelectionStatus()).thenReturn(selectionStatus);
+
+ //Set up associated configs for test1 & test2
+ WifiConfiguration[] savedConfigs = generateWifiConfigurations(
+ Arrays.copyOfRange(ssids, 0, 2), Arrays.copyOfRange(security, 0, 2));
+ prepareConfigStore(savedConfigs);
+ List<ScanDetail> savedScanDetails = new ArrayList<ScanDetail>(scanDetails.subList(0, 2));
+ final List<WifiConfiguration> savedNetwork = Arrays.asList(savedConfigs);
+ when(mWifiConfigManager.getConfiguredNetworks()).thenReturn(savedNetwork);
+ scanResultLinkConfiguration(savedConfigs, savedScanDetails);
+
+ //Force mock ConfigManager to return null (and not an empty list) for "test3" & "test4"
+ when(mWifiConfigManager.updateSavedNetworkWithNewScanDetail(scanDetails.get(2)))
+ .thenReturn(null);
+ when(mWifiConfigManager.updateSavedNetworkWithNewScanDetail(scanDetails.get(3)))
+ .thenReturn(null);
+
+ ScanResult chosenScanResult = scanDetails.get(0).getScanResult();
+
+ WifiConfiguration candidate = mWifiQualifiedNetworkSelector.selectQualifiedNetwork(
+ false /* forceSelectNetwork */,
+ true /* isUntrustedConnectionsAllowed */,
+ scanDetails,
+ false, /* isLinkDebouncing */
+ false, /* isConnected */
+ true, /* isDisconnected */
+ false /* isSupplicantTransient */);
+
+ verifySelectedResult(chosenScanResult, candidate);
+ //Verify two scanDetails returned in the filteredScanDetails
+ assertEquals(2, mWifiQualifiedNetworkSelector.getFilteredScanDetails().size());
+ assertEquals(mWifiQualifiedNetworkSelector.getFilteredScanDetails().get(0).toString(),
+ scanDetails.get(0).toString());
+ assertEquals(mWifiQualifiedNetworkSelector.getFilteredScanDetails().get(1).toString(),
+ scanDetails.get(3).toString());
+ }
+
+
+ /**
+ * Case #35 Test Filtering of potential candidate scanDetails (Untrusted disallowed)
+ *
+ * In this test. we simulate following scenario
+ * WifiStateMachine is under disconnected state
+ * test1 is @ 2GHz with RSSI -60
+ * test2 is @ 5Ghz with RSSI -86, (below minimum threshold)
+ * test3 is @ 5Ghz with RSSI -50, however it has no associated saved config
+ * test4 is @ 2Ghz with RSSI -62, no associated config, but is Ephemeral
+ *
+ * Expected behavior: test1 is chosen due to 5GHz signal is too weak (5GHz bonus can not
+ * compensate).
+ * test1 & test4's scanDetails are returned by 'getFilteredScanDetail()'
+ */
+ @Test
+ public void testGetFilteredScanDetailsReturnsOnlyConsideredScanDetails_untrustedDisallowed() {
+ String[] ssids = {"\"test1\"", "\"test2\"", "\"test3\"", "\"test4\""};
+ String[] bssids = {"6c:f3:7f:ae:8c:f3", "6c:f3:7f:ae:8c:f4", "de:ad:ba:b1:e5:55",
+ "c0:ff:ee:ee:e3:ee"};
+ int[] frequencies = {2437, 5180, 5180, 2437};
+ String[] caps = {"[WPA2-EAP-CCMP][ESS]", "[WPA2-EAP-CCMP][ESS]", "[WPA2-EAP-CCMP][ESS]",
+ "[WPA2-EAP-CCMP][ESS]"};
+ int[] levels = {-60, -86, -50, -62};
+ int[] security = {SECURITY_PSK, SECURITY_PSK, SECURITY_PSK, SECURITY_PSK};
+ boolean[] meteredHints = {false, false, false, true};
+ Integer[] scores = {null, null, null, 120};
+
+ //Create all 4 scanDetails
+ List<ScanDetail> scanDetails = getScanDetails(ssids, bssids, frequencies, caps, levels);
+
+ //Setup NetworkScoreCache for detecting ephemeral networks ("test4")
+ configureScoreCache(scanDetails, scores, meteredHints);
+ WifiConfiguration unTrustedNetworkCandidate = mock(WifiConfiguration.class);
+ unTrustedNetworkCandidate.SSID = null;
+ unTrustedNetworkCandidate.networkId = WifiConfiguration.INVALID_NETWORK_ID;
+ ScanResult untrustedScanResult = scanDetails.get(3).getScanResult();
+ when(mWifiConfigManager
+ .wifiConfigurationFromScanResult(untrustedScanResult))
+ .thenReturn(unTrustedNetworkCandidate);
+ WifiConfiguration.NetworkSelectionStatus selectionStatus =
+ mock(WifiConfiguration.NetworkSelectionStatus.class);
+ when(unTrustedNetworkCandidate.getNetworkSelectionStatus()).thenReturn(selectionStatus);
+
+ //Set up associated configs for test1 & test2
+ WifiConfiguration[] savedConfigs = generateWifiConfigurations(
+ Arrays.copyOfRange(ssids, 0, 2), Arrays.copyOfRange(security, 0, 2));
+ prepareConfigStore(savedConfigs);
+ List<ScanDetail> savedScanDetails = new ArrayList<ScanDetail>(scanDetails.subList(0, 2));
+ final List<WifiConfiguration> savedNetwork = Arrays.asList(savedConfigs);
+ when(mWifiConfigManager.getConfiguredNetworks()).thenReturn(savedNetwork);
+ scanResultLinkConfiguration(savedConfigs, savedScanDetails);
+
+ //Force mock ConfigManager to return null (and not an empty list) for "test3" & "test4"
+ when(mWifiConfigManager.updateSavedNetworkWithNewScanDetail(scanDetails.get(2)))
+ .thenReturn(null);
+ when(mWifiConfigManager.updateSavedNetworkWithNewScanDetail(scanDetails.get(3)))
+ .thenReturn(null);
+
+ ScanResult chosenScanResult = scanDetails.get(0).getScanResult();
+
+ WifiConfiguration candidate = mWifiQualifiedNetworkSelector.selectQualifiedNetwork(
+ false /* forceSelectNetwork */,
+ false /* isUntrustedConnectionsAllowed */,
+ scanDetails,
+ false, /* isLinkDebouncing */
+ false, /* isConnected */
+ true, /* isDisconnected */
+ false /* isSupplicantTransient */);
+
+ verifySelectedResult(chosenScanResult, candidate);
+ //Verify two scanDetails returned in the filteredScanDetails
+ assertEquals(1, mWifiQualifiedNetworkSelector.getFilteredScanDetails().size());
+ assertEquals(mWifiQualifiedNetworkSelector.getFilteredScanDetails().get(0).toString(),
+ scanDetails.get(0).toString());
+ }
}