qa: functional test Miniscript inside Taproot descriptors

This commit is contained in:
Antoine Poinsot 2023-02-15 11:56:01 +01:00
parent 8571b89a7f
commit bd4b11ee06
No known key found for this signature in database
GPG key ID: E13FC145CD3F4304

View file

@ -33,7 +33,7 @@ PUBKEYS = [
"0211c7b2e18b6fd330f322de087da62da92ae2ae3d0b7cec7e616479cce175f183", "0211c7b2e18b6fd330f322de087da62da92ae2ae3d0b7cec7e616479cce175f183",
] ]
MINISCRIPTS = [ P2WSH_MINISCRIPTS = [
# One of two keys # One of two keys
f"or_b(pk({TPUBS[0]}/*),s:pk({TPUBS[1]}/*))", f"or_b(pk({TPUBS[0]}/*),s:pk({TPUBS[1]}/*))",
# A script similar (same spending policy) to BOLT3's offered HTLC (with anchor outputs) # A script similar (same spending policy) to BOLT3's offered HTLC (with anchor outputs)
@ -44,6 +44,18 @@ MINISCRIPTS = [
f"or_i(and_b(pk({PUBKEYS[0]}),a:and_b(pk({PUBKEYS[1]}),a:and_b(pk({PUBKEYS[2]}),a:and_b(pk({PUBKEYS[3]}),s:pk({PUBKEYS[4]}))))),and_v(v:thresh(2,pkh({TPUBS[0]}/*),a:pkh({PUBKEYS[5]}),a:pkh({PUBKEYS[6]})),older(4209713)))", f"or_i(and_b(pk({PUBKEYS[0]}),a:and_b(pk({PUBKEYS[1]}),a:and_b(pk({PUBKEYS[2]}),a:and_b(pk({PUBKEYS[3]}),s:pk({PUBKEYS[4]}))))),and_v(v:thresh(2,pkh({TPUBS[0]}/*),a:pkh({PUBKEYS[5]}),a:pkh({PUBKEYS[6]})),older(4209713)))",
] ]
DESCS = [
*[f"wsh({ms})" for ms in P2WSH_MINISCRIPTS],
# A Taproot with one of the above scripts as the single script path.
f"tr(4d54bb9928a0683b7e383de72943b214b0716f58aa54c7ba6bcea2328bc9c768,{P2WSH_MINISCRIPTS[0]})",
# A Taproot with two script paths among the above scripts.
f"tr(4d54bb9928a0683b7e383de72943b214b0716f58aa54c7ba6bcea2328bc9c768,{{{P2WSH_MINISCRIPTS[0]},{P2WSH_MINISCRIPTS[1]}}})",
# A Taproot with three script paths among the above scripts.
f"tr(4d54bb9928a0683b7e383de72943b214b0716f58aa54c7ba6bcea2328bc9c768,{{{{{P2WSH_MINISCRIPTS[0]},{P2WSH_MINISCRIPTS[1]}}},{P2WSH_MINISCRIPTS[2].replace('multi', 'multi_a')}}})",
# A Taproot with all above scripts in its tree.
f"tr(4d54bb9928a0683b7e383de72943b214b0716f58aa54c7ba6bcea2328bc9c768,{{{{{P2WSH_MINISCRIPTS[0]},{P2WSH_MINISCRIPTS[1]}}},{{{P2WSH_MINISCRIPTS[2].replace('multi', 'multi_a')},{P2WSH_MINISCRIPTS[3]}}}}})",
]
MINISCRIPTS_PRIV = [ MINISCRIPTS_PRIV = [
# One of two keys, of which one private key is known # One of two keys, of which one private key is known
{ {
@ -150,9 +162,9 @@ class WalletMiniscriptTest(BitcoinTestFramework):
self.skip_if_no_wallet() self.skip_if_no_wallet()
self.skip_if_no_sqlite() self.skip_if_no_sqlite()
def watchonly_test(self, ms): def watchonly_test(self, desc):
self.log.info(f"Importing Miniscript '{ms}'") self.log.info(f"Importing descriptor '{desc}'")
desc = descsum_create(f"wsh({ms})") desc = descsum_create(f"{desc}")
assert self.ms_wo_wallet.importdescriptors( assert self.ms_wo_wallet.importdescriptors(
[ [
{ {
@ -166,11 +178,14 @@ class WalletMiniscriptTest(BitcoinTestFramework):
)[0]["success"] )[0]["success"]
self.log.info("Testing we derive new addresses for it") self.log.info("Testing we derive new addresses for it")
addr_type = "bech32m" if desc.startswith("tr(") else "bech32"
assert_equal( assert_equal(
self.ms_wo_wallet.getnewaddress(), self.funder.deriveaddresses(desc, 0)[0] self.ms_wo_wallet.getnewaddress(address_type=addr_type),
self.funder.deriveaddresses(desc, 0)[0],
) )
assert_equal( assert_equal(
self.ms_wo_wallet.getnewaddress(), self.funder.deriveaddresses(desc, 1)[1] self.ms_wo_wallet.getnewaddress(address_type=addr_type),
self.funder.deriveaddresses(desc, 1)[1],
) )
self.log.info("Testing we detect funds sent to one of them") self.log.info("Testing we detect funds sent to one of them")
@ -290,8 +305,8 @@ class WalletMiniscriptTest(BitcoinTestFramework):
assert not res["success"] and "is not satisfiable" in res["error"]["message"] assert not res["success"] and "is not satisfiable" in res["error"]["message"]
# Test we can track any type of Miniscript # Test we can track any type of Miniscript
for ms in MINISCRIPTS: for desc in DESCS:
self.watchonly_test(ms) self.watchonly_test(desc)
# Test we can sign for any Miniscript. # Test we can sign for any Miniscript.
for ms in MINISCRIPTS_PRIV: for ms in MINISCRIPTS_PRIV: