From f3f700dd529482e420439cb2483e7840223e4ead Mon Sep 17 00:00:00 2001 From: callebtc <93376500+callebtc@users.noreply.github.com> Date: Thu, 21 Sep 2023 14:49:09 +0200 Subject: [PATCH] test second refund pubkey --- tests/test_wallet_p2pk.py | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/tests/test_wallet_p2pk.py b/tests/test_wallet_p2pk.py index 600fec2b..9a864242 100644 --- a/tests/test_wallet_p2pk.py +++ b/tests/test_wallet_p2pk.py @@ -135,6 +135,7 @@ async def test_p2pk_locktime_with_refund_pubkey(wallet1: Wallet, wallet2: Wallet ) send_proofs_copy = copy.deepcopy(send_proofs) # receiver side: can't redeem since we used a garbage pubkey + # and locktime has not passed await assert_err( wallet2.redeem(send_proofs), "Mint Error: no valid signature provided for input.", @@ -163,6 +164,7 @@ async def test_p2pk_locktime_with_wrong_refund_pubkey(wallet1: Wallet, wallet2: ) send_proofs_copy = copy.deepcopy(send_proofs) # receiver side: can't redeem since we used a garbage pubkey + # and locktime has not passed await assert_err( wallet2.redeem(send_proofs), "Mint Error: no valid signature provided for input.", @@ -175,6 +177,38 @@ async def test_p2pk_locktime_with_wrong_refund_pubkey(wallet1: Wallet, wallet2: ) +@pytest.mark.asyncio +async def test_p2pk_locktime_with_second_refund_pubkey( + wallet1: Wallet, wallet2: Wallet +): + await wallet1.mint(64) + pubkey_wallet1 = await wallet1.create_p2pk_pubkey() # receiver side + pubkey_wallet2 = await wallet2.create_p2pk_pubkey() # receiver side + # sender side + garbage_pubkey = PrivateKey().pubkey + assert garbage_pubkey + secret_lock = await wallet1.create_p2pk_lock( + garbage_pubkey.serialize().hex(), # create lock to unspendable pubkey + locktime_seconds=2, # locktime + tags=Tags( + [["refund", pubkey_wallet2, pubkey_wallet1]] + ), # multiple refund pubkeys + ) # sender side + _, send_proofs = await wallet1.split_to_send( + wallet1.proofs, 8, secret_lock=secret_lock + ) + send_proofs_copy = copy.deepcopy(send_proofs) + # receiver side: can't redeem since we used a garbage pubkey + # and locktime has not passed + await assert_err( + wallet1.redeem(send_proofs), + "Mint Error: no valid signature provided for input.", + ) + await asyncio.sleep(2) + # we can now redeem because of the refund locktime + await wallet1.redeem(send_proofs_copy) + + @pytest.mark.asyncio async def test_p2pk_multisig_2_of_2(wallet1: Wallet, wallet2: Wallet): await wallet1.mint(64)