Test: No address reuse for single descriptor

This test is to ensure there are no regressions when we later change
internal logic of `Wallet`. A single descriptor wallet should always get
a new address with `AddressIndex::New` even if we alternate grabbing
internal/external keychains.
This commit is contained in:
志宇 2022-07-09 20:29:58 +08:00
parent dd51380520
commit 2c02a44586
No known key found for this signature in database
GPG Key ID: F6345C9837C2BDE8

View File

@ -4490,6 +4490,34 @@ pub(crate) mod test {
);
}
#[test]
fn test_get_address_no_reuse_single_descriptor() {
use crate::descriptor::template::Bip84;
use std::collections::HashSet;
let key = bitcoin::util::bip32::ExtendedPrivKey::from_str("tprv8ZgxMBicQKsPcx5nBGsR63Pe8KnRUqmbJNENAfGftF3yuXoMMoVJJcYeUw5eVkm9WBPjWYt6HMWYJNesB5HaNVBaFc1M6dRjWSYnmewUMYy").unwrap();
let wallet = Wallet::new(
Bip84(key, KeychainKind::External),
None,
Network::Regtest,
MemoryDatabase::default(),
)
.unwrap();
let mut used_set = HashSet::new();
(0..3).for_each(|_| {
let external_addr = wallet.get_address(AddressIndex::New).unwrap().address;
assert!(used_set.insert(external_addr));
let internal_addr = wallet
.get_internal_address(AddressIndex::New)
.unwrap()
.address;
assert!(used_set.insert(internal_addr));
});
}
#[test]
fn test_taproot_psbt_populate_tap_key_origins() {
let (wallet, _, _) = get_funded_wallet(get_test_tr_single_sig_xprv());