commit 6d703db971769ed6410c25c4f998051c4e8a3128
parent aa8700d0b3fdffdbcb18ca235d1061a37f2dd23a
Author: ThomasV <thomasv@electrum.org>
Date: Tue, 17 Apr 2018 11:28:01 +0200
add test for key derivation
Diffstat:
1 file changed, 13 insertions(+), 0 deletions(-)
diff --git a/lib/tests/test_lnbase.py b/lib/tests/test_lnbase.py
@@ -1,7 +1,10 @@
+import binascii
import json
import unittest
+
from lib.util import bh2u, bfh
from lib.lnbase import make_commitment, get_obscured_ctn, Peer, make_offered_htlc, make_received_htlc
+from lib.lnbase import secret_to_pubkey, derive_pubkey
from lib.transaction import Transaction
from lib import bitcoin
import ecdsa.ellipticcurve
@@ -167,3 +170,13 @@ class Test_LNBase(unittest.TestCase):
p.on_channel_update({'short_channel_id': bfh('0000000000000006'), 'flags': b'0', 'cltv_expiry_delta': 10, 'htlc_minimum_msat': 250, 'fee_base_msat': 100, 'fee_proportional_millionths': 99999999})
p.on_channel_update({'short_channel_id': bfh('0000000000000006'), 'flags': b'1', 'cltv_expiry_delta': 10, 'htlc_minimum_msat': 250, 'fee_base_msat': 100, 'fee_proportional_millionths': 150})
print(p.find_route_for_payment('a', 'e', 100000))
+
+ def test_key_derivation(self):
+ print('test key derivation')
+ base_secret = 0x000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f
+ per_commitment_secret = 0x1f1e1d1c1b1a191817161514131211100f0e0d0c0b0a09080706050403020100
+ base_point = secret_to_pubkey(base_secret)
+ self.assertEqual(base_point, bfh('036d6caac248af96f6afa7f904f550253a0f3ef3f5aa2fe6838a95b216691468e2'))
+ per_commitment_point = secret_to_pubkey(per_commitment_secret)
+ localpubkey = derive_pubkey(base_point, per_commitment_point)
+ self.assertEqual(localpubkey, bfh('0235f2dbfaa89b57ec7b055afe29849ef7ddfeb1cefdb9ebdc43f5494984db29e5'))