forked from cypherstack/spark
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_address.py
32 lines (27 loc) · 1.09 KB
/
test_address.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
import address
from dumb25519 import hash_to_scalar, random_point
import unittest
class TestAddress(unittest.TestCase):
def test_generate(self):
lookahead = 8
params = address.AddressParameters(random_point(),random_point(),lookahead)
spend = address.SpendKey(params)
full = spend.full_view_key()
incoming = spend.incoming_view_key()
public = spend.public_address(lookahead)
self.assertEqual(incoming.s1,spend.s1)
self.assertEqual(full.s1,spend.s1)
self.assertEqual(full.s2,spend.s2)
self.assertEqual(full.D,spend.r*params.G)
self.assertEqual(public.Q0,hash_to_scalar('Q0',spend.s1,lookahead)*params.F)
self.assertEqual(public.Q1,spend.s1*public.Q0)
self.assertEqual(public.Q2,(hash_to_scalar('Q2',spend.s1,lookahead) + spend.s2)*params.F + spend.r*params.G)
for i in range(lookahead+2):
entry = (hash_to_scalar('Q2',spend.s1,i) + spend.s2)*params.F + spend.r*params.G
if i > lookahead:
with self.assertRaises(IndexError):
incoming.get_diversifier(entry)
else:
self.assertEqual(incoming.get_diversifier(entry),i)
if __name__ == '__main__':
unittest.main()