mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-28 03:57:31 -03:00
e4f4350471
Add WalletClient interface so node interface is cleaner and don't need wallet-specific methods. The new NodeContext::wallet_client pointer will also be needed to eliminate global wallet variables like ::vpwallets, because createWallet(), loadWallet(), getWallets(), etc methods called by the GUI need a way to get a reference to the list of open wallets if it is no longer a global variable. Also tweaks splash screen registration for load wallet events to be delayed until after wallet client is created.
85 lines
2.7 KiB
C++
85 lines
2.7 KiB
C++
// Copyright (c) 2018-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 <boost/test/unit_test.hpp>
|
|
|
|
#include <noui.h>
|
|
#include <test/util/logging.h>
|
|
#include <test/util/setup_common.h>
|
|
#include <util/system.h>
|
|
#include <wallet/test/init_test_fixture.h>
|
|
|
|
BOOST_FIXTURE_TEST_SUITE(init_tests, InitWalletDirTestingSetup)
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_default)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["default"]);
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == true);
|
|
fs::path walletdir = gArgs.GetArg("-walletdir", "");
|
|
fs::path expected_path = fs::canonical(m_walletdir_path_cases["default"]);
|
|
BOOST_CHECK(walletdir == expected_path);
|
|
}
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_custom)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["custom"]);
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == true);
|
|
fs::path walletdir = gArgs.GetArg("-walletdir", "");
|
|
fs::path expected_path = fs::canonical(m_walletdir_path_cases["custom"]);
|
|
BOOST_CHECK(walletdir == expected_path);
|
|
}
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_does_not_exist)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["nonexistent"]);
|
|
{
|
|
ASSERT_DEBUG_LOG("does not exist");
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == false);
|
|
}
|
|
}
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_is_not_directory)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["file"]);
|
|
{
|
|
ASSERT_DEBUG_LOG("is not a directory");
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == false);
|
|
}
|
|
}
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_is_not_relative)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["relative"]);
|
|
{
|
|
ASSERT_DEBUG_LOG("is a relative path");
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == false);
|
|
}
|
|
}
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_no_trailing)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["trailing"]);
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == true);
|
|
fs::path walletdir = gArgs.GetArg("-walletdir", "");
|
|
fs::path expected_path = fs::canonical(m_walletdir_path_cases["default"]);
|
|
BOOST_CHECK(walletdir == expected_path);
|
|
}
|
|
|
|
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_no_trailing2)
|
|
{
|
|
SetWalletDir(m_walletdir_path_cases["trailing2"]);
|
|
bool result = m_wallet_client->verify();
|
|
BOOST_CHECK(result == true);
|
|
fs::path walletdir = gArgs.GetArg("-walletdir", "");
|
|
fs::path expected_path = fs::canonical(m_walletdir_path_cases["default"]);
|
|
BOOST_CHECK(walletdir == expected_path);
|
|
}
|
|
|
|
BOOST_AUTO_TEST_SUITE_END()
|