Bitcoin Core 28.99.0
P2P Digital Currency
block_assemble.cpp
Go to the documentation of this file.
1// Copyright (c) 2011-2022 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#include <bench/bench.h>
7#include <node/miner.h>
9#include <random.h>
10#include <script/script.h>
11#include <sync.h>
12#include <test/util/mining.h>
13#include <test/util/script.h>
15#include <validation.h>
16
17#include <array>
18#include <cassert>
19#include <cstddef>
20#include <memory>
21#include <vector>
22
24
26{
27 const auto test_setup = MakeNoLogFileContext<const TestingSetup>();
28
29 CScriptWitness witness;
30 witness.stack.push_back(WITNESS_STACK_ELEM_OP_TRUE);
31 BlockAssembler::Options options;
32 options.coinbase_output_script = P2WSH_OP_TRUE;
33
34 // Collect some loose transactions that spend the coinbases of our mined blocks
35 constexpr size_t NUM_BLOCKS{200};
36 std::array<CTransactionRef, NUM_BLOCKS - COINBASE_MATURITY + 1> txs;
37 for (size_t b{0}; b < NUM_BLOCKS; ++b) {
39 tx.vin.emplace_back(MineBlock(test_setup->m_node, options));
40 tx.vin.back().scriptWitness = witness;
41 tx.vout.emplace_back(1337, P2WSH_OP_TRUE);
42 if (NUM_BLOCKS - b >= COINBASE_MATURITY)
43 txs.at(b) = MakeTransactionRef(tx);
44 }
45 {
47
48 for (const auto& txr : txs) {
49 const MempoolAcceptResult res = test_setup->m_node.chainman->ProcessTransaction(txr);
51 }
52 }
53
54 bench.run([&] {
55 PrepareBlock(test_setup->m_node, options);
56 });
57}
59{
60 FastRandomContext det_rand{true};
61 auto testing_setup{MakeNoLogFileContext<TestChain100Setup>()};
62 testing_setup->PopulateMempool(det_rand, /*num_transactions=*/1000, /*submit=*/true);
63 BlockAssembler::Options assembler_options;
64 assembler_options.test_block_validity = false;
65 assembler_options.coinbase_output_script = P2WSH_OP_TRUE;
66
67 bench.run([&] {
68 PrepareBlock(testing_setup->m_node, assembler_options);
69 });
70}
71
static void AssembleBlock(benchmark::Bench &bench)
static void BlockAssemblerAddPackageTxns(benchmark::Bench &bench)
BENCHMARK(AssembleBlock, benchmark::PriorityLevel::HIGH)
Fast randomness source.
Definition: random.h:377
Main entry point to nanobench's benchmarking facility.
Definition: nanobench.h:627
Bench & run(char const *benchmarkName, Op &&op)
Repeatedly calls op() based on the configuration, and performs measurements.
Definition: nanobench.h:1234
Generate a new block, without valid proof-of-work.
Definition: miner.h:144
static const int COINBASE_MATURITY
Coinbase transaction outputs can only be spent after this number of new blocks (network rule)
Definition: consensus.h:19
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition: cs_main.cpp:8
@ HIGH
Definition: bench.h:48
@ LOW
Definition: bench.h:47
static CTransactionRef MakeTransactionRef(Tx &&txIn)
Definition: transaction.h:424
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:423
A mutable version of CTransaction.
Definition: transaction.h:378
std::vector< CTxOut > vout
Definition: transaction.h:380
std::vector< CTxIn > vin
Definition: transaction.h:379
std::vector< std::vector< unsigned char > > stack
Definition: script.h:588
Validation result for a transaction evaluated by MemPoolAccept (single or package).
Definition: validation.h:123
const ResultType m_result_type
Result type.
Definition: validation.h:132
#define LOCK(cs)
Definition: sync.h:257
std::shared_ptr< CBlock > PrepareBlock(const NodeContext &node, const BlockAssembler::Options &assembler_options)
Definition: mining.cpp:112
COutPoint MineBlock(const NodeContext &node, const node::BlockAssembler::Options &assembler_options)
Returns the generated coin.
Definition: mining.cpp:64
static const std::vector< uint8_t > WITNESS_STACK_ELEM_OP_TRUE
Definition: script.h:11
static const CScript P2WSH_OP_TRUE
Definition: script.h:12
assert(!tx.IsCoinBase())