Merge "Fix title of PRIVATE_DNS_BROKEN notification when connecting VPN" am: fc8c834040 am: 22ba258b99
am: 61fcd4126f
Change-Id: I9539e73842040e3a38a64c4b4863adfe32c893e9
This commit is contained in:
@@ -20,6 +20,7 @@ import static com.android.server.connectivity.NetworkNotificationManager.Notific
|
||||
|
||||
import static org.mockito.Mockito.any;
|
||||
import static org.mockito.Mockito.anyInt;
|
||||
import static org.mockito.Mockito.doReturn;
|
||||
import static org.mockito.Mockito.eq;
|
||||
import static org.mockito.Mockito.never;
|
||||
import static org.mockito.Mockito.reset;
|
||||
@@ -40,6 +41,7 @@ import android.telephony.TelephonyManager;
|
||||
import androidx.test.filters.SmallTest;
|
||||
import androidx.test.runner.AndroidJUnit4;
|
||||
|
||||
import com.android.internal.R;
|
||||
import com.android.server.connectivity.NetworkNotificationManager.NotificationType;
|
||||
|
||||
import org.junit.Before;
|
||||
@@ -60,12 +62,19 @@ public class NetworkNotificationManagerTest {
|
||||
|
||||
static final NetworkCapabilities CELL_CAPABILITIES = new NetworkCapabilities();
|
||||
static final NetworkCapabilities WIFI_CAPABILITIES = new NetworkCapabilities();
|
||||
static final NetworkCapabilities VPN_CAPABILITIES = new NetworkCapabilities();
|
||||
static {
|
||||
CELL_CAPABILITIES.addTransportType(NetworkCapabilities.TRANSPORT_CELLULAR);
|
||||
CELL_CAPABILITIES.addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET);
|
||||
|
||||
WIFI_CAPABILITIES.addTransportType(NetworkCapabilities.TRANSPORT_WIFI);
|
||||
WIFI_CAPABILITIES.addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET);
|
||||
|
||||
// Set the underyling network to wifi.
|
||||
VPN_CAPABILITIES.addTransportType(NetworkCapabilities.TRANSPORT_WIFI);
|
||||
VPN_CAPABILITIES.addTransportType(NetworkCapabilities.TRANSPORT_VPN);
|
||||
VPN_CAPABILITIES.addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET);
|
||||
VPN_CAPABILITIES.removeCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VPN);
|
||||
}
|
||||
|
||||
@Mock Context mCtx;
|
||||
@@ -75,6 +84,7 @@ public class NetworkNotificationManagerTest {
|
||||
@Mock NotificationManager mNotificationManager;
|
||||
@Mock NetworkAgentInfo mWifiNai;
|
||||
@Mock NetworkAgentInfo mCellNai;
|
||||
@Mock NetworkAgentInfo mVpnNai;
|
||||
@Mock NetworkInfo mNetworkInfo;
|
||||
ArgumentCaptor<Notification> mCaptor;
|
||||
|
||||
@@ -88,6 +98,9 @@ public class NetworkNotificationManagerTest {
|
||||
mWifiNai.networkInfo = mNetworkInfo;
|
||||
mCellNai.networkCapabilities = CELL_CAPABILITIES;
|
||||
mCellNai.networkInfo = mNetworkInfo;
|
||||
mVpnNai.networkCapabilities = VPN_CAPABILITIES;
|
||||
mVpnNai.networkInfo = mNetworkInfo;
|
||||
doReturn(true).when(mVpnNai).isVPN();
|
||||
when(mCtx.getResources()).thenReturn(mResources);
|
||||
when(mCtx.getPackageManager()).thenReturn(mPm);
|
||||
when(mCtx.getApplicationInfo()).thenReturn(new ApplicationInfo());
|
||||
@@ -97,6 +110,35 @@ public class NetworkNotificationManagerTest {
|
||||
mManager = new NetworkNotificationManager(mCtx, mTelephonyManager, mNotificationManager);
|
||||
}
|
||||
|
||||
private void verifyTitleByNetwork(final int id, final NetworkAgentInfo nai, final int title) {
|
||||
final String tag = NetworkNotificationManager.tagFor(id);
|
||||
mManager.showNotification(id, PRIVATE_DNS_BROKEN, nai, null, null, true);
|
||||
verify(mNotificationManager, times(1))
|
||||
.notifyAsUser(eq(tag), eq(PRIVATE_DNS_BROKEN.eventId), any(), any());
|
||||
final int transportType = NetworkNotificationManager.approximateTransportType(nai);
|
||||
if (transportType == NetworkCapabilities.TRANSPORT_WIFI) {
|
||||
verify(mResources, times(1)).getString(title, eq(any()));
|
||||
} else {
|
||||
verify(mResources, times(1)).getString(title);
|
||||
}
|
||||
verify(mResources, times(1)).getString(R.string.private_dns_broken_detailed);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTitleOfPrivateDnsBroken() {
|
||||
// Test the title of mobile data.
|
||||
verifyTitleByNetwork(100, mCellNai, R.string.mobile_no_internet);
|
||||
reset(mResources);
|
||||
|
||||
// Test the title of wifi.
|
||||
verifyTitleByNetwork(101, mWifiNai, R.string.wifi_no_internet);
|
||||
reset(mResources);
|
||||
|
||||
// Test the title of other networks.
|
||||
verifyTitleByNetwork(102, mVpnNai, R.string.other_networks_no_internet);
|
||||
reset(mResources);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testNotificationsShownAndCleared() {
|
||||
final int NETWORK_ID_BASE = 100;
|
||||
|
||||
Reference in New Issue
Block a user