URI: 
       tlnbase_test: insert remote_signature and compare fields independently - electrum - Electrum Bitcoin wallet
  HTML git clone https://git.parazyd.org/electrum
   DIR Log
   DIR Files
   DIR Refs
   DIR Submodules
       ---
   DIR commit 814146f099931acf3b3c3da69564e03df4377a6c
   DIR parent 7b6f64a402bf4836cae4ab825988ed07cdeaf75e
  HTML Author: Janus <ysangkok@gmail.com>
       Date:   Fri, 13 Apr 2018 16:53:51 +0200
       
       lnbase_test: insert remote_signature and compare fields independently
       
       Diffstat:
         M lib/tests/test_lnbase.py            |      33 ++++++++++++++++++++++++++-----
       
       1 file changed, 28 insertions(+), 5 deletions(-)
       ---
   DIR diff --git a/lib/tests/test_lnbase.py b/lib/tests/test_lnbase.py
       t@@ -1,6 +1,9 @@
       +import json
        import unittest
        from lib.util import bh2u
        from lib.lnbase import make_commitment, get_locktime
       +from lib.transaction import Transaction
       +from lib import bitcoin
        
        class Test_LNBase(unittest.TestCase):
        
       t@@ -35,15 +38,35 @@ class Test_LNBase(unittest.TestCase):
                # actual commitment transaction fee = 10860
                # to_local amount 6989140 wscript 63210212a140cd0c6539d07cd08dfe09984dec3251ea808b892efeac3ede9402bf2b1967029000b2752103fd5960528dc152014952efdb702a88f71e3c1653b2314431701ec77e57fde83c68ac
                # to_remote amount 3000000 P2WPKH(0394854aa6eab5b2a8122cc726e9dded053a2184d88256816826d6231c068d4a5b)
       -        #remote_signature = 3045022100f51d2e566a70ba740fc5d8c0f07b9b93d2ed741c3c0860c613173de7d39e7968022041376d520e9c0e1ad52248ddf4b22e12be8763007df977253ef45a4ca3bdb7c0
       +        remote_signature = "3045022100f51d2e566a70ba740fc5d8c0f07b9b93d2ed741c3c0860c613173de7d39e7968022041376d520e9c0e1ad52248ddf4b22e12be8763007df977253ef45a4ca3bdb7c0"
                # local_signature = 3044022051b75c73198c6deee1a875871c3961832909acd297c6b908d59e3319e5185a46022055c419379c5051a78d00dbbce11b5b664a0c22815fbcc6fcef6b1937c3836939
                #num_htlcs: 0
       -        c_tx = make_commitment(
       +        our_commit_tx = make_commitment(
                    local_funding_pubkey, remote_funding_pubkey,
                    local_payment_basepoint, remote_payment_basepoint,
                    local_revocation_pubkey, local_delayedpubkey,
                    funding_tx_id, funding_output_index, funding_amount_satoshi)
       -        
       -        commit_tx = '02000000000101bef67e4e2fb9ddeeb3461973cd4c62abb35050b1add772995b820b584a488489000000000038b02b8002c0c62d0000000000160014ccf1af2f2aabee14bb40fa3851ab2301de84311054a56a00000000002200204adb4e2f00643db396dd120d4e7dc17625f5f2c11a40d857accc862d6b7dd80e0400473044022051b75c73198c6deee1a875871c3961832909acd297c6b908d59e3319e5185a46022055c419379c5051a78d00dbbce11b5b664a0c22815fbcc6fcef6b1937c383693901483045022100f51d2e566a70ba740fc5d8c0f07b9b93d2ed741c3c0860c613173de7d39e7968022041376d520e9c0e1ad52248ddf4b22e12be8763007df977253ef45a4ca3bdb7c001475221023da092f6980e58d2c037173180e9a465476026ee50f96695963e8efe436f54eb21030e9f7b623d2ccc7c9bd44d66d5ce21ce504c0acf6385a132cec6d3c39fa711c152ae3e195220'
       -        self.assertEqual(str(c_tx), commit_tx)
       +        our_commit_tx.sign({bh2u(local_funding_pubkey): (local_funding_privkey[:-1], True)})
        
       +        ref_commit_tx_str = '02000000000101bef67e4e2fb9ddeeb3461973cd4c62abb35050b1add772995b820b584a488489000000000038b02b8002c0c62d0000000000160014ccf1af2f2aabee14bb40fa3851ab2301de84311054a56a00000000002200204adb4e2f00643db396dd120d4e7dc17625f5f2c11a40d857accc862d6b7dd80e0400473044022051b75c73198c6deee1a875871c3961832909acd297c6b908d59e3319e5185a46022055c419379c5051a78d00dbbce11b5b664a0c22815fbcc6fcef6b1937c383693901483045022100f51d2e566a70ba740fc5d8c0f07b9b93d2ed741c3c0860c613173de7d39e7968022041376d520e9c0e1ad52248ddf4b22e12be8763007df977253ef45a4ca3bdb7c001475221023da092f6980e58d2c037173180e9a465476026ee50f96695963e8efe436f54eb21030e9f7b623d2ccc7c9bd44d66d5ce21ce504c0acf6385a132cec6d3c39fa711c152ae3e195220'
       +        ref_commit_tx = Transaction(ref_commit_tx_str)
       +
       +        pubkeys, _x_pubkeys = our_commit_tx.get_sorted_pubkeys(our_commit_tx.inputs()[0])
       +        index_of_pubkey = pubkeys.index(bh2u(remote_funding_pubkey))
       +        our_commit_tx._inputs[0]["signatures"][index_of_pubkey] = remote_signature + "01"
       +
       +        print("Reference inputs", json.dumps(ref_commit_tx.inputs(), indent=2))
       +        print("Our inputs", json.dumps(our_commit_tx.inputs(), indent=2))
       +
       +        for idx, inp in enumerate(our_commit_tx.inputs()):
       +            for field in inp.keys():
       +                 self.assertEqual(inp[field], ref_commit_tx.inputs()[idx][field], field)
       +
       +        self.assertEquals(ref_commit_tx.inputs()[0]["witness"], our_commit_tx.serialize_witness(txin=our_commit_tx.inputs()[0]))
       +
       +        output1adr = ref_commit_tx.outputs()[0][1]
       +        output2adr = ref_commit_tx.outputs()[1][1]
       +        self.assertTrue(bitcoin.redeem_script_to_address("p2wsh", "63210212a140cd0c6539d07cd08dfe09984dec3251ea808b892efeac3ede9402bf2b1967029000b2752103fd5960528dc152014952efdb702a88f71e3c1653b2314431701ec77e57fde83c68ac") in [output1adr, output2adr])
       +        # todo check order and other output
       +
       +        self.assertEqual(str(our_commit_tx), ref_commit_tx_str)