logos-blockchain-specs/carnot/test_tree_overlay.py

58 lines
2.1 KiB
Python
Raw Normal View History

2023-06-27 09:39:02 +02:00
from unittest import TestCase
from tree_overlay import CarnotOverlay, CarnotTree
2023-06-27 09:39:02 +02:00
2023-06-29 15:40:09 +02:00
class TestCarnotTree(TestCase):
def setUp(self) -> None:
self.nodes = [int.to_bytes(i, length=32, byteorder="little") for i in range(10)]
self.tree = CarnotTree(self.nodes, 3)
2023-06-29 15:40:09 +02:00
def test_parenting(self):
root = self.tree.inner_committees[0]
one = self.tree.inner_committees[1]
two = self.tree.inner_committees[2]
self.assertIs(self.tree.parent_committee(one), root)
self.assertIs(self.tree.parent_committee(two), root)
2023-06-30 09:20:26 +02:00
def test_root_parenting(self):
root = self.tree.inner_committees[0]
self.assertIsNone(self.tree.parent_committee(root))
2023-06-29 15:40:09 +02:00
def test_childs(self):
root = self.tree.inner_committees[0]
one = self.tree.inner_committees[1]
two = self.tree.inner_committees[2]
self.assertEqual(self.tree.child_committees(root), (one, two))
2023-06-27 09:39:02 +02:00
class TestTreeOverlay(TestCase):
def setUp(self) -> None:
self.nodes = [int.to_bytes(i, length=32, byteorder="little") for i in range(10)]
self.tree = CarnotOverlay(self.nodes, self.nodes[0], b"0"*32, 3)
def test_leader(self):
self.assertEqual(self.tree.leader(), self.nodes[0])
def test_next_leader_is_advance_current_leader(self):
leader = self.tree.next_leader()
self.tree = self.tree.advance(b"1"*32)
self.assertEqual(leader, self.tree.leader())
def test_root_committee(self):
2023-06-30 09:18:12 +02:00
self.assertEqual(self.tree.root_committee(), set([self.nodes[9], *self.nodes[:3]]))
2023-06-27 09:39:02 +02:00
def test_leaf_committees(self):
2023-06-30 09:18:12 +02:00
self.assertEqual(self.tree.leaf_committees(), {frozenset(self.nodes[3:6]), frozenset(self.nodes[6:9])})
2023-06-27 09:39:02 +02:00
def test_super_majority_threshold_for_leaf(self):
2023-06-30 09:18:12 +02:00
self.assertEqual(self.tree.super_majority_threshold(self.nodes[-2]), 0)
2023-06-27 09:39:02 +02:00
def test_super_majority_threshold_for_root_member(self):
self.assertEqual(self.tree.super_majority_threshold(self.nodes[0]), 3)
def test_leader_super_majority_threshold(self):
2023-06-30 09:54:10 +02:00
self.assertEqual(self.tree.leader_super_majority_threshold(self.nodes[0]), 7)
2023-06-29 15:40:09 +02:00