test: Fix wallet_basic.py for BDB-only wallets

This commit is contained in:
Hennadii Stepanov 2022-09-07 19:28:18 +02:00
parent fc44d1796e
commit 1941ce6cd1
No known key found for this signature in database
GPG key ID: 410108112E7EA81F

View file

@ -695,37 +695,38 @@ class WalletTest(BitcoinTestFramework):
txid_feeReason_four = self.nodes[2].sendmany(dummy='', amounts={address: 5}, verbose=False) txid_feeReason_four = self.nodes[2].sendmany(dummy='', amounts={address: 5}, verbose=False)
assert_equal(self.nodes[2].gettransaction(txid_feeReason_four)['txid'], txid_feeReason_four) assert_equal(self.nodes[2].gettransaction(txid_feeReason_four)['txid'], txid_feeReason_four)
self.log.info("Testing 'listunspent' outputs the parent descriptor(s) of coins") if self.options.descriptors:
# Create two multisig descriptors, and send a UTxO each. self.log.info("Testing 'listunspent' outputs the parent descriptor(s) of coins")
multi_a = descsum_create("wsh(multi(1,tpubD6NzVbkrYhZ4YBNjUo96Jxd1u4XKWgnoc7LsA1jz3Yc2NiDbhtfBhaBtemB73n9V5vtJHwU6FVXwggTbeoJWQ1rzdz8ysDuQkpnaHyvnvzR/*,tpubD6NzVbkrYhZ4YHdDGMAYGaWxMSC1B6tPRTHuU5t3BcfcS3nrF523iFm5waFd1pP3ZvJt4Jr8XmCmsTBNx5suhcSgtzpGjGMASR3tau1hJz4/*))") # Create two multisig descriptors, and send a UTxO each.
multi_b = descsum_create("wsh(multi(1,tpubD6NzVbkrYhZ4YHdDGMAYGaWxMSC1B6tPRTHuU5t3BcfcS3nrF523iFm5waFd1pP3ZvJt4Jr8XmCmsTBNx5suhcSgtzpGjGMASR3tau1hJz4/*,tpubD6NzVbkrYhZ4Y2RLiuEzNQkntjmsLpPYDm3LTRBYynUQtDtpzeUKAcb9sYthSFL3YR74cdFgF5mW8yKxv2W2CWuZDFR2dUpE5PF9kbrVXNZ/*))") multi_a = descsum_create("wsh(multi(1,tpubD6NzVbkrYhZ4YBNjUo96Jxd1u4XKWgnoc7LsA1jz3Yc2NiDbhtfBhaBtemB73n9V5vtJHwU6FVXwggTbeoJWQ1rzdz8ysDuQkpnaHyvnvzR/*,tpubD6NzVbkrYhZ4YHdDGMAYGaWxMSC1B6tPRTHuU5t3BcfcS3nrF523iFm5waFd1pP3ZvJt4Jr8XmCmsTBNx5suhcSgtzpGjGMASR3tau1hJz4/*))")
addr_a = self.nodes[0].deriveaddresses(multi_a, 0)[0] multi_b = descsum_create("wsh(multi(1,tpubD6NzVbkrYhZ4YHdDGMAYGaWxMSC1B6tPRTHuU5t3BcfcS3nrF523iFm5waFd1pP3ZvJt4Jr8XmCmsTBNx5suhcSgtzpGjGMASR3tau1hJz4/*,tpubD6NzVbkrYhZ4Y2RLiuEzNQkntjmsLpPYDm3LTRBYynUQtDtpzeUKAcb9sYthSFL3YR74cdFgF5mW8yKxv2W2CWuZDFR2dUpE5PF9kbrVXNZ/*))")
addr_b = self.nodes[0].deriveaddresses(multi_b, 0)[0] addr_a = self.nodes[0].deriveaddresses(multi_a, 0)[0]
txid_a = self.nodes[0].sendtoaddress(addr_a, 0.01) addr_b = self.nodes[0].deriveaddresses(multi_b, 0)[0]
txid_b = self.nodes[0].sendtoaddress(addr_b, 0.01) txid_a = self.nodes[0].sendtoaddress(addr_a, 0.01)
self.generate(self.nodes[0], 1, sync_fun=self.no_op) txid_b = self.nodes[0].sendtoaddress(addr_b, 0.01)
# Now import the descriptors, make sure we can identify on which descriptor each coin was received. self.generate(self.nodes[0], 1, sync_fun=self.no_op)
self.nodes[0].createwallet(wallet_name="wo", descriptors=True, disable_private_keys=True) # Now import the descriptors, make sure we can identify on which descriptor each coin was received.
wo_wallet = self.nodes[0].get_wallet_rpc("wo") self.nodes[0].createwallet(wallet_name="wo", descriptors=True, disable_private_keys=True)
wo_wallet.importdescriptors([ wo_wallet = self.nodes[0].get_wallet_rpc("wo")
{ wo_wallet.importdescriptors([
"desc": multi_a, {
"active": False, "desc": multi_a,
"timestamp": "now", "active": False,
}, "timestamp": "now",
{ },
"desc": multi_b, {
"active": False, "desc": multi_b,
"timestamp": "now", "active": False,
}, "timestamp": "now",
]) },
coins = wo_wallet.listunspent(minconf=0) ])
assert_equal(len(coins), 2) coins = wo_wallet.listunspent(minconf=0)
coin_a = next(c for c in coins if c["txid"] == txid_a) assert_equal(len(coins), 2)
assert_equal(coin_a["parent_descs"][0], multi_a) coin_a = next(c for c in coins if c["txid"] == txid_a)
coin_b = next(c for c in coins if c["txid"] == txid_b) assert_equal(coin_a["parent_descs"][0], multi_a)
assert_equal(coin_b["parent_descs"][0], multi_b) coin_b = next(c for c in coins if c["txid"] == txid_b)
self.nodes[0].unloadwallet("wo") assert_equal(coin_b["parent_descs"][0], multi_b)
self.nodes[0].unloadwallet("wo")
if __name__ == '__main__': if __name__ == '__main__':