示例#1
0
    def test_iteration(self):
        """
        Make 10 nodes, 5 buckets, two nodes add to one bucket in order,
        All buckets: [node0, node1], [node2, node3], [node4, node5],
                     [node6, node7], [node8, node9]
        Test traver result starting from node4.
        """

        nodes = [mknode(intid=x) for x in range(10)]

        buckets = []
        for i in range(5):
            bucket = KBucket(2 * i, 2 * i + 1, 2)
            bucket.add_node(nodes[2 * i])
            bucket.add_node(nodes[2 * i + 1])
            buckets.append(bucket)

        # replace router's bucket with our test buckets
        self.router.buckets = buckets

        # expected nodes order
        expected_nodes = [nodes[5], nodes[4], nodes[3], nodes[2], nodes[7],
                          nodes[6], nodes[1], nodes[0], nodes[9], nodes[8]]

        start_node = nodes[4]
        for index, node in enumerate(TableTraverser(self.router, start_node)):
            self.assertEqual(node, expected_nodes[index])
示例#2
0
    def test_remove_node(self):
        k = 3
        bucket = KBucket(0, 10, k)
        nodes = [mknode() for _ in range(10)]
        for node in nodes:
            bucket.add_node(node)

        replacement_nodes = bucket.replacement_nodes
        self.assertEqual(list(bucket.nodes.values()), nodes[:k])
        self.assertEqual(list(replacement_nodes.values()), nodes[k:])

        bucket.remove_node(nodes.pop())
        self.assertEqual(list(bucket.nodes.values()), nodes[:k])
        self.assertEqual(list(replacement_nodes.values()), nodes[k:])

        bucket.remove_node(nodes.pop(0))
        self.assertEqual(list(bucket.nodes.values()),
                         nodes[:k - 1] + nodes[-1:])
        self.assertEqual(list(replacement_nodes.values()), nodes[k - 1:-1])

        shuffle(nodes)
        for node in nodes:
            bucket.remove_node(node)
        self.assertEqual(len(bucket), 0)
        self.assertEqual(len(replacement_nodes), 0)
示例#3
0
 def test_split(self):
     bucket = KBucket(0, 10, 5)
     bucket.addNode(mknode(intid=5))
     bucket.addNode(mknode(intid=6))
     one, two = bucket.split()
     self.assertEqual(len(one), 1)
     self.assertEqual(one.range, (0, 5))
     self.assertEqual(len(two), 1)
     self.assertEqual(two.range, (6, 10))
示例#4
0
 def test_split(self):
     bucket = KBucket(0, 10, 5)
     bucket.add_node(mknode(intid=5))
     bucket.add_node(mknode(intid=6))
     one, two = bucket.split()
     self.assertEqual(len(one), 1)
     self.assertEqual(one.range, (0, 5))
     self.assertEqual(len(two), 1)
     self.assertEqual(two.range, (6, 10))
示例#5
0
 def test_split(self, mknode):  # pylint: disable=no-self-use
     bucket = KBucket(0, 10, 5)
     bucket.add_node(mknode(intid=5))
     bucket.add_node(mknode(intid=6))
     one, two = bucket.split()
     assert len(one) == 1
     assert one.range == (0, 5)
     assert len(two) == 1
     assert two.range == (6, 10)
示例#6
0
    def test_replacement_factor(self, mknode):  # pylint: disable=no-self-use
        k = 3
        factor = 2
        bucket = KBucket(0, 10, k, replacementNodeFactor=factor)
        nodes = [mknode() for _ in range(10)]
        for node in nodes:
            bucket.add_node(node)

        replacement_nodes = bucket.replacement_nodes
        assert len(list(replacement_nodes.values())) == k * factor
        assert list(replacement_nodes.values()) == nodes[k + 1:]
        assert nodes[k] not in list(replacement_nodes.values())
示例#7
0
    def test_addNode(self):
        # when full, return false
        bucket = KBucket(0, 10, 2)
        self.assertTrue(bucket.addNode(mknode()))
        self.assertTrue(bucket.addNode(mknode()))
        self.assertFalse(bucket.addNode(mknode()))
        self.assertEqual(len(bucket), 2)

        # make sure when a node is double added it's put at the end
        bucket = KBucket(0, 10, 3)
        nodes = [mknode(), mknode(), mknode()]
        for node in nodes:
            bucket.addNode(node)
        for index, node in enumerate(bucket.getNodes()):
            self.assertEqual(node, nodes[index])
示例#8
0
    def test_add_node(self, mknode):  # pylint: disable=no-self-use
        # when full, return false
        bucket = KBucket(0, 10, 2)
        assert bucket.add_node(mknode()) is True
        assert bucket.add_node(mknode()) is True
        assert bucket.add_node(mknode()) is False
        assert len(bucket) == 2

        # make sure when a node is double added it's put at the end
        bucket = KBucket(0, 10, 3)
        nodes = [mknode(), mknode(), mknode()]
        for node in nodes:
            bucket.add_node(node)
        for index, node in enumerate(bucket.get_nodes()):
            assert node == nodes[index]
示例#9
0
    def test_iteration(self):
        """
        Make 10 nodes, 5 buckets, two nodes add to one bucket in order,
        All buckets: [node0, node1], [node2, node3], [node4, node5],
                     [node6, node7], [node8, node9]
        Test traver result starting from node4.
        """

        nodes = [mknode(intid=x) for x in range(10)]

        buckets = []
        for i in range(5):
            bucket = KBucket(2 * i, 2 * i + 1, 2)
            bucket.addNode(nodes[2 * i])
            bucket.addNode(nodes[2 * i + 1])
            buckets.append(bucket)

        # replace router's bucket with our test buckets
        self.router.buckets = buckets

        # expected nodes order
        expected_nodes = [
            nodes[5], nodes[4], nodes[3], nodes[2], nodes[7], nodes[6],
            nodes[1], nodes[0], nodes[9], nodes[8]
        ]

        start_node = nodes[4]
        for index, node in enumerate(TableTraverser(self.router, start_node)):
            self.assertEqual(node, expected_nodes[index])
示例#10
0
    def test_remove_node(self, mknode):  # pylint: disable=no-self-use
        k = 3
        bucket = KBucket(0, 10, k)
        nodes = [mknode() for _ in range(10)]
        for node in nodes:
            bucket.add_node(node)

        replacement_nodes = bucket.replacement_nodes
        assert list(bucket.nodes.values()) == nodes[:k]
        assert list(replacement_nodes.values()) == nodes[k:]

        bucket.remove_node(nodes.pop())
        assert list(bucket.nodes.values()) == nodes[:k]
        assert list(replacement_nodes.values()) == nodes[k:]

        bucket.remove_node(nodes.pop(0))
        assert list(bucket.nodes.values()) == nodes[:k - 1] + nodes[-1:]
        assert list(replacement_nodes.values()) == nodes[k - 1:-1]

        shuffle(nodes)
        for node in nodes:
            bucket.remove_node(node)
        assert not bucket
        assert not replacement_nodes
示例#11
0
    def test_add_node(self):
        # when full, return false
        bucket = KBucket(0, 10, 2)
        self.assertTrue(bucket.add_node(mknode()))
        self.assertTrue(bucket.add_node(mknode()))
        self.assertFalse(bucket.add_node(mknode()))
        self.assertEqual(len(bucket), 2)

        # make sure when a node is double added it's put at the end
        bucket = KBucket(0, 10, 3)
        nodes = [mknode(), mknode(), mknode()]
        for node in nodes:
            bucket.add_node(node)
        for index, node in enumerate(bucket.get_nodes()):
            self.assertEqual(node, nodes[index])
示例#12
0
    def test_remove_node(self):
        k = 3
        bucket = KBucket(0, 10, k)
        nodes = [mknode() for _ in range(10)]
        for node in nodes:
            bucket.add_node(node)

        replacement_nodes = bucket.replacement_nodes
        self.assertEqual(list(bucket.nodes.values()), nodes[:k])
        self.assertEqual(list(replacement_nodes.values()), nodes[k:])

        bucket.remove_node(nodes.pop())
        self.assertEqual(list(bucket.nodes.values()), nodes[:k])
        self.assertEqual(list(replacement_nodes.values()), nodes[k:])

        bucket.remove_node(nodes.pop(0))
        self.assertEqual(list(bucket.nodes.values()), nodes[:k-1] + nodes[-1:])
        self.assertEqual(list(replacement_nodes.values()), nodes[k-1:-1])

        shuffle(nodes)
        for node in nodes:
            bucket.remove_node(node)
        self.assertEqual(len(bucket), 0)
        self.assertEqual(len(replacement_nodes), 0)
示例#13
0
 def test_inRange(self):
     bucket = KBucket(0, 10, 10)
     self.assertTrue(bucket.hasInRange(mknode(intid=5)))
     self.assertFalse(bucket.hasInRange(mknode(intid=11)))
     self.assertTrue(bucket.hasInRange(mknode(intid=10)))
     self.assertTrue(bucket.hasInRange(mknode(intid=0)))
示例#14
0
 def test_in_range(self):
     bucket = KBucket(0, 10, 10)
     self.assertTrue(bucket.has_in_range(mknode(intid=5)))
     self.assertFalse(bucket.has_in_range(mknode(intid=11)))
     self.assertTrue(bucket.has_in_range(mknode(intid=10)))
     self.assertTrue(bucket.has_in_range(mknode(intid=0)))
示例#15
0
 def test_in_range(self, mknode):  # pylint: disable=no-self-use
     bucket = KBucket(0, 10, 10)
     assert bucket.has_in_range(mknode(intid=5)) is True
     assert bucket.has_in_range(mknode(intid=11)) is False
     assert bucket.has_in_range(mknode(intid=10)) is True
     assert bucket.has_in_range(mknode(intid=0)) is True
示例#16
0
 def test_split_no_overlap(self):  # pylint: disable=no-self-use
     left, right = KBucket(0, 2**160, 20).split()
     assert (right.range[0] - left.range[1]) == 1