mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-08 10:31:50 -05:00
bench: add readblock benchmark
This commit is contained in:
parent
5f9fd11680
commit
1c4b9cbe90
2 changed files with 54 additions and 0 deletions
|
@ -46,6 +46,7 @@ bench_bench_bitcoin_SOURCES = \
|
||||||
bench/poly1305.cpp \
|
bench/poly1305.cpp \
|
||||||
bench/pool.cpp \
|
bench/pool.cpp \
|
||||||
bench/prevector.cpp \
|
bench/prevector.cpp \
|
||||||
|
bench/readblock.cpp \
|
||||||
bench/rollingbloom.cpp \
|
bench/rollingbloom.cpp \
|
||||||
bench/rpc_blockchain.cpp \
|
bench/rpc_blockchain.cpp \
|
||||||
bench/rpc_mempool.cpp \
|
bench/rpc_mempool.cpp \
|
||||||
|
|
53
src/bench/readblock.cpp
Normal file
53
src/bench/readblock.cpp
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
// Copyright (c) 2023 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 <bench/bench.h>
|
||||||
|
#include <bench/data.h>
|
||||||
|
|
||||||
|
#include <consensus/validation.h>
|
||||||
|
#include <node/blockstorage.h>
|
||||||
|
#include <streams.h>
|
||||||
|
#include <test/util/setup_common.h>
|
||||||
|
#include <util/chaintype.h>
|
||||||
|
#include <validation.h>
|
||||||
|
|
||||||
|
static FlatFilePos WriteBlockToDisk(ChainstateManager& chainman)
|
||||||
|
{
|
||||||
|
DataStream stream{benchmark::data::block413567};
|
||||||
|
CBlock block;
|
||||||
|
stream >> TX_WITH_WITNESS(block);
|
||||||
|
|
||||||
|
return chainman.m_blockman.SaveBlockToDisk(block, 0, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ReadBlockFromDiskTest(benchmark::Bench& bench)
|
||||||
|
{
|
||||||
|
const auto testing_setup{MakeNoLogFileContext<const TestingSetup>(ChainType::MAIN)};
|
||||||
|
ChainstateManager& chainman{*testing_setup->m_node.chainman};
|
||||||
|
|
||||||
|
CBlock block;
|
||||||
|
const auto pos{WriteBlockToDisk(chainman)};
|
||||||
|
|
||||||
|
bench.run([&] {
|
||||||
|
const auto success{chainman.m_blockman.ReadBlockFromDisk(block, pos)};
|
||||||
|
assert(success);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ReadRawBlockFromDiskTest(benchmark::Bench& bench)
|
||||||
|
{
|
||||||
|
const auto testing_setup{MakeNoLogFileContext<const TestingSetup>(ChainType::MAIN)};
|
||||||
|
ChainstateManager& chainman{*testing_setup->m_node.chainman};
|
||||||
|
|
||||||
|
std::vector<uint8_t> block_data;
|
||||||
|
const auto pos{WriteBlockToDisk(chainman)};
|
||||||
|
|
||||||
|
bench.run([&] {
|
||||||
|
const auto success{chainman.m_blockman.ReadRawBlockFromDisk(block_data, pos)};
|
||||||
|
assert(success);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
BENCHMARK(ReadBlockFromDiskTest, benchmark::PriorityLevel::HIGH);
|
||||||
|
BENCHMARK(ReadRawBlockFromDiskTest, benchmark::PriorityLevel::HIGH);
|
Loading…
Add table
Reference in a new issue