1 /*
2  * Copyright (C) 2015 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.cts.managedprofile;
18 
19 import android.content.Context;
20 import android.content.Intent;
21 import android.net.wifi.WifiConfiguration;
22 import android.net.wifi.WifiManager;
23 import android.os.SystemClock;
24 import android.test.AndroidTestCase;
25 
26 import java.util.concurrent.TimeUnit;
27 
28 import static com.android.compatibility.common.util.WifiConfigCreator.ACTION_CREATE_WIFI_CONFIG;
29 import static com.android.compatibility.common.util.WifiConfigCreator.ACTION_REMOVE_WIFI_CONFIG;
30 import static com.android.compatibility.common.util.WifiConfigCreator.EXTRA_NETID;
31 import static com.android.compatibility.common.util.WifiConfigCreator.EXTRA_SSID;
32 
33 /**
34  * Driven by the host-side test: com.android.cts.devicepolicy.ManagedProfileTest
35  *
36  * Each of these tests can run independently but have side-effects. The side-effects are used as
37  * building blocks to test various cleanup routines, for example that networks belonging to one
38  * user are deleted
39  */
40 public class WifiTest extends AndroidTestCase {
41     private static final String TAG = WifiTest.class.getSimpleName();
42 
43     // Unique SSID to use for this test (max SSID length is 32)
44     private static final String NETWORK_SSID = "com.android.cts.xwde7ktvh8rmjuhr";
45 
46     // Time duration to allow before assuming that a WiFi operation failed and ceasing to wait.
47     private static final long UPDATE_TIMEOUT_MS = TimeUnit.SECONDS.toMillis(30);
48     private static final long UPDATE_INTERVAL_MS = TimeUnit.SECONDS.toMillis(1);
49 
50     // Shared WifiManager instance.
51     private WifiManager mWifiManager;
52 
53     @Override
setUp()54     public void setUp() throws Exception {
55         super.setUp();
56         mWifiManager = (WifiManager) getContext().getSystemService(Context.WIFI_SERVICE);
57     }
58 
59     /**
60      * Add a network through the WifiManager API. Verifies that the network was actually added.
61      *
62      * <p>Side effects:
63      * <ul>
64      *   <li>Network with SSID {@link WifiTest#NETWORK_SSID} is created.</li>
65      * </ul>
66      */
testAddWifiNetwork()67     public void testAddWifiNetwork() throws Exception {
68         Intent intent = new Intent(ACTION_CREATE_WIFI_CONFIG);
69         intent.putExtra(EXTRA_SSID, NETWORK_SSID);
70         intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
71         getContext().startActivity(intent);
72 
73         // Wait for configuration to appear in networks list.
74         assertTrue(awaitNetworkState(NETWORK_SSID, /* exists */ true));
75     }
76 
77     /**
78      * Remove any network through the WifiManager API with a certain SSID. Verifies that the network
79      * was actually removed.
80      *
81      * <p>Side effects:
82      * <ul>
83      *   <li>If a network with SSID {@link WifiTest#NETWORK_SSID} exists, it will be deleted.</li>
84      * </ul>
85      */
testRemoveWifiNetworkIfExists()86     public void testRemoveWifiNetworkIfExists() throws Exception {
87         WifiConfiguration config = getNetworkForSsid(NETWORK_SSID);
88 
89         if (config != null && config.networkId != -1) {
90             Intent intent = new Intent(ACTION_REMOVE_WIFI_CONFIG);
91             intent.putExtra(EXTRA_NETID, config.networkId);
92             intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
93             getContext().startActivity(intent);
94         }
95 
96         assertTrue(awaitNetworkState(NETWORK_SSID, /* exists */ false));
97     }
98 
99     /**
100      * Verify that no network exists with a certain SSID.
101      *
102      * <p>The SSID that will be checked for is {@link WifiTest#NETWORK_SSID}.
103      */
testWifiNetworkDoesNotExist()104     public void testWifiNetworkDoesNotExist() throws Exception {
105         assertTrue(awaitNetworkState(NETWORK_SSID, /* exists */ false));
106     }
107 
108     /**
109      * Block until a network configuration with a certain SSID either exists or ceases to.
110      * Wait for up to {@link WifiTest#UPDATE_TIMEOUT_MS} milliseconds, in increments of
111      * {@link WifiTest#UPDATE_INTERVAL_MS}.
112      */
awaitNetworkState(String ssid, boolean exists)113     private boolean awaitNetworkState(String ssid, boolean exists) {
114         for (int probes = 0; probes * UPDATE_INTERVAL_MS <= UPDATE_TIMEOUT_MS; probes++) {
115             if (probes != 0) {
116                 SystemClock.sleep(UPDATE_INTERVAL_MS);
117             }
118             if ((getNetworkForSsid(ssid) != null) == exists) {
119                 return true;
120             }
121         }
122         return false;
123     }
124 
125     /**
126      * Internal method to find an existing {@link WifiConfiguration} with the given SSID.
127      *
128      * @return A {@link WifiConfiguration} matching the specification, or {@code null} if no such
129      *         configuration exists.
130      */
getNetworkForSsid(String ssid)131     private WifiConfiguration getNetworkForSsid(String ssid) {
132         if (!ssid.startsWith("\"")) {
133             ssid = '"' + ssid + '"';
134         }
135         for (WifiConfiguration config : mWifiManager.getConfiguredNetworks()) {
136             if (ssid.equals(config.SSID)) {
137                 return config;
138             }
139         }
140         return null;
141     }
142 }
143