예제 #1
0
    def test_two_even_items(self):
        tree = MerkleTree()
        tree.add_content("test")
        tree.add_hash(tree.hash_f("test2"))
        result = tree.merkle_root()

        ans = '694299f8eb01a328732fb21f4163fbfaa8f60d5662f04f52ad33bec63953ec7f'
        self.assertEqual(result, ans)
예제 #2
0
    def test_proof_false2(self):
        tree = MerkleTree()

        tree.add_content("test")
        tree.add_content("test2")
        tree.add_content("test3")

        proof = tree.merkle_proof(sha256("test4"))
        self.assertFalse(proof.is_valid())
예제 #3
0
    def test_tree_odd_items(self):
        tree = MerkleTree()
        tree.add_content("test")
        tree.add_content("test2")
        tree.add_content("test3")
        result = tree.merkle_root()

        ans = 'd49e815a91a26d399f8c2fba429e6ef7e472e54b6eb1e04341d207eee219f6c0'
        self.assertEqual(result, ans)
예제 #4
0
    def test_tree_odd_items(self):
        tree = MerkleTree()
        tree.add_content("test")
        tree.add_content("test2")
        tree.add_content("test3")
        result = tree.merkle_root()

        ans = 'd49e815a91a26d399f8c2fba429e6ef7e472e54b6eb1e04341d207eee219f6c0'
        self.assertEqual(result, ans)

        target = tree.hash_f("test3")
        proof = tree.merkle_proof(target)
        self.assertEqual(proof[1].get_parent(), ans)
예제 #5
0
    def test_tree_odd_items(self):
        tree = MerkleTree()
        tree.add_content("test")
        tree.add_content("test2")
        tree.add_content("test3")
        result = tree.merkle_root()

        ans = 'd49e815a91a26d399f8c2fba429e6ef7e472e54b6eb1e04341d207eee219f6c0'
        self.assertEqual(result, ans)

        target = tree.hash_f("test3")
        proof = tree.merkle_proof(target)
        self.assertEqual(proof[1].get_parent(), ans)
예제 #6
0
    def test_merkle_proof_simple_true(self):
        tree = MerkleTree()
        tree.add_content("test")
        tree.add_content("test2")

        left = sha256("test")
        right = sha256("test2")
        branch = MerkleBranch(left, right)

        target = left
        proof = MerkleProof(target, tree)
        proof.add(branch)
        self.assertTrue(proof.is_valid())
예제 #7
0
 def test_proof_single_true(self):
     tree = MerkleTree()
     tree.add_content("test")
     proof = tree.merkle_proof(sha256("test"))
     self.assertTrue(proof.is_valid())
예제 #8
0
 def test_large_tree(self):
     tree = MerkleTree()
     for i in range(10000):
         tree.add_content(str(i))
     ans = 'a048d580177b80a60cbd31355400a0c9eabb5d2d3a4704fc9c86bae277f985c7'
     self.assertEqual(tree.merkle_root(), ans)