mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-11-12 06:58:57 +01:00
Merge #17593: test: move more utility functions into test utility library
78e283e656[test] move wallet helper functions into test library (Martin Zumsande)f613e5dfda[test] move mining helper functions into test library (Martin Zumsande)2cb4e8bdc7[test] move string helper functions into test library (Martin Zumsande) Pull request description: This disbands `test/util.h` and `test/util.cpp` and moves the content into the test utility library recently created in #17542, so that all test utility functions are in one place. The content of the original files are split into three modules: 1) string helper functions go to `test/util/str` 2) mining helper functions go to the newly created `test/util/mining` 3) wallet helper functions go to the newly created `test/util/wallet` ACKs for top commit: MarcoFalke: ACK78e283e656🔧 Tree-SHA512: f182a61e86e76c32bcb84e37f44904d3a4a9c5a321f7a8efdda5368a6623cb8b5a5384ec4f96e67f0357b0c22099f6e3ecd0ac4cb467e3fa3f3128f8d36edfb8
This commit is contained in:
@@ -39,9 +39,7 @@ bench_bench_bitcoin_SOURCES = \
|
|||||||
bench/bech32.cpp \
|
bench/bech32.cpp \
|
||||||
bench/lockedpool.cpp \
|
bench/lockedpool.cpp \
|
||||||
bench/poly1305.cpp \
|
bench/poly1305.cpp \
|
||||||
bench/prevector.cpp \
|
bench/prevector.cpp
|
||||||
test/util.h \
|
|
||||||
test/util.cpp
|
|
||||||
|
|
||||||
nodist_bench_bench_bitcoin_SOURCES = $(GENERATED_BENCH_FILES)
|
nodist_bench_bench_bitcoin_SOURCES = $(GENERATED_BENCH_FILES)
|
||||||
|
|
||||||
|
|||||||
@@ -10,22 +10,25 @@ EXTRA_LIBRARIES += \
|
|||||||
TEST_UTIL_H = \
|
TEST_UTIL_H = \
|
||||||
test/util/blockfilter.h \
|
test/util/blockfilter.h \
|
||||||
test/util/logging.h \
|
test/util/logging.h \
|
||||||
|
test/util/mining.h \
|
||||||
test/util/setup_common.h \
|
test/util/setup_common.h \
|
||||||
test/util/str.h \
|
test/util/str.h \
|
||||||
test/util/transaction_utils.h
|
test/util/transaction_utils.h \
|
||||||
|
test/util/wallet.h
|
||||||
|
|
||||||
libtest_util_a_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) $(MINIUPNPC_CPPFLAGS) $(EVENT_CFLAGS) $(EVENT_PTHREADS_CFLAGS)
|
libtest_util_a_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) $(MINIUPNPC_CPPFLAGS) $(EVENT_CFLAGS) $(EVENT_PTHREADS_CFLAGS)
|
||||||
libtest_util_a_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
libtest_util_a_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
||||||
libtest_util_a_SOURCES = \
|
libtest_util_a_SOURCES = \
|
||||||
test/util/blockfilter.cpp \
|
test/util/blockfilter.cpp \
|
||||||
test/util/logging.cpp \
|
test/util/logging.cpp \
|
||||||
|
test/util/mining.cpp \
|
||||||
test/util/setup_common.cpp \
|
test/util/setup_common.cpp \
|
||||||
test/util/str.cpp \
|
test/util/str.cpp \
|
||||||
test/util/transaction_utils.cpp \
|
test/util/transaction_utils.cpp \
|
||||||
|
test/util/wallet.cpp \
|
||||||
$(TEST_UTIL_H)
|
$(TEST_UTIL_H)
|
||||||
|
|
||||||
LIBTEST_UTIL += $(LIBBITCOIN_SERVER)
|
LIBTEST_UTIL += $(LIBBITCOIN_SERVER)
|
||||||
LIBTEST_UTIL += $(LIBBITCOIN_COMMON)
|
LIBTEST_UTIL += $(LIBBITCOIN_COMMON)
|
||||||
LIBTEST_UTIL += $(LIBBITCOIN_UTIL)
|
LIBTEST_UTIL += $(LIBBITCOIN_UTIL)
|
||||||
LIBTEST_UTIL += $(LIBBITCOIN_CRYPTO_BASE)
|
LIBTEST_UTIL += $(LIBBITCOIN_CRYPTO_BASE)
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,8 @@
|
|||||||
#include <bench/bench.h>
|
#include <bench/bench.h>
|
||||||
#include <consensus/validation.h>
|
#include <consensus/validation.h>
|
||||||
#include <crypto/sha256.h>
|
#include <crypto/sha256.h>
|
||||||
#include <test/util.h>
|
#include <test/util/mining.h>
|
||||||
|
#include <test/util/wallet.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
#include <validation.h>
|
#include <validation.h>
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,8 @@
|
|||||||
#include <interfaces/chain.h>
|
#include <interfaces/chain.h>
|
||||||
#include <node/context.h>
|
#include <node/context.h>
|
||||||
#include <optional.h>
|
#include <optional.h>
|
||||||
#include <test/util.h>
|
#include <test/util/mining.h>
|
||||||
|
#include <test/util/wallet.h>
|
||||||
#include <validationinterface.h>
|
#include <validationinterface.h>
|
||||||
#include <wallet/wallet.h>
|
#include <wallet/wallet.h>
|
||||||
|
|
||||||
|
|||||||
@@ -4,8 +4,9 @@
|
|||||||
|
|
||||||
#include <util/settings.h>
|
#include <util/settings.h>
|
||||||
|
|
||||||
#include <test/util.h>
|
|
||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
|
#include <test/util/str.h>
|
||||||
|
|
||||||
|
|
||||||
#include <boost/test/unit_test.hpp>
|
#include <boost/test/unit_test.hpp>
|
||||||
#include <univalue.h>
|
#include <univalue.h>
|
||||||
|
|||||||
@@ -1,70 +0,0 @@
|
|||||||
// Copyright (c) 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.
|
|
||||||
|
|
||||||
#ifndef BITCOIN_TEST_UTIL_H
|
|
||||||
#define BITCOIN_TEST_UTIL_H
|
|
||||||
|
|
||||||
#include <memory>
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
class CBlock;
|
|
||||||
class CScript;
|
|
||||||
class CTxIn;
|
|
||||||
class CWallet;
|
|
||||||
|
|
||||||
// Constants //
|
|
||||||
|
|
||||||
extern const std::string ADDRESS_BCRT1_UNSPENDABLE;
|
|
||||||
|
|
||||||
// Lower-level utils //
|
|
||||||
|
|
||||||
/** Returns the generated coin */
|
|
||||||
CTxIn MineBlock(const CScript& coinbase_scriptPubKey);
|
|
||||||
/** Prepare a block to be mined */
|
|
||||||
std::shared_ptr<CBlock> PrepareBlock(const CScript& coinbase_scriptPubKey);
|
|
||||||
|
|
||||||
|
|
||||||
// RPC-like //
|
|
||||||
|
|
||||||
/** Import the address to the wallet */
|
|
||||||
void importaddress(CWallet& wallet, const std::string& address);
|
|
||||||
/** Returns a new address from the wallet */
|
|
||||||
std::string getnewaddress(CWallet& w);
|
|
||||||
/** Returns the generated coin */
|
|
||||||
CTxIn generatetoaddress(const std::string& address);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Increment a string. Useful to enumerate all fixed length strings with
|
|
||||||
* characters in [min_char, max_char].
|
|
||||||
*/
|
|
||||||
template <typename CharType, size_t StringLength>
|
|
||||||
bool NextString(CharType (&string)[StringLength], CharType min_char, CharType max_char)
|
|
||||||
{
|
|
||||||
for (CharType& elem : string) {
|
|
||||||
bool has_next = elem != max_char;
|
|
||||||
elem = elem < min_char || elem >= max_char ? min_char : CharType(elem + 1);
|
|
||||||
if (has_next) return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Iterate over string values and call function for each string without
|
|
||||||
* successive duplicate characters.
|
|
||||||
*/
|
|
||||||
template <typename CharType, size_t StringLength, typename Fn>
|
|
||||||
void ForEachNoDup(CharType (&string)[StringLength], CharType min_char, CharType max_char, Fn&& fn) {
|
|
||||||
for (bool has_next = true; has_next; has_next = NextString(string, min_char, max_char)) {
|
|
||||||
int prev = -1;
|
|
||||||
bool skip_string = false;
|
|
||||||
for (CharType c : string) {
|
|
||||||
if (c == prev) skip_string = true;
|
|
||||||
if (skip_string || c < min_char || c > max_char) break;
|
|
||||||
prev = c;
|
|
||||||
}
|
|
||||||
if (!skip_string) fn();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // BITCOIN_TEST_UTIL_H
|
|
||||||
@@ -2,48 +2,15 @@
|
|||||||
// Distributed under the MIT software license, see the accompanying
|
// Distributed under the MIT software license, see the accompanying
|
||||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
#include <test/util.h>
|
#include <test/util/mining.h>
|
||||||
|
|
||||||
#include <chainparams.h>
|
#include <chainparams.h>
|
||||||
#include <consensus/merkle.h>
|
#include <consensus/merkle.h>
|
||||||
#include <key_io.h>
|
#include <key_io.h>
|
||||||
#include <miner.h>
|
#include <miner.h>
|
||||||
#include <outputtype.h>
|
|
||||||
#include <pow.h>
|
#include <pow.h>
|
||||||
#include <script/standard.h>
|
#include <script/standard.h>
|
||||||
#include <validation.h>
|
#include <validation.h>
|
||||||
#include <validationinterface.h>
|
|
||||||
#ifdef ENABLE_WALLET
|
|
||||||
#include <wallet/wallet.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const std::string ADDRESS_BCRT1_UNSPENDABLE = "bcrt1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq3xueyj";
|
|
||||||
|
|
||||||
#ifdef ENABLE_WALLET
|
|
||||||
std::string getnewaddress(CWallet& w)
|
|
||||||
{
|
|
||||||
constexpr auto output_type = OutputType::BECH32;
|
|
||||||
CTxDestination dest;
|
|
||||||
std::string error;
|
|
||||||
if (!w.GetNewDestination(output_type, "", dest, error)) assert(false);
|
|
||||||
|
|
||||||
return EncodeDestination(dest);
|
|
||||||
}
|
|
||||||
|
|
||||||
void importaddress(CWallet& wallet, const std::string& address)
|
|
||||||
{
|
|
||||||
auto spk_man = wallet.GetLegacyScriptPubKeyMan();
|
|
||||||
LOCK(wallet.cs_wallet);
|
|
||||||
AssertLockHeld(spk_man->cs_wallet);
|
|
||||||
const auto dest = DecodeDestination(address);
|
|
||||||
assert(IsValidDestination(dest));
|
|
||||||
const auto script = GetScriptForDestination(dest);
|
|
||||||
wallet.MarkDirty();
|
|
||||||
assert(!spk_man->HaveWatchOnly(script));
|
|
||||||
if (!spk_man->AddWatchOnly(script, 0 /* nCreateTime */)) assert(false);
|
|
||||||
wallet.SetAddressBook(dest, /* label */ "", "receive");
|
|
||||||
}
|
|
||||||
#endif // ENABLE_WALLET
|
|
||||||
|
|
||||||
CTxIn generatetoaddress(const std::string& address)
|
CTxIn generatetoaddress(const std::string& address)
|
||||||
{
|
{
|
||||||
24
src/test/util/mining.h
Normal file
24
src/test/util/mining.h
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
// Copyright (c) 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.
|
||||||
|
|
||||||
|
#ifndef BITCOIN_TEST_UTIL_MINING_H
|
||||||
|
#define BITCOIN_TEST_UTIL_MINING_H
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
class CBlock;
|
||||||
|
class CScript;
|
||||||
|
class CTxIn;
|
||||||
|
|
||||||
|
/** Returns the generated coin */
|
||||||
|
CTxIn MineBlock(const CScript& coinbase_scriptPubKey);
|
||||||
|
|
||||||
|
/** Prepare a block to be mined */
|
||||||
|
std::shared_ptr<CBlock> PrepareBlock(const CScript& coinbase_scriptPubKey);
|
||||||
|
|
||||||
|
/** RPC-like helper function, returns the generated coin */
|
||||||
|
CTxIn generatetoaddress(const std::string& address);
|
||||||
|
|
||||||
|
#endif // BITCOIN_TEST_UTIL_MINING_H
|
||||||
@@ -9,4 +9,37 @@
|
|||||||
|
|
||||||
bool CaseInsensitiveEqual(const std::string& s1, const std::string& s2);
|
bool CaseInsensitiveEqual(const std::string& s1, const std::string& s2);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Increment a string. Useful to enumerate all fixed length strings with
|
||||||
|
* characters in [min_char, max_char].
|
||||||
|
*/
|
||||||
|
template <typename CharType, size_t StringLength>
|
||||||
|
bool NextString(CharType (&string)[StringLength], CharType min_char, CharType max_char)
|
||||||
|
{
|
||||||
|
for (CharType& elem : string) {
|
||||||
|
bool has_next = elem != max_char;
|
||||||
|
elem = elem < min_char || elem >= max_char ? min_char : CharType(elem + 1);
|
||||||
|
if (has_next) return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Iterate over string values and call function for each string without
|
||||||
|
* successive duplicate characters.
|
||||||
|
*/
|
||||||
|
template <typename CharType, size_t StringLength, typename Fn>
|
||||||
|
void ForEachNoDup(CharType (&string)[StringLength], CharType min_char, CharType max_char, Fn&& fn) {
|
||||||
|
for (bool has_next = true; has_next; has_next = NextString(string, min_char, max_char)) {
|
||||||
|
int prev = -1;
|
||||||
|
bool skip_string = false;
|
||||||
|
for (CharType c : string) {
|
||||||
|
if (c == prev) skip_string = true;
|
||||||
|
if (skip_string || c < min_char || c > max_char) break;
|
||||||
|
prev = c;
|
||||||
|
}
|
||||||
|
if (!skip_string) fn();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endif // BITCOIN_TEST_UTIL_STR_H
|
#endif // BITCOIN_TEST_UTIL_STR_H
|
||||||
|
|||||||
40
src/test/util/wallet.cpp
Normal file
40
src/test/util/wallet.cpp
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (c) 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 <test/util/wallet.h>
|
||||||
|
|
||||||
|
#include <key_io.h>
|
||||||
|
#include <outputtype.h>
|
||||||
|
#include <script/standard.h>
|
||||||
|
#ifdef ENABLE_WALLET
|
||||||
|
#include <wallet/wallet.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const std::string ADDRESS_BCRT1_UNSPENDABLE = "bcrt1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq3xueyj";
|
||||||
|
|
||||||
|
#ifdef ENABLE_WALLET
|
||||||
|
std::string getnewaddress(CWallet& w)
|
||||||
|
{
|
||||||
|
constexpr auto output_type = OutputType::BECH32;
|
||||||
|
CTxDestination dest;
|
||||||
|
std::string error;
|
||||||
|
if (!w.GetNewDestination(output_type, "", dest, error)) assert(false);
|
||||||
|
|
||||||
|
return EncodeDestination(dest);
|
||||||
|
}
|
||||||
|
|
||||||
|
void importaddress(CWallet& wallet, const std::string& address)
|
||||||
|
{
|
||||||
|
auto spk_man = wallet.GetLegacyScriptPubKeyMan();
|
||||||
|
LOCK(wallet.cs_wallet);
|
||||||
|
AssertLockHeld(spk_man->cs_wallet);
|
||||||
|
const auto dest = DecodeDestination(address);
|
||||||
|
assert(IsValidDestination(dest));
|
||||||
|
const auto script = GetScriptForDestination(dest);
|
||||||
|
wallet.MarkDirty();
|
||||||
|
assert(!spk_man->HaveWatchOnly(script));
|
||||||
|
if (!spk_man->AddWatchOnly(script, 0 /* nCreateTime */)) assert(false);
|
||||||
|
wallet.SetAddressBook(dest, /* label */ "", "receive");
|
||||||
|
}
|
||||||
|
#endif // ENABLE_WALLET
|
||||||
24
src/test/util/wallet.h
Normal file
24
src/test/util/wallet.h
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
// Copyright (c) 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.
|
||||||
|
|
||||||
|
#ifndef BITCOIN_TEST_UTIL_WALLET_H
|
||||||
|
#define BITCOIN_TEST_UTIL_WALLET_H
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
class CWallet;
|
||||||
|
|
||||||
|
// Constants //
|
||||||
|
|
||||||
|
extern const std::string ADDRESS_BCRT1_UNSPENDABLE;
|
||||||
|
|
||||||
|
// RPC-like //
|
||||||
|
|
||||||
|
/** Import the address to the wallet */
|
||||||
|
void importaddress(CWallet& wallet, const std::string& address);
|
||||||
|
/** Returns a new address from the wallet */
|
||||||
|
std::string getnewaddress(CWallet& w);
|
||||||
|
|
||||||
|
|
||||||
|
#endif // BITCOIN_TEST_UTIL_WALLET_H
|
||||||
@@ -7,7 +7,7 @@
|
|||||||
#include <clientversion.h>
|
#include <clientversion.h>
|
||||||
#include <sync.h>
|
#include <sync.h>
|
||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
#include <test/util.h>
|
#include <test/util/str.h>
|
||||||
#include <util/moneystr.h>
|
#include <util/moneystr.h>
|
||||||
#include <util/strencodings.h>
|
#include <util/strencodings.h>
|
||||||
#include <util/string.h>
|
#include <util/string.h>
|
||||||
|
|||||||
Reference in New Issue
Block a user