mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 20:03:34 -03:00
create and use mempool transactions using real coins in MempoolCheck
This commit is contained in:
parent
2118750631
commit
aecc332a71
1 changed files with 5 additions and 6 deletions
|
@ -102,16 +102,15 @@ static void ComplexMemPool(benchmark::Bench& bench)
|
||||||
static void MempoolCheck(benchmark::Bench& bench)
|
static void MempoolCheck(benchmark::Bench& bench)
|
||||||
{
|
{
|
||||||
FastRandomContext det_rand{true};
|
FastRandomContext det_rand{true};
|
||||||
const int childTxs = bench.complexityN() > 1 ? static_cast<int>(bench.complexityN()) : 2000;
|
auto testing_setup = MakeNoLogFileContext<TestChain100Setup>(CBaseChainParams::REGTEST, {"-checkmempool=1"});
|
||||||
const std::vector<CTransactionRef> ordered_coins = CreateOrderedCoins(det_rand, childTxs, /*min_ancestors=*/5);
|
CTxMemPool& pool = *testing_setup.get()->m_node.mempool;
|
||||||
const auto testing_setup = MakeNoLogFileContext<const TestingSetup>(CBaseChainParams::MAIN, {"-checkmempool=1"});
|
|
||||||
CTxMemPool pool;
|
|
||||||
LOCK2(cs_main, pool.cs);
|
LOCK2(cs_main, pool.cs);
|
||||||
|
testing_setup->PopulateMempool(det_rand, 400, true);
|
||||||
const CCoinsViewCache& coins_tip = testing_setup.get()->m_node.chainman->ActiveChainstate().CoinsTip();
|
const CCoinsViewCache& coins_tip = testing_setup.get()->m_node.chainman->ActiveChainstate().CoinsTip();
|
||||||
for (auto& tx : ordered_coins) AddTx(tx, pool);
|
|
||||||
|
|
||||||
bench.run([&]() NO_THREAD_SAFETY_ANALYSIS {
|
bench.run([&]() NO_THREAD_SAFETY_ANALYSIS {
|
||||||
pool.check(coins_tip, /*spendheight=*/2);
|
// Bump up the spendheight so we don't hit premature coinbase spend errors.
|
||||||
|
pool.check(coins_tip, /*spendheight=*/300);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue