mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-05 10:17:30 -05:00
ab31b9d6fe
Currently it's possible for ReleaseWallet to delete the CWallet pointer while it is processing BlockConnected, etc chain notifications. To fix this, unregister from notifications earlier in UnloadWallet instead of ReleaseWallet, and use a new RegisterSharedValidationInterface function to prevent the CValidationInterface shared_ptr from being deleted until the last notification is actually finished.
15 lines
613 B
C++
15 lines
613 B
C++
// Copyright (c) 2016-2019 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#include <wallet/test/wallet_test_fixture.h>
|
|
|
|
WalletTestingSetup::WalletTestingSetup(const std::string& chainName)
|
|
: TestingSetup(chainName),
|
|
m_wallet(m_chain.get(), WalletLocation(), WalletDatabase::CreateMock())
|
|
{
|
|
bool fFirstRun;
|
|
m_wallet.LoadWallet(fFirstRun);
|
|
m_chain_notifications_handler = m_chain->handleNotifications({ &m_wallet, [](CWallet*) {} });
|
|
m_chain_client->registerRpcs();
|
|
}
|