コード例 #1
0
 def test_06__deletes(self):
     tree = radix.Radix()
     node1 = tree.add("10.0.0.0/8")
     self.assertRaises(KeyError, tree.delete, "127.0.0.1")
     self.assertRaises(KeyError, tree.delete, "10.0.0.0/24")
     node = tree.search_best("10.0.0.10")
     self.assertEqual(node, node1)
コード例 #2
0
 def test_21__cpickle(self):
     if sys.version_info[0] >= 3:
         return
     tree = radix.Radix()
     num_nodes_in = 0
     for i in range(0, 128):
         for j in range(0, 128):
             k = ((i + j) % 8) + 24
             addr = "1.%d.%d.0" % (i, j)
             node = tree.add(addr, k)
             node.data["i"] = i
             node.data["j"] = j
             num_nodes_in += 1
     tree_pickled = cPickle.dumps(tree)
     del tree
     tree2 = cPickle.loads(tree_pickled)
     for i in range(0, 128):
         for j in range(0, 128):
             k = ((i + j) % 8) + 24
             addr = "1.%d.%d.0" % (i, j)
             node = tree2.search_exact(addr, k)
             self.assertNotEquals(node, None)
             self.assertEquals(node.data["i"], i)
             self.assertEquals(node.data["j"], j)
             node.data["j"] = j
     self.assertEquals(len(tree2.nodes()), num_nodes_in)
コード例 #3
0
 def test_26_search_covered(self):
     tree = radix.Radix()
     tree.add('10.0.0.0/8')
     tree.add('10.0.0.0/13')
     tree.add('10.0.0.0/31')
     tree.add('11.0.0.0/16')
     tree.add('10.30.2.1/32')
     tree.add('10.30.2.0/25')
     tree.add('0.0.0.0/0')
     self.assertEquals(
         [n.prefix for n in tree.search_covered('11.0.0.0/8')],
         ['11.0.0.0/16'])
     self.assertEquals(
         sorted([n.prefix for n in tree.search_covered('10.0.0.0/9')]),
         ['10.0.0.0/13', '10.0.0.0/31', '10.30.2.0/25', '10.30.2.1/32'])
     self.assertEquals(
         sorted([n.prefix for n in tree.search_covered('10.0.0.0/8')]),
         ['10.0.0.0/13', '10.0.0.0/31', '10.0.0.0/8', '10.30.2.0/25', '10.30.2.1/32'])
     self.assertEquals(
         [n.prefix for n in tree.search_covered('11.0.0.0/8')],
         ['11.0.0.0/16'])
     self.assertEquals(
         [n.prefix for n in tree.search_covered('10.30.2.64/32')],
         [])
     self.assertEquals(
         [n.prefix for n in tree.search_covered('21.0.0.0/8')],
         [])
     self.assertEquals(
         [n.prefix for n in tree.search_covered('10.0.0.1')],
         [])
     self.assertEquals(
         sorted([n.prefix for n in tree.search_covered('0.0.0.0/0')]),
         ['0.0.0.0/0', '10.0.0.0/13', '10.0.0.0/31', '10.0.0.0/8', '10.30.2.0/25', '10.30.2.1/32', '11.0.0.0/16'])
コード例 #4
0
 def test_23_add_with_glue(self):
     tree = radix.Radix()
     tree.add('1.0.24.0/23')
     tree.add('1.0.26.0/23')
     tree.add('1.0.28.0/22')
     expected = ['1.0.24.0/23', '1.0.26.0/23', '1.0.28.0/22']
     self.assertEqual(expected, [n.prefix for n in tree])
コード例 #5
0
 def test_14__packed_addresses4(self):
     tree = radix.Radix()
     p = struct.pack('4B', 0xe0, 0x14, 0x0b, 0x40)
     node = tree.add(packed=p, masklen=26)
     self.assertEquals(node.family, socket.AF_INET)
     self.assertEquals(node.prefix, "224.20.11.64/26")
     self.assertEquals(node.packed, p)
コード例 #6
0
 def test_31_parent(self):
     tree = radix.Radix()
     root = tree.add('0.0.0.0/0')
     self.assertEqual(root.parent, None)
     parent_node = tree.add('10.0.0.0/23')
     node1 = tree.add('10.0.0.0/24')
     self.assertEqual(node1.parent, parent_node)
コード例 #7
0
    def test_21__lots_of_prefixes(self):
        tree = radix.Radix()
        num_nodes_in = 0
        for i in range(0, 128):
            for j in range(0, 128):
                k = ((i + j) % 8) + 24
                node = tree.add("1.%d.%d.0" % (i, j), k)
                node.data["i"] = i
                node.data["j"] = j
                num_nodes_in += 1

        num_nodes_del = 0
        for i in range(0, 128, 5):
            for j in range(0, 128, 3):
                k = ((i + j) % 8) + 24
                tree.delete("1.%d.%d.0" % (i, j), k)
                num_nodes_del += 1

        num_nodes_out = 0
        for node in tree:
            i = node.data["i"]
            j = node.data["j"]
            k = ((i + j) % 8) + 24
            prefix = "1.%d.%d.0/%d" % (i, j, k)
            self.assertEquals(node.prefix, prefix)
            num_nodes_out += 1

        self.assertEquals(num_nodes_in - num_nodes_del, num_nodes_out)
        self.assertEquals(
            num_nodes_in - num_nodes_del,
            len(tree.nodes()))
コード例 #8
0
 def test_25_search_default(self):
     tree = radix.Radix()
     tree.add('192.168.30.0/24')
     tree.add('1.1.2.0/24')
     tree.add('0.0.0.0/0')
     self.assertEquals(
         tree.search_best('10.10.10.10').prefix,
         '0.0.0.0/0')
コード例 #9
0
 def test_13__inconsistent_masks6(self):
     tree = radix.Radix()
     node1 = tree.add("dead:beef:1234:5678::", 32)
     node2 = tree.add(network="dead:beef:8888:9999::/32")
     node3 = tree.add(network="dead:beef::", masklen=32)
     self.assertTrue(node1 is node2)
     self.assertTrue(node1 is node3)
     self.assertEquals(node1.prefix, "dead:beef::/32")
コード例 #10
0
 def test_12__inconsistent_masks4(self):
     tree = radix.Radix()
     node1 = tree.add("10.255.255.255", 28)
     node2 = tree.add(network="10.255.255.240/28")
     node3 = tree.add(network="10.255.255.252", masklen=28)
     self.assertTrue(node1 is node2)
     self.assertTrue(node1 is node3)
     self.assertEquals(node1.prefix, "10.255.255.240/28")
コード例 #11
0
 def test_22_search_best(self):
     tree = radix.Radix()
     tree.add('10.0.0.0/8')
     tree.add('10.0.0.0/13')
     tree.add('10.0.0.0/16')
     self.assertEquals(
         tree.search_best('10.0.0.0/15').prefix,
         '10.0.0.0/13')
コード例 #12
0
 def test_05__concurrent_trees(self):
     tree1 = radix.Radix()
     node1_2 = tree1.add("10.0.0.0/16")
     node1_3 = tree1.add("10.0.0.0/24")
     node1_3.data["blah"] = 12345
     tree2 = radix.Radix()
     node2_2 = tree2.add("10.0.0.0/16")
     node2_3 = tree2.add("10.0.0.0/24")
     node2_3.data["blah"] = 45678
     self.assertNotEqual(tree1, tree2)
     self.assertNotEqual(node1_2, node2_2)
     node = tree1.search_best("10.0.1.0/24")
     self.assertEqual(node, node1_2)
     self.assertNotEqual(node, node2_2)
     node = tree2.search_best("20.0.0.0/24")
     self.assertEqual(node, None)
     node = tree2.search_best("10.0.0.10")
     self.assertEqual(node.data["blah"], 45678)
コード例 #13
0
    def test_30_remove(self):
        tree = radix.Radix()
        tree.add('109.161.64.0/20')
        tree.add('5.150.145.0/24')
        tree.delete('5.150.145.0/24')
        tree.add('5.150.145.0/24')

        expected = ['5.150.145.0/24', '109.161.64.0/20']
        self.assertEqual(expected, [n.prefix for n in tree])
コード例 #14
0
    def test_000_check_incref(self):
        tree = radix.Radix()
        node = tree.add('10.0.1.0/24')

        # it takes a number of tries to cause a problem, so this is more of a
        # smoke test
        curr_refs = sys.getrefcount(None)
        for __ in range(curr_refs+1):
            self.assertEqual(type(None), type(node.parent))
コード例 #15
0
    def test_28_search_covered_super_node_error(self):
        tree = radix.Radix()
        tree.add('27.0.100.0/24')
        tree.add('27.0.101.0/24')

        self.assertEquals(
            [n.prefix for n in tree.search_covered('31.3.104.0/21')],
            []
        )
コード例 #16
0
 def test_02__node_userdata(self):
     tree = radix.Radix()
     node = tree.add(network="10.0.0.0", masklen=28)
     node.data["blah"] = "abc123"
     node.data["foo"] = 12345
     self.assertEqual(node.data["blah"], "abc123")
     self.assertEqual(node.data["foo"], 12345)
     self.assertRaises(AttributeError, lambda x: x.nonexist, node)
     del node.data["blah"]
     self.assertRaises(KeyError, lambda x: x.data["blah"], node)
コード例 #17
0
    def test_32_covering_with_delete_error(self):
        tree = radix.Radix()
        tree.add('91.187.124.0/24')
        tree.add('91.187.125.0/24')
        tree.add('91.187.124.0/23')
        tree.delete('91.187.124.0/23')
        tree.add('91.187.124.0/23')

        expected = ['91.187.124.0/23', '91.187.124.0/24', '91.187.125.0/24']
        self.assertEqual(expected, [n.prefix for n in tree])
コード例 #18
0
    def test_27_search_covered_segfault(self):
        # the following will make py-radix 0.8 segfault
        tree = radix.Radix()
        tree.add('193.178.156.0/24')
        tree.add('193.178.157.0/24')

        self.assertEquals(
            [n.prefix for n in tree.search_covered('193.178.152.0/21')],
            ['193.178.156.0/24', '193.178.157.0/24']
        )
コード例 #19
0
 def test_16__bad_addresses(self):
     tree = radix.Radix()
     self.assertRaises(TypeError, tree.add)
     self.assertRaises(ValueError, tree.add, "blah/32")
     self.assertRaises(ValueError, tree.add, "blah", 32)
     self.assertRaises(ValueError, tree.add, "127.0.0.1", -2)
     self.assertRaises(ValueError, tree.add, "127.0.0.1", 64)
     self.assertRaises(ValueError, tree.add, "::", -2)
     self.assertRaises(ValueError, tree.add, "::", 256)
     self.assertEquals(len(tree.nodes()), 0)
コード例 #20
0
 def test_17__mixed_address_family(self):
     tree = radix.Radix()
     node1 = tree.add("255.255.255.255", 32)
     node2 = tree.add("ffff::/32")
     node1_o = tree.search_best("255.255.255.255")
     node2_o = tree.search_best("ffff::")
     self.assertTrue(node1 is node1_o)
     self.assertTrue(node2 is node2_o)
     self.assertNotEquals(node1.prefix, node2.prefix)
     self.assertNotEquals(node1.network, node2.network)
     self.assertNotEquals(node1.family, node2.family)
コード例 #21
0
 def test_15__packed_addresses6(self):
     tree = radix.Radix()
     p = struct.pack(
         '16B',
         0xde, 0xad, 0xbe, 0xef, 0x12, 0x34, 0x56, 0x78,
         0x9a, 0xbc, 0xde, 0xf0, 0x00, 0x00, 0x00, 0x00)
     node = tree.add(packed=p, masklen=108)
     self.assertEquals(node.family, socket.AF_INET6)
     self.assertEquals(
         node.prefix,
         "dead:beef:1234:5678:9abc:def0::/108")
     self.assertEquals(node.packed, p)
コード例 #22
0
 def test_04__search_best(self):
     tree = radix.Radix()
     node2 = tree.add("10.0.0.0/16")
     node3 = tree.add("10.0.0.0/24")
     node = tree.search_best("127.0.0.1")
     self.assertEqual(node, None)
     node = tree.search_best("10.0.0.0")
     self.assertEqual(node, node3)
     node = tree.search_best("10.0.0.0/24")
     self.assertEqual(node, node3)
     node = tree.search_best("10.0.1.0/24")
     self.assertEqual(node, node2)
コード例 #23
0
 def test_09__prefixes(self):
     tree = radix.Radix()
     prefixes = [
         "10.0.0.0/8", "127.0.0.1/32",
         "10.1.0.0/16", "10.100.100.100/32",
         "abcd:ef12::/32", "abcd:ef01:2345:6789::/64", "::1/128"
     ]
     prefixes.sort()
     for prefix in prefixes:
         tree.add(prefix)
     addrs = tree.prefixes()
     addrs.sort()
     self.assertEqual(addrs, prefixes)
コード例 #24
0
    def test_20__iterate_and_modify_tree(self):
        tree = radix.Radix()
        prefixes = [
            "::1/128", "2000::/16", "2000::/8", "dead:beef::/64",
            "0.0.0.0/8", "127.0.0.1/32"
        ]
        prefixes.sort()
        for prefix in prefixes:
            tree.add(prefix)

        def iter_mod(t):
            [t.delete(x.prefix) for x in t]
        self.assertRaises(RuntimeWarning, iter_mod, tree)
コード例 #25
0
 def test_07__nodes(self):
     tree = radix.Radix()
     prefixes = [
         "10.0.0.0/8", "127.0.0.1/32",
         "10.1.0.0/16", "10.100.100.100/32",
         "abcd:ef12::/32", "abcd:ef01:2345:6789::/64", "::1/128"
     ]
     prefixes.sort()
     for prefix in prefixes:
         tree.add(prefix)
     nodes = tree.nodes()
     addrs = list(map(lambda x: x.prefix, nodes))
     addrs.sort()
     self.assertEqual(addrs, prefixes)
コード例 #26
0
 def test_18__iterator(self):
     tree = radix.Radix()
     prefixes = [
         "::1/128", "2000::/16", "2000::/8", "dead:beef::/64",
         "ffff::/16", "10.0.0.0/8", "a00::/8", "255.255.0.0/16",
         "::/0", "0.0.0.0/0"
     ]
     prefixes.sort()
     for prefix in prefixes:
         tree.add(prefix)
     iterprefixes = []
     for node in tree:
         iterprefixes.append(node.prefix)
     iterprefixes.sort()
     self.assertEqual(iterprefixes, prefixes)
コード例 #27
0
 def test_03__search_exact(self):
     tree = radix.Radix()
     node1 = tree.add("10.0.0.0/8")
     node2 = tree.add("10.0.0.0/16")
     node3 = tree.add("10.0.0.0/24")
     node2.data["foo"] = 12345
     node = tree.search_exact("127.0.0.1")
     self.assertEqual(node, None)
     node = tree.search_exact("10.0.0.0")
     self.assertEqual(node, None)
     node = tree.search_exact("10.0.0.0/24")
     self.assertEqual(node, node3)
     node = tree.search_exact("10.0.0.0/8")
     self.assertEqual(node, node1)
     node = tree.search_exact("10.0.0.0/16")
     self.assertEqual(node.data["foo"], 12345)
コード例 #28
0
 def test_01__create_node(self):
     tree = radix.Radix()
     node = tree.add("10.0.0.0/8")
     self.assertTrue('radix.RadixNode' in str(type(node)))
     self.assertEqual(node.prefix, "10.0.0.0/8")
     self.assertEqual(node.network, "10.0.0.0")
     self.assertEqual(node.prefixlen, 8)
     self.assertEqual(node.family, socket.AF_INET)
     node = tree.add("10.0.0.0", 16)
     self.assertEqual(node.network, "10.0.0.0")
     self.assertEqual(node.prefixlen, 16)
     node = tree.add(network="10.0.0.0", masklen=24)
     self.assertEqual(node.network, "10.0.0.0")
     self.assertEqual(node.prefixlen, 24)
     node2 = tree.add(network="ff00::", masklen=24)
     self.assertEqual(node2.network, "ff00::")
     self.assertEqual(node2.prefixlen, 24)
     self.assertTrue(node is not node2)
コード例 #29
0
    def test_29_search_covering(self):
        tree = radix.Radix()
        tree.add('0.0.0.0/2')
        tree.add('8.9.0.1/32')
        tree.add('8.9.0.0/16')
        tree.add('3.178.156.0/24')
        tree.add('3.178.157.0/24')

        self.assertEquals([n.prefix for n in
                           tree.search_covering('8.9.0.1/32')],
                          ['8.9.0.1/32', '8.9.0.0/16', '0.0.0.0/2'])
        self.assertEquals([n.prefix for n in
                           tree.search_covering('5.5.5.0/24')],
                          ['0.0.0.0/2'])
        self.assertEquals([n.prefix for n in
                           tree.search_covering('3.178.152.0/21')],
                          ['0.0.0.0/2'])
        self.assertEquals([n.prefix for n in
                           tree.search_covering('205.0.1.0/24')],
                          [])
コード例 #30
0
from random import randint
from radix import radix

# blacklist
blacklist = radix.Radix()
# generate ip addresses
for i in range(1000000):
    # ip4 ips shoutout to Ben and Omar for this code :)
    ip = "{}.{}.{}.{}".format(randint(0, 255), randint(0, 255),
                              randint(0, 255), randint(0, 255))
    node = blacklist.add(ip)
    node.data["ip"] = ip
    node.data["requests"] = 1