tadd test for key derivation - electrum - Electrum Bitcoin wallet HTML git clone https://git.parazyd.org/electrum DIR Log DIR Files DIR Refs DIR Submodules --- DIR commit 6d703db971769ed6410c25c4f998051c4e8a3128 DIR parent aa8700d0b3fdffdbcb18ca235d1061a37f2dd23a HTML Author: ThomasV <thomasv@electrum.org> Date: Tue, 17 Apr 2018 11:28:01 +0200 add test for key derivation Diffstat: M lib/tests/test_lnbase.py | 13 +++++++++++++ 1 file changed, 13 insertions(+), 0 deletions(-) --- DIR diff --git a/lib/tests/test_lnbase.py b/lib/tests/test_lnbase.py t@@ -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 t@@ -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'))