Merge "Update VPN capabilities when its underlying network set is null." am: c7702baa80
am: 07fff8eb3c
Change-Id: I832cbc4646c010add5a4f051d3f7151cfc94120c
This commit is contained in:
@@ -919,7 +919,8 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
|
|
||||||
mPermissionMonitor = new PermissionMonitor(mContext, mNMS);
|
mPermissionMonitor = new PermissionMonitor(mContext, mNMS);
|
||||||
|
|
||||||
//set up the listener for user state for creating user VPNs
|
// Set up the listener for user state for creating user VPNs.
|
||||||
|
// Should run on mHandler to avoid any races.
|
||||||
IntentFilter intentFilter = new IntentFilter();
|
IntentFilter intentFilter = new IntentFilter();
|
||||||
intentFilter.addAction(Intent.ACTION_USER_STARTED);
|
intentFilter.addAction(Intent.ACTION_USER_STARTED);
|
||||||
intentFilter.addAction(Intent.ACTION_USER_STOPPED);
|
intentFilter.addAction(Intent.ACTION_USER_STOPPED);
|
||||||
@@ -927,7 +928,11 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
intentFilter.addAction(Intent.ACTION_USER_REMOVED);
|
intentFilter.addAction(Intent.ACTION_USER_REMOVED);
|
||||||
intentFilter.addAction(Intent.ACTION_USER_UNLOCKED);
|
intentFilter.addAction(Intent.ACTION_USER_UNLOCKED);
|
||||||
mContext.registerReceiverAsUser(
|
mContext.registerReceiverAsUser(
|
||||||
mIntentReceiver, UserHandle.ALL, intentFilter, null, null);
|
mIntentReceiver,
|
||||||
|
UserHandle.ALL,
|
||||||
|
intentFilter,
|
||||||
|
null /* broadcastPermission */,
|
||||||
|
mHandler);
|
||||||
mContext.registerReceiverAsUser(mUserPresentReceiver, UserHandle.SYSTEM,
|
mContext.registerReceiverAsUser(mUserPresentReceiver, UserHandle.SYSTEM,
|
||||||
new IntentFilter(Intent.ACTION_USER_PRESENT), null, null);
|
new IntentFilter(Intent.ACTION_USER_PRESENT), null, null);
|
||||||
|
|
||||||
@@ -938,7 +943,11 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
intentFilter.addAction(Intent.ACTION_PACKAGE_REMOVED);
|
intentFilter.addAction(Intent.ACTION_PACKAGE_REMOVED);
|
||||||
intentFilter.addDataScheme("package");
|
intentFilter.addDataScheme("package");
|
||||||
mContext.registerReceiverAsUser(
|
mContext.registerReceiverAsUser(
|
||||||
mIntentReceiver, UserHandle.ALL, intentFilter, null, null);
|
mIntentReceiver,
|
||||||
|
UserHandle.ALL,
|
||||||
|
intentFilter,
|
||||||
|
null /* broadcastPermission */,
|
||||||
|
mHandler);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
mNMS.registerObserver(mTethering);
|
mNMS.registerObserver(mTethering);
|
||||||
@@ -4128,17 +4137,27 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
* handler thread through their agent, this is asynchronous. When the capabilities objects
|
* handler thread through their agent, this is asynchronous. When the capabilities objects
|
||||||
* are computed they will be up-to-date as they are computed synchronously from here and
|
* are computed they will be up-to-date as they are computed synchronously from here and
|
||||||
* this is running on the ConnectivityService thread.
|
* this is running on the ConnectivityService thread.
|
||||||
* TODO : Fix this and call updateCapabilities inline to remove out-of-order events.
|
|
||||||
*/
|
*/
|
||||||
private void updateAllVpnsCapabilities() {
|
private void updateAllVpnsCapabilities() {
|
||||||
|
Network defaultNetwork = getNetwork(getDefaultNetwork());
|
||||||
synchronized (mVpns) {
|
synchronized (mVpns) {
|
||||||
for (int i = 0; i < mVpns.size(); i++) {
|
for (int i = 0; i < mVpns.size(); i++) {
|
||||||
final Vpn vpn = mVpns.valueAt(i);
|
final Vpn vpn = mVpns.valueAt(i);
|
||||||
vpn.updateCapabilities();
|
NetworkCapabilities nc = vpn.updateCapabilities(defaultNetwork);
|
||||||
|
updateVpnCapabilities(vpn, nc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateVpnCapabilities(Vpn vpn, @Nullable NetworkCapabilities nc) {
|
||||||
|
ensureRunningOnConnectivityServiceThread();
|
||||||
|
NetworkAgentInfo vpnNai = getNetworkAgentInfoForNetId(vpn.getNetId());
|
||||||
|
if (vpnNai == null || nc == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
updateCapabilities(vpnNai.getCurrentScore(), vpnNai, nc);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean updateLockdownVpn() {
|
public boolean updateLockdownVpn() {
|
||||||
if (Binder.getCallingUid() != Process.SYSTEM_UID) {
|
if (Binder.getCallingUid() != Process.SYSTEM_UID) {
|
||||||
@@ -4479,22 +4498,28 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
|
|
||||||
private void onUserAdded(int userId) {
|
private void onUserAdded(int userId) {
|
||||||
mPermissionMonitor.onUserAdded(userId);
|
mPermissionMonitor.onUserAdded(userId);
|
||||||
|
Network defaultNetwork = getNetwork(getDefaultNetwork());
|
||||||
synchronized (mVpns) {
|
synchronized (mVpns) {
|
||||||
final int vpnsSize = mVpns.size();
|
final int vpnsSize = mVpns.size();
|
||||||
for (int i = 0; i < vpnsSize; i++) {
|
for (int i = 0; i < vpnsSize; i++) {
|
||||||
Vpn vpn = mVpns.valueAt(i);
|
Vpn vpn = mVpns.valueAt(i);
|
||||||
vpn.onUserAdded(userId);
|
vpn.onUserAdded(userId);
|
||||||
|
NetworkCapabilities nc = vpn.updateCapabilities(defaultNetwork);
|
||||||
|
updateVpnCapabilities(vpn, nc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onUserRemoved(int userId) {
|
private void onUserRemoved(int userId) {
|
||||||
mPermissionMonitor.onUserRemoved(userId);
|
mPermissionMonitor.onUserRemoved(userId);
|
||||||
|
Network defaultNetwork = getNetwork(getDefaultNetwork());
|
||||||
synchronized (mVpns) {
|
synchronized (mVpns) {
|
||||||
final int vpnsSize = mVpns.size();
|
final int vpnsSize = mVpns.size();
|
||||||
for (int i = 0; i < vpnsSize; i++) {
|
for (int i = 0; i < vpnsSize; i++) {
|
||||||
Vpn vpn = mVpns.valueAt(i);
|
Vpn vpn = mVpns.valueAt(i);
|
||||||
vpn.onUserRemoved(userId);
|
vpn.onUserRemoved(userId);
|
||||||
|
NetworkCapabilities nc = vpn.updateCapabilities(defaultNetwork);
|
||||||
|
updateVpnCapabilities(vpn, nc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -4563,6 +4588,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
private BroadcastReceiver mIntentReceiver = new BroadcastReceiver() {
|
private BroadcastReceiver mIntentReceiver = new BroadcastReceiver() {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
ensureRunningOnConnectivityServiceThread();
|
||||||
final String action = intent.getAction();
|
final String action = intent.getAction();
|
||||||
final int userId = intent.getIntExtra(Intent.EXTRA_USER_HANDLE, UserHandle.USER_NULL);
|
final int userId = intent.getIntExtra(Intent.EXTRA_USER_HANDLE, UserHandle.USER_NULL);
|
||||||
final int uid = intent.getIntExtra(Intent.EXTRA_UID, -1);
|
final int uid = intent.getIntExtra(Intent.EXTRA_UID, -1);
|
||||||
@@ -5067,6 +5093,19 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
return getNetworkForRequest(mDefaultRequest.requestId);
|
return getNetworkForRequest(mDefaultRequest.requestId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
private Network getNetwork(@Nullable NetworkAgentInfo nai) {
|
||||||
|
return nai != null ? nai.network : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ensureRunningOnConnectivityServiceThread() {
|
||||||
|
if (mHandler.getLooper().getThread() != Thread.currentThread()) {
|
||||||
|
throw new IllegalStateException(
|
||||||
|
"Not running on ConnectivityService thread: "
|
||||||
|
+ Thread.currentThread().getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private boolean isDefaultNetwork(NetworkAgentInfo nai) {
|
private boolean isDefaultNetwork(NetworkAgentInfo nai) {
|
||||||
return nai == getDefaultNetwork();
|
return nai == getDefaultNetwork();
|
||||||
}
|
}
|
||||||
@@ -5665,6 +5704,8 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
updateTcpBufferSizes(newNetwork.linkProperties.getTcpBufferSizes());
|
updateTcpBufferSizes(newNetwork.linkProperties.getTcpBufferSizes());
|
||||||
mDnsManager.setDefaultDnsSystemProperties(newNetwork.linkProperties.getDnsServers());
|
mDnsManager.setDefaultDnsSystemProperties(newNetwork.linkProperties.getDnsServers());
|
||||||
notifyIfacesChangedForNetworkStats();
|
notifyIfacesChangedForNetworkStats();
|
||||||
|
// Fix up the NetworkCapabilities of any VPNs that don't specify underlying networks.
|
||||||
|
updateAllVpnsCapabilities();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void processListenRequests(NetworkAgentInfo nai, boolean capabilitiesChanged) {
|
private void processListenRequests(NetworkAgentInfo nai, boolean capabilitiesChanged) {
|
||||||
@@ -6104,6 +6145,10 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
// doing.
|
// doing.
|
||||||
updateSignalStrengthThresholds(networkAgent, "CONNECT", null);
|
updateSignalStrengthThresholds(networkAgent, "CONNECT", null);
|
||||||
|
|
||||||
|
if (networkAgent.isVPN()) {
|
||||||
|
updateAllVpnsCapabilities();
|
||||||
|
}
|
||||||
|
|
||||||
// Consider network even though it is not yet validated.
|
// Consider network even though it is not yet validated.
|
||||||
final long now = SystemClock.elapsedRealtime();
|
final long now = SystemClock.elapsedRealtime();
|
||||||
rematchNetworkAndRequests(networkAgent, ReapUnvalidatedNetworks.REAP, now);
|
rematchNetworkAndRequests(networkAgent, ReapUnvalidatedNetworks.REAP, now);
|
||||||
@@ -6365,7 +6410,11 @@ public class ConnectivityService extends IConnectivityManager.Stub
|
|||||||
success = mVpns.get(user).setUnderlyingNetworks(networks);
|
success = mVpns.get(user).setUnderlyingNetworks(networks);
|
||||||
}
|
}
|
||||||
if (success) {
|
if (success) {
|
||||||
mHandler.post(() -> notifyIfacesChangedForNetworkStats());
|
mHandler.post(() -> {
|
||||||
|
// Update VPN's capabilities based on updated underlying network set.
|
||||||
|
updateAllVpnsCapabilities();
|
||||||
|
notifyIfacesChangedForNetworkStats();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ import static android.net.ConnectivityManager.CONNECTIVITY_ACTION;
|
|||||||
import static android.net.ConnectivityManager.PRIVATE_DNS_MODE_OFF;
|
import static android.net.ConnectivityManager.PRIVATE_DNS_MODE_OFF;
|
||||||
import static android.net.ConnectivityManager.PRIVATE_DNS_MODE_OPPORTUNISTIC;
|
import static android.net.ConnectivityManager.PRIVATE_DNS_MODE_OPPORTUNISTIC;
|
||||||
import static android.net.ConnectivityManager.PRIVATE_DNS_MODE_PROVIDER_HOSTNAME;
|
import static android.net.ConnectivityManager.PRIVATE_DNS_MODE_PROVIDER_HOSTNAME;
|
||||||
|
import static android.net.ConnectivityManager.NETID_UNSET;
|
||||||
import static android.net.ConnectivityManager.TYPE_ETHERNET;
|
import static android.net.ConnectivityManager.TYPE_ETHERNET;
|
||||||
import static android.net.ConnectivityManager.TYPE_MOBILE;
|
import static android.net.ConnectivityManager.TYPE_MOBILE;
|
||||||
import static android.net.ConnectivityManager.TYPE_MOBILE_FOTA;
|
import static android.net.ConnectivityManager.TYPE_MOBILE_FOTA;
|
||||||
@@ -885,11 +886,14 @@ public class ConnectivityServiceTest {
|
|||||||
|
|
||||||
public void setUids(Set<UidRange> uids) {
|
public void setUids(Set<UidRange> uids) {
|
||||||
mNetworkCapabilities.setUids(uids);
|
mNetworkCapabilities.setUids(uids);
|
||||||
updateCapabilities();
|
updateCapabilities(null /* defaultNetwork */);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getNetId() {
|
public int getNetId() {
|
||||||
|
if (mMockNetworkAgent == null) {
|
||||||
|
return NETID_UNSET;
|
||||||
|
}
|
||||||
return mMockNetworkAgent.getNetwork().netId;
|
return mMockNetworkAgent.getNetwork().netId;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -911,12 +915,13 @@ public class ConnectivityServiceTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateCapabilities() {
|
public NetworkCapabilities updateCapabilities(Network defaultNetwork) {
|
||||||
if (!mConnected) return;
|
if (!mConnected) return null;
|
||||||
super.updateCapabilities();
|
super.updateCapabilities(defaultNetwork);
|
||||||
// Because super.updateCapabilities will update the capabilities of the agent but not
|
// Because super.updateCapabilities will update the capabilities of the agent but
|
||||||
// the mock agent, the mock agent needs to know about them.
|
// not the mock agent, the mock agent needs to know about them.
|
||||||
copyCapabilitiesToNetworkAgent();
|
copyCapabilitiesToNetworkAgent();
|
||||||
|
return new NetworkCapabilities(mNetworkCapabilities);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void copyCapabilitiesToNetworkAgent() {
|
private void copyCapabilitiesToNetworkAgent() {
|
||||||
@@ -4669,6 +4674,7 @@ public class ConnectivityServiceTest {
|
|||||||
|
|
||||||
vpnNetworkAgent.connect(false);
|
vpnNetworkAgent.connect(false);
|
||||||
mMockVpn.connect();
|
mMockVpn.connect();
|
||||||
|
mMockVpn.setUnderlyingNetworks(new Network[0]);
|
||||||
|
|
||||||
genericNetworkCallback.expectAvailableCallbacksUnvalidated(vpnNetworkAgent);
|
genericNetworkCallback.expectAvailableCallbacksUnvalidated(vpnNetworkAgent);
|
||||||
genericNotVpnNetworkCallback.assertNoCallback();
|
genericNotVpnNetworkCallback.assertNoCallback();
|
||||||
@@ -4701,6 +4707,7 @@ public class ConnectivityServiceTest {
|
|||||||
|
|
||||||
ranges.add(new UidRange(uid, uid));
|
ranges.add(new UidRange(uid, uid));
|
||||||
mMockVpn.setUids(ranges);
|
mMockVpn.setUids(ranges);
|
||||||
|
vpnNetworkAgent.setUids(ranges);
|
||||||
|
|
||||||
genericNetworkCallback.expectAvailableCallbacksValidated(vpnNetworkAgent);
|
genericNetworkCallback.expectAvailableCallbacksValidated(vpnNetworkAgent);
|
||||||
genericNotVpnNetworkCallback.assertNoCallback();
|
genericNotVpnNetworkCallback.assertNoCallback();
|
||||||
@@ -4734,12 +4741,11 @@ public class ConnectivityServiceTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testVpnWithAndWithoutInternet() {
|
public void testVpnWithoutInternet() {
|
||||||
final int uid = Process.myUid();
|
final int uid = Process.myUid();
|
||||||
|
|
||||||
final TestNetworkCallback defaultCallback = new TestNetworkCallback();
|
final TestNetworkCallback defaultCallback = new TestNetworkCallback();
|
||||||
mCm.registerDefaultNetworkCallback(defaultCallback);
|
mCm.registerDefaultNetworkCallback(defaultCallback);
|
||||||
defaultCallback.assertNoCallback();
|
|
||||||
|
|
||||||
mWiFiNetworkAgent = new MockNetworkAgent(TRANSPORT_WIFI);
|
mWiFiNetworkAgent = new MockNetworkAgent(TRANSPORT_WIFI);
|
||||||
mWiFiNetworkAgent.connect(true);
|
mWiFiNetworkAgent.connect(true);
|
||||||
@@ -4761,11 +4767,30 @@ public class ConnectivityServiceTest {
|
|||||||
vpnNetworkAgent.disconnect();
|
vpnNetworkAgent.disconnect();
|
||||||
defaultCallback.assertNoCallback();
|
defaultCallback.assertNoCallback();
|
||||||
|
|
||||||
vpnNetworkAgent = new MockNetworkAgent(TRANSPORT_VPN);
|
mCm.unregisterNetworkCallback(defaultCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testVpnWithInternet() {
|
||||||
|
final int uid = Process.myUid();
|
||||||
|
|
||||||
|
final TestNetworkCallback defaultCallback = new TestNetworkCallback();
|
||||||
|
mCm.registerDefaultNetworkCallback(defaultCallback);
|
||||||
|
|
||||||
|
mWiFiNetworkAgent = new MockNetworkAgent(TRANSPORT_WIFI);
|
||||||
|
mWiFiNetworkAgent.connect(true);
|
||||||
|
|
||||||
|
defaultCallback.expectAvailableThenValidatedCallbacks(mWiFiNetworkAgent);
|
||||||
|
assertEquals(defaultCallback.getLastAvailableNetwork(), mCm.getActiveNetwork());
|
||||||
|
|
||||||
|
MockNetworkAgent vpnNetworkAgent = new MockNetworkAgent(TRANSPORT_VPN);
|
||||||
|
final ArraySet<UidRange> ranges = new ArraySet<>();
|
||||||
|
ranges.add(new UidRange(uid, uid));
|
||||||
mMockVpn.setNetworkAgent(vpnNetworkAgent);
|
mMockVpn.setNetworkAgent(vpnNetworkAgent);
|
||||||
mMockVpn.setUids(ranges);
|
mMockVpn.setUids(ranges);
|
||||||
vpnNetworkAgent.connect(true /* validated */, true /* hasInternet */);
|
vpnNetworkAgent.connect(true /* validated */, true /* hasInternet */);
|
||||||
mMockVpn.connect();
|
mMockVpn.connect();
|
||||||
|
|
||||||
defaultCallback.expectAvailableThenValidatedCallbacks(vpnNetworkAgent);
|
defaultCallback.expectAvailableThenValidatedCallbacks(vpnNetworkAgent);
|
||||||
assertEquals(defaultCallback.getLastAvailableNetwork(), mCm.getActiveNetwork());
|
assertEquals(defaultCallback.getLastAvailableNetwork(), mCm.getActiveNetwork());
|
||||||
|
|
||||||
@@ -4773,14 +4798,6 @@ public class ConnectivityServiceTest {
|
|||||||
defaultCallback.expectCallback(CallbackState.LOST, vpnNetworkAgent);
|
defaultCallback.expectCallback(CallbackState.LOST, vpnNetworkAgent);
|
||||||
defaultCallback.expectAvailableCallbacksValidated(mWiFiNetworkAgent);
|
defaultCallback.expectAvailableCallbacksValidated(mWiFiNetworkAgent);
|
||||||
|
|
||||||
vpnNetworkAgent = new MockNetworkAgent(TRANSPORT_VPN);
|
|
||||||
ranges.clear();
|
|
||||||
mMockVpn.setNetworkAgent(vpnNetworkAgent);
|
|
||||||
mMockVpn.setUids(ranges);
|
|
||||||
vpnNetworkAgent.connect(false /* validated */, true /* hasInternet */);
|
|
||||||
mMockVpn.connect();
|
|
||||||
defaultCallback.assertNoCallback();
|
|
||||||
|
|
||||||
mCm.unregisterNetworkCallback(defaultCallback);
|
mCm.unregisterNetworkCallback(defaultCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4882,6 +4899,70 @@ public class ConnectivityServiceTest {
|
|||||||
mMockVpn.disconnect();
|
mMockVpn.disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNullUnderlyingNetworks() {
|
||||||
|
final int uid = Process.myUid();
|
||||||
|
|
||||||
|
final TestNetworkCallback vpnNetworkCallback = new TestNetworkCallback();
|
||||||
|
final NetworkRequest vpnNetworkRequest = new NetworkRequest.Builder()
|
||||||
|
.removeCapability(NET_CAPABILITY_NOT_VPN)
|
||||||
|
.addTransportType(TRANSPORT_VPN)
|
||||||
|
.build();
|
||||||
|
NetworkCapabilities nc;
|
||||||
|
mCm.registerNetworkCallback(vpnNetworkRequest, vpnNetworkCallback);
|
||||||
|
vpnNetworkCallback.assertNoCallback();
|
||||||
|
|
||||||
|
final MockNetworkAgent vpnNetworkAgent = new MockNetworkAgent(TRANSPORT_VPN);
|
||||||
|
final ArraySet<UidRange> ranges = new ArraySet<>();
|
||||||
|
ranges.add(new UidRange(uid, uid));
|
||||||
|
mMockVpn.setNetworkAgent(vpnNetworkAgent);
|
||||||
|
mMockVpn.connect();
|
||||||
|
mMockVpn.setUids(ranges);
|
||||||
|
vpnNetworkAgent.connect(true /* validated */, false /* hasInternet */);
|
||||||
|
|
||||||
|
vpnNetworkCallback.expectAvailableThenValidatedCallbacks(vpnNetworkAgent);
|
||||||
|
nc = mCm.getNetworkCapabilities(vpnNetworkAgent.getNetwork());
|
||||||
|
assertTrue(nc.hasTransport(TRANSPORT_VPN));
|
||||||
|
assertFalse(nc.hasTransport(TRANSPORT_CELLULAR));
|
||||||
|
assertFalse(nc.hasTransport(TRANSPORT_WIFI));
|
||||||
|
// By default, VPN is set to track default network (i.e. its underlying networks is null).
|
||||||
|
// In case of no default network, VPN is considered metered.
|
||||||
|
assertFalse(nc.hasCapability(NET_CAPABILITY_NOT_METERED));
|
||||||
|
|
||||||
|
// Connect to Cell; Cell is the default network.
|
||||||
|
mCellNetworkAgent = new MockNetworkAgent(TRANSPORT_CELLULAR);
|
||||||
|
mCellNetworkAgent.connect(true);
|
||||||
|
|
||||||
|
vpnNetworkCallback.expectCapabilitiesLike((caps) -> caps.hasTransport(TRANSPORT_VPN)
|
||||||
|
&& caps.hasTransport(TRANSPORT_CELLULAR) && !caps.hasTransport(TRANSPORT_WIFI)
|
||||||
|
&& !caps.hasCapability(NET_CAPABILITY_NOT_METERED),
|
||||||
|
vpnNetworkAgent);
|
||||||
|
|
||||||
|
// Connect to WiFi; WiFi is the new default.
|
||||||
|
mWiFiNetworkAgent = new MockNetworkAgent(TRANSPORT_WIFI);
|
||||||
|
mWiFiNetworkAgent.addCapability(NET_CAPABILITY_NOT_METERED);
|
||||||
|
mWiFiNetworkAgent.connect(true);
|
||||||
|
|
||||||
|
vpnNetworkCallback.expectCapabilitiesLike((caps) -> caps.hasTransport(TRANSPORT_VPN)
|
||||||
|
&& !caps.hasTransport(TRANSPORT_CELLULAR) && caps.hasTransport(TRANSPORT_WIFI)
|
||||||
|
&& caps.hasCapability(NET_CAPABILITY_NOT_METERED),
|
||||||
|
vpnNetworkAgent);
|
||||||
|
|
||||||
|
// Disconnect Cell. The default network did not change, so there shouldn't be any changes in
|
||||||
|
// the capabilities.
|
||||||
|
mCellNetworkAgent.disconnect();
|
||||||
|
|
||||||
|
// Disconnect wifi too. Now we have no default network.
|
||||||
|
mWiFiNetworkAgent.disconnect();
|
||||||
|
|
||||||
|
vpnNetworkCallback.expectCapabilitiesLike((caps) -> caps.hasTransport(TRANSPORT_VPN)
|
||||||
|
&& !caps.hasTransport(TRANSPORT_CELLULAR) && !caps.hasTransport(TRANSPORT_WIFI)
|
||||||
|
&& !caps.hasCapability(NET_CAPABILITY_NOT_METERED),
|
||||||
|
vpnNetworkAgent);
|
||||||
|
|
||||||
|
mMockVpn.disconnect();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNetworkBlockedStatus() {
|
public void testNetworkBlockedStatus() {
|
||||||
final TestNetworkCallback cellNetworkCallback = new TestNetworkCallback();
|
final TestNetworkCallback cellNetworkCallback = new TestNetworkCallback();
|
||||||
|
|||||||
@@ -566,7 +566,7 @@ public class VpnTest {
|
|||||||
|
|
||||||
final NetworkCapabilities caps = new NetworkCapabilities();
|
final NetworkCapabilities caps = new NetworkCapabilities();
|
||||||
|
|
||||||
Vpn.updateCapabilities(
|
Vpn.applyUnderlyingCapabilities(
|
||||||
mConnectivityManager, new Network[] {}, caps, false /* isAlwaysMetered */);
|
mConnectivityManager, new Network[] {}, caps, false /* isAlwaysMetered */);
|
||||||
assertTrue(caps.hasTransport(TRANSPORT_VPN));
|
assertTrue(caps.hasTransport(TRANSPORT_VPN));
|
||||||
assertFalse(caps.hasTransport(TRANSPORT_CELLULAR));
|
assertFalse(caps.hasTransport(TRANSPORT_CELLULAR));
|
||||||
@@ -577,7 +577,7 @@ public class VpnTest {
|
|||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
||||||
|
|
||||||
Vpn.updateCapabilities(
|
Vpn.applyUnderlyingCapabilities(
|
||||||
mConnectivityManager,
|
mConnectivityManager,
|
||||||
new Network[] {mobile},
|
new Network[] {mobile},
|
||||||
caps,
|
caps,
|
||||||
@@ -591,7 +591,7 @@ public class VpnTest {
|
|||||||
assertFalse(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
assertFalse(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
||||||
|
|
||||||
Vpn.updateCapabilities(
|
Vpn.applyUnderlyingCapabilities(
|
||||||
mConnectivityManager, new Network[] {wifi}, caps, false /* isAlwaysMetered */);
|
mConnectivityManager, new Network[] {wifi}, caps, false /* isAlwaysMetered */);
|
||||||
assertTrue(caps.hasTransport(TRANSPORT_VPN));
|
assertTrue(caps.hasTransport(TRANSPORT_VPN));
|
||||||
assertFalse(caps.hasTransport(TRANSPORT_CELLULAR));
|
assertFalse(caps.hasTransport(TRANSPORT_CELLULAR));
|
||||||
@@ -602,7 +602,7 @@ public class VpnTest {
|
|||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
||||||
|
|
||||||
Vpn.updateCapabilities(
|
Vpn.applyUnderlyingCapabilities(
|
||||||
mConnectivityManager, new Network[] {wifi}, caps, true /* isAlwaysMetered */);
|
mConnectivityManager, new Network[] {wifi}, caps, true /* isAlwaysMetered */);
|
||||||
assertTrue(caps.hasTransport(TRANSPORT_VPN));
|
assertTrue(caps.hasTransport(TRANSPORT_VPN));
|
||||||
assertFalse(caps.hasTransport(TRANSPORT_CELLULAR));
|
assertFalse(caps.hasTransport(TRANSPORT_CELLULAR));
|
||||||
@@ -613,7 +613,7 @@ public class VpnTest {
|
|||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_ROAMING));
|
||||||
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
assertTrue(caps.hasCapability(NET_CAPABILITY_NOT_CONGESTED));
|
||||||
|
|
||||||
Vpn.updateCapabilities(
|
Vpn.applyUnderlyingCapabilities(
|
||||||
mConnectivityManager,
|
mConnectivityManager,
|
||||||
new Network[] {mobile, wifi},
|
new Network[] {mobile, wifi},
|
||||||
caps,
|
caps,
|
||||||
|
|||||||
Reference in New Issue
Block a user