diff options
Diffstat (limited to 'tests/unit/java/com/android/server/ConnectivityServiceTest.java')
| -rw-r--r-- | tests/unit/java/com/android/server/ConnectivityServiceTest.java | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/tests/unit/java/com/android/server/ConnectivityServiceTest.java b/tests/unit/java/com/android/server/ConnectivityServiceTest.java index 6316c72e0a..a82fe83f96 100644 --- a/tests/unit/java/com/android/server/ConnectivityServiceTest.java +++ b/tests/unit/java/com/android/server/ConnectivityServiceTest.java @@ -195,6 +195,7 @@ import android.app.AlarmManager; import android.app.AppOpsManager; import android.app.NotificationManager; import android.app.PendingIntent; +import android.app.admin.DevicePolicyManager; import android.app.usage.NetworkStatsManager; import android.content.BroadcastReceiver; import android.content.ComponentName; @@ -542,6 +543,7 @@ public class ConnectivityServiceTest { @Mock NetworkPolicyManager mNetworkPolicyManager; @Mock VpnProfileStore mVpnProfileStore; @Mock SystemConfigManager mSystemConfigManager; + @Mock DevicePolicyManager mDevicePolicyManager; @Mock Resources mResources; @Mock ClatCoordinator mClatCoordinator; @Mock PacProxyManager mPacProxyManager; @@ -664,6 +666,7 @@ public class ConnectivityServiceTest { if (Context.TELEPHONY_SERVICE.equals(name)) return mTelephonyManager; if (Context.ETHERNET_SERVICE.equals(name)) return mEthernetManager; if (Context.NETWORK_POLICY_SERVICE.equals(name)) return mNetworkPolicyManager; + if (Context.DEVICE_POLICY_SERVICE.equals(name)) return mDevicePolicyManager; if (Context.SYSTEM_CONFIG_SERVICE.equals(name)) return mSystemConfigManager; if (Context.NETWORK_STATS_SERVICE.equals(name)) return mStatsManager; if (Context.BATTERY_STATS_SERVICE.equals(name)) return mBatteryStatsManager; @@ -693,6 +696,14 @@ public class ConnectivityServiceTest { doReturn(value).when(mUserManager).isManagedProfile(eq(userHandle.getIdentifier())); } + public void setDeviceOwner(@NonNull final UserHandle userHandle, String value) { + // This relies on all contexts for a given user returning the same UM mock + final DevicePolicyManager dpmMock = createContextAsUser(userHandle, 0 /* flags */) + .getSystemService(DevicePolicyManager.class); + doReturn(value).when(dpmMock).getDeviceOwner(); + doReturn(value).when(mDevicePolicyManager).getDeviceOwner(); + } + @Override public ContentResolver getContentResolver() { return mContentResolver; @@ -14733,12 +14744,41 @@ public class ConnectivityServiceTest { public void testProfileNetworkPrefWrongProfile() throws Exception { final UserHandle testHandle = UserHandle.of(TEST_WORK_PROFILE_USER_ID); mServiceContext.setWorkProfile(testHandle, false); - assertThrows("Should not be able to set a user pref for a non-work profile", + mServiceContext.setDeviceOwner(testHandle, null); + assertThrows("Should not be able to set a user pref for a non-work profile " + + "and non device owner", IllegalArgumentException.class , () -> mCm.setProfileNetworkPreference(testHandle, PROFILE_NETWORK_PREFERENCE_ENTERPRISE, null, null)); } + /** + * Make sure requests for per-profile default networking for a device owner is + * accepted on T and not accepted on S + */ + public void testProfileNetworkDeviceOwner() throws Exception { + final UserHandle testHandle = UserHandle.of(TEST_WORK_PROFILE_USER_ID); + mServiceContext.setWorkProfile(testHandle, false); + mServiceContext.setDeviceOwner(testHandle, "deviceOwnerPackage"); + ProfileNetworkPreference.Builder profileNetworkPreferenceBuilder = + new ProfileNetworkPreference.Builder(); + profileNetworkPreferenceBuilder.setPreference(PROFILE_NETWORK_PREFERENCE_ENTERPRISE); + profileNetworkPreferenceBuilder.setPreferenceEnterpriseId(NET_ENTERPRISE_ID_1); + final TestOnCompleteListener listener = new TestOnCompleteListener(); + if (SdkLevel.isAtLeastT()) { + mCm.setProfileNetworkPreferences(testHandle, + List.of(profileNetworkPreferenceBuilder.build()), + r -> r.run(), listener); + } else { + // S should not allow setting preference on device owner + assertThrows("Should not be able to set a user pref for a non-work profile on S", + IllegalArgumentException.class , () -> + mCm.setProfileNetworkPreferences(testHandle, + List.of(profileNetworkPreferenceBuilder.build()), + r -> r.run(), listener)); + } + } + @Test public void testSubIdsClearedWithoutNetworkFactoryPermission() throws Exception { mServiceContext.setPermission(NETWORK_FACTORY, PERMISSION_DENIED); |
