-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathtest_miximus.py
46 lines (35 loc) · 1.09 KB
/
test_miximus.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import unittest
from ethsnarks.field import FQ
from ethsnarks.mimc import mimc_hash
from ethsnarks.utils import native_lib_path
from ethsnarks.merkletree import MerkleTree
from miximus import Miximus
NATIVE_LIB_PATH = native_lib_path('../.build/libmiximus')
VK_PATH = '../.keys/miximus.vk.json'
PK_PATH = '../.keys/miximus.pk.raw'
class TestMiximus(unittest.TestCase):
def test_make_proof(self):
n_items = 2<<28
tree = MerkleTree(n_items)
for n in range(0, 2):
tree.append(int(FQ.random()))
exthash = int(FQ.random())
secret = int(FQ.random())
leaf_hash = mimc_hash([secret])
leaf_idx = tree.append(leaf_hash)
self.assertEqual(leaf_idx, tree.index(leaf_hash))
# Verify it exists in true
leaf_proof = tree.proof(leaf_idx)
self.assertTrue(leaf_proof.verify(tree.root))
# Generate proof
wrapper = Miximus(NATIVE_LIB_PATH, VK_PATH, PK_PATH)
tree_depth = wrapper.tree_depth
snark_proof = wrapper.prove(
tree.root,
secret,
exthash,
leaf_proof.address,
leaf_proof.path)
self.assertTrue(wrapper.verify(snark_proof))
if __name__ == "__main__":
unittest.main()