Merge "Give VPNs the INTERNET capability when they route most of the IP space" am: f477aedec5 am: 7506c131c1
am: 941de3f74c
Change-Id: Ifd77149ca2c45249b8776c878c6fac46ae81c2a4
This commit is contained in:
@@ -223,14 +223,14 @@ public class IpPrefixTest {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testContains() {
|
||||
public void testContainsInetAddress() {
|
||||
IpPrefix p = new IpPrefix("2001:db8:f00::ace:d00d/127");
|
||||
assertTrue(p.contains(Address("2001:db8:f00::ace:d00c")));
|
||||
assertTrue(p.contains(Address("2001:db8:f00::ace:d00d")));
|
||||
assertFalse(p.contains(Address("2001:db8:f00::ace:d00e")));
|
||||
assertFalse(p.contains(Address("2001:db8:f00::bad:d00d")));
|
||||
assertFalse(p.contains(Address("2001:4868:4860::8888")));
|
||||
assertFalse(p.contains(null));
|
||||
assertFalse(p.contains((InetAddress)null));
|
||||
assertFalse(p.contains(Address("8.8.8.8")));
|
||||
|
||||
p = new IpPrefix("192.0.2.0/23");
|
||||
@@ -250,6 +250,53 @@ public class IpPrefixTest {
|
||||
assertFalse(ipv4Default.contains(Address("2001:db8::f00")));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testContainsIpPrefix() {
|
||||
assertTrue(new IpPrefix("0.0.0.0/0").containsPrefix(new IpPrefix("0.0.0.0/0")));
|
||||
assertTrue(new IpPrefix("0.0.0.0/0").containsPrefix(new IpPrefix("1.2.3.4/0")));
|
||||
assertTrue(new IpPrefix("0.0.0.0/0").containsPrefix(new IpPrefix("1.2.3.4/8")));
|
||||
assertTrue(new IpPrefix("0.0.0.0/0").containsPrefix(new IpPrefix("1.2.3.4/24")));
|
||||
assertTrue(new IpPrefix("0.0.0.0/0").containsPrefix(new IpPrefix("1.2.3.4/23")));
|
||||
|
||||
assertTrue(new IpPrefix("1.2.3.4/8").containsPrefix(new IpPrefix("1.2.3.4/8")));
|
||||
assertTrue(new IpPrefix("1.2.3.4/8").containsPrefix(new IpPrefix("1.254.12.9/8")));
|
||||
assertTrue(new IpPrefix("1.2.3.4/21").containsPrefix(new IpPrefix("1.2.3.4/21")));
|
||||
assertTrue(new IpPrefix("1.2.3.4/32").containsPrefix(new IpPrefix("1.2.3.4/32")));
|
||||
|
||||
assertTrue(new IpPrefix("1.2.3.4/20").containsPrefix(new IpPrefix("1.2.3.0/24")));
|
||||
|
||||
assertFalse(new IpPrefix("1.2.3.4/32").containsPrefix(new IpPrefix("1.2.3.5/32")));
|
||||
assertFalse(new IpPrefix("1.2.3.4/8").containsPrefix(new IpPrefix("2.2.3.4/8")));
|
||||
assertFalse(new IpPrefix("0.0.0.0/16").containsPrefix(new IpPrefix("0.0.0.0/15")));
|
||||
assertFalse(new IpPrefix("100.0.0.0/8").containsPrefix(new IpPrefix("99.0.0.0/8")));
|
||||
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("::/0")));
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("2001:db8::f00/1")));
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("3d8a:661:a0::770/8")));
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("2001:db8::f00/8")));
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("2001:db8::f00/64")));
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("2001:db8::f00/113")));
|
||||
assertTrue(new IpPrefix("::/0").containsPrefix(new IpPrefix("2001:db8::f00/128")));
|
||||
|
||||
assertTrue(new IpPrefix("2001:db8:f00::ace:d00d/64").containsPrefix(
|
||||
new IpPrefix("2001:db8:f00::ace:d00d/64")));
|
||||
assertTrue(new IpPrefix("2001:db8:f00::ace:d00d/64").containsPrefix(
|
||||
new IpPrefix("2001:db8:f00::ace:d00d/120")));
|
||||
assertFalse(new IpPrefix("2001:db8:f00::ace:d00d/64").containsPrefix(
|
||||
new IpPrefix("2001:db8:f00::ace:d00d/32")));
|
||||
assertFalse(new IpPrefix("2001:db8:f00::ace:d00d/64").containsPrefix(
|
||||
new IpPrefix("2006:db8:f00::ace:d00d/96")));
|
||||
|
||||
assertTrue(new IpPrefix("2001:db8:f00::ace:d00d/128").containsPrefix(
|
||||
new IpPrefix("2001:db8:f00::ace:d00d/128")));
|
||||
assertTrue(new IpPrefix("2001:db8:f00::ace:d00d/100").containsPrefix(
|
||||
new IpPrefix("2001:db8:f00::ace:ccaf/110")));
|
||||
|
||||
assertFalse(new IpPrefix("2001:db8:f00::ace:d00d/128").containsPrefix(
|
||||
new IpPrefix("2001:db8:f00::ace:d00e/128")));
|
||||
assertFalse(new IpPrefix("::/30").containsPrefix(new IpPrefix("::/29")));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testHashCode() {
|
||||
IpPrefix p = new IpPrefix(new byte[4], 0);
|
||||
|
||||
@@ -19,8 +19,10 @@ package android.net;
|
||||
import android.net.NetworkUtils;
|
||||
import android.test.suitebuilder.annotation.SmallTest;
|
||||
|
||||
import java.math.BigInteger;
|
||||
import java.net.Inet4Address;
|
||||
import java.net.InetAddress;
|
||||
import java.util.TreeSet;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
@@ -67,4 +69,101 @@ public class NetworkUtilsTest extends TestCase {
|
||||
assertInvalidNetworkMask(IPv4Address("255.255.255.253"));
|
||||
assertInvalidNetworkMask(IPv4Address("255.255.0.255"));
|
||||
}
|
||||
|
||||
@SmallTest
|
||||
public void testRoutedIPv4AddressCount() {
|
||||
final TreeSet<IpPrefix> set = new TreeSet<>(IpPrefix.lengthComparator());
|
||||
// No routes routes to no addresses.
|
||||
assertEquals(0, NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("0.0.0.0/0"));
|
||||
assertEquals(1l << 32, NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("20.18.0.0/16"));
|
||||
set.add(new IpPrefix("20.18.0.0/24"));
|
||||
set.add(new IpPrefix("20.18.0.0/8"));
|
||||
// There is a default route, still covers everything
|
||||
assertEquals(1l << 32, NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
set.clear();
|
||||
set.add(new IpPrefix("20.18.0.0/24"));
|
||||
set.add(new IpPrefix("20.18.0.0/8"));
|
||||
// The 8-length includes the 24-length prefix
|
||||
assertEquals(1l << 24, NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("10.10.10.126/25"));
|
||||
// The 8-length does not include this 25-length prefix
|
||||
assertEquals((1l << 24) + (1 << 7), NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
set.clear();
|
||||
set.add(new IpPrefix("1.2.3.4/32"));
|
||||
set.add(new IpPrefix("1.2.3.4/32"));
|
||||
set.add(new IpPrefix("1.2.3.4/32"));
|
||||
set.add(new IpPrefix("1.2.3.4/32"));
|
||||
assertEquals(1l, NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("1.2.3.5/32"));
|
||||
set.add(new IpPrefix("1.2.3.6/32"));
|
||||
|
||||
set.add(new IpPrefix("1.2.3.7/32"));
|
||||
set.add(new IpPrefix("1.2.3.8/32"));
|
||||
set.add(new IpPrefix("1.2.3.9/32"));
|
||||
set.add(new IpPrefix("1.2.3.0/32"));
|
||||
assertEquals(7l, NetworkUtils.routedIPv4AddressCount(set));
|
||||
|
||||
// 1.2.3.4/30 eats 1.2.3.{4-7}/32
|
||||
set.add(new IpPrefix("1.2.3.4/30"));
|
||||
set.add(new IpPrefix("6.2.3.4/28"));
|
||||
set.add(new IpPrefix("120.2.3.4/16"));
|
||||
assertEquals(7l - 4 + 4 + 16 + 65536, NetworkUtils.routedIPv4AddressCount(set));
|
||||
}
|
||||
|
||||
@SmallTest
|
||||
public void testRoutedIPv6AddressCount() {
|
||||
final TreeSet<IpPrefix> set = new TreeSet<>(IpPrefix.lengthComparator());
|
||||
// No routes routes to no addresses.
|
||||
assertEquals(BigInteger.ZERO, NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("::/0"));
|
||||
assertEquals(BigInteger.ONE.shiftLeft(128), NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("1234:622a::18/64"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6adb/96"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6adb/8"));
|
||||
// There is a default route, still covers everything
|
||||
assertEquals(BigInteger.ONE.shiftLeft(128), NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
set.clear();
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6adb/96"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6adb/8"));
|
||||
// The 8-length includes the 96-length prefix
|
||||
assertEquals(BigInteger.ONE.shiftLeft(120), NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("10::26/64"));
|
||||
// The 8-length does not include this 64-length prefix
|
||||
assertEquals(BigInteger.ONE.shiftLeft(120).add(BigInteger.ONE.shiftLeft(64)),
|
||||
NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
set.clear();
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad4/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad4/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad4/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad4/128"));
|
||||
assertEquals(BigInteger.ONE, NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad5/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad6/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad7/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad8/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad9/128"));
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad0/128"));
|
||||
assertEquals(BigInteger.valueOf(7), NetworkUtils.routedIPv6AddressCount(set));
|
||||
|
||||
// add4:f00:80:f7:1111::6ad4/126 eats add4:f00:8[:f7:1111::6ad{4-7}/128
|
||||
set.add(new IpPrefix("add4:f00:80:f7:1111::6ad4/126"));
|
||||
set.add(new IpPrefix("d00d:f00:80:f7:1111::6ade/124"));
|
||||
set.add(new IpPrefix("f00b:a33::/112"));
|
||||
assertEquals(BigInteger.valueOf(7l - 4 + 4 + 16 + 65536),
|
||||
NetworkUtils.routedIPv6AddressCount(set));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user