mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-15 22:32:37 -03:00
66576c4fd5
Leaving this value set interfered with the CreateWallet test if it happened to execute later in the test ordering. Specifically it would cause CreateWallet test to write data to the current directory instead of temporary test directory.
50 lines
1.8 KiB
C++
50 lines
1.8 KiB
C++
// Copyright (c) 2018-2020 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 <fs.h>
|
|
#include <univalue.h>
|
|
#include <util/check.h>
|
|
#include <util/system.h>
|
|
|
|
#include <wallet/test/init_test_fixture.h>
|
|
|
|
InitWalletDirTestingSetup::InitWalletDirTestingSetup(const std::string& chainName) : BasicTestingSetup(chainName)
|
|
{
|
|
m_wallet_client = MakeWalletClient(*m_node.chain, *Assert(m_node.args));
|
|
|
|
std::string sep;
|
|
sep += fs::path::preferred_separator;
|
|
|
|
m_datadir = GetDataDir();
|
|
m_cwd = fs::current_path();
|
|
|
|
m_walletdir_path_cases["default"] = m_datadir / "wallets";
|
|
m_walletdir_path_cases["custom"] = m_datadir / "my_wallets";
|
|
m_walletdir_path_cases["nonexistent"] = m_datadir / "path_does_not_exist";
|
|
m_walletdir_path_cases["file"] = m_datadir / "not_a_directory.dat";
|
|
m_walletdir_path_cases["trailing"] = m_datadir / "wallets" / sep;
|
|
m_walletdir_path_cases["trailing2"] = m_datadir / "wallets" / sep / sep;
|
|
|
|
fs::current_path(m_datadir);
|
|
m_walletdir_path_cases["relative"] = "wallets";
|
|
|
|
fs::create_directories(m_walletdir_path_cases["default"]);
|
|
fs::create_directories(m_walletdir_path_cases["custom"]);
|
|
fs::create_directories(m_walletdir_path_cases["relative"]);
|
|
std::ofstream f(m_walletdir_path_cases["file"].BOOST_FILESYSTEM_C_STR);
|
|
f.close();
|
|
}
|
|
|
|
InitWalletDirTestingSetup::~InitWalletDirTestingSetup()
|
|
{
|
|
gArgs.LockSettings([&](util::Settings& settings) {
|
|
settings.forced_settings.erase("walletdir");
|
|
});
|
|
fs::current_path(m_cwd);
|
|
}
|
|
|
|
void InitWalletDirTestingSetup::SetWalletDir(const fs::path& walletdir_path)
|
|
{
|
|
gArgs.ForceSetArg("-walletdir", walletdir_path.string());
|
|
}
|