From 62b2d23edbad76c1d68bb8c0fc8af54e7c0d7dc8 Mon Sep 17 00:00:00 2001 From: Ava Chow Date: Mon, 9 Dec 2024 14:55:38 -0500 Subject: [PATCH] wallet: Migrate non-HD keys to combo() descriptor Non-HD keys in legacy wallets without a HD seed ID were being migrated to separate pk(), pkh(), sh(wpkh()), and wpkh() descriptors for each key. These could be more compactly represented as combo() descriptors, so migration should make combo() for them. It is possible that existing non-HD wallets that were migrated, or wallets that started blank and had private keys imported into them have run into this issue. However, as the 4 descriptors produce the same output scripts as the single combo(), so any previously migrated wallets are not missing any output scripts. The only observable difference should be performance related, and the wallet size on disk. --- src/wallet/scriptpubkeyman.cpp | 2 +- test/functional/wallet_migration.py | 8 ++------ 2 files changed, 3 insertions(+), 7 deletions(-) diff --git a/src/wallet/scriptpubkeyman.cpp b/src/wallet/scriptpubkeyman.cpp index 62384056dc6e4..23e2257b1e7cf 100644 --- a/src/wallet/scriptpubkeyman.cpp +++ b/src/wallet/scriptpubkeyman.cpp @@ -1799,7 +1799,7 @@ std::optional LegacyDataSPKM::MigrateToDescriptor() keyid_it++; continue; } - if (m_hd_chain.seed_id == meta.hd_seed_id || m_inactive_hd_chains.count(meta.hd_seed_id) > 0) { + if (!meta.hd_seed_id.IsNull() && (m_hd_chain.seed_id == meta.hd_seed_id || m_inactive_hd_chains.count(meta.hd_seed_id) > 0)) { keyid_it = keyids.erase(keyid_it); continue; } diff --git a/test/functional/wallet_migration.py b/test/functional/wallet_migration.py index fd6ec16065faa..62b4756a8ffcb 100755 --- a/test/functional/wallet_migration.py +++ b/test/functional/wallet_migration.py @@ -1032,15 +1032,11 @@ def test_manual_keys_import(self): # There should be descriptors containing the imported key for: pk(), pkh(), sh(wpkh()), wpkh() key_origin = hash160(pubkey)[:4].hex() pubkey_hex = pubkey.hex() - pk_desc = descsum_create(f'pk([{key_origin}]{pubkey_hex})') - pkh_desc = descsum_create(f'pkh([{key_origin}]{pubkey_hex})') - sh_wpkh_desc = descsum_create(f'sh(wpkh([{key_origin}]{pubkey_hex}))') - wpkh_desc = descsum_create(f'wpkh([{key_origin}]{pubkey_hex})') - expected_descs = [pk_desc, pkh_desc, sh_wpkh_desc, wpkh_desc] + combo_desc = descsum_create(f"combo([{key_origin}]{pubkey_hex})") # Verify all expected descriptors were migrated migrated_desc = [item['desc'] for item in wallet.listdescriptors()['descriptors'] if pubkey.hex() in item['desc']] - assert_equal(expected_descs, migrated_desc) + assert_equal([combo_desc], migrated_desc) wallet.unloadwallet() ######################################################