mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-13 14:24:33 +00:00
e7c6bba63d
Some checks are pending
Audit / audit (push) Waiting to run
CI / fmt (push) Waiting to run
CI / typo (push) Waiting to run
CI / ci (macos-latest, stable, bash) (push) Waiting to run
CI / ci (ubuntu-latest, stable, bash) (push) Waiting to run
CI / ci (windows-latest, stable-x86_64-pc-windows-gnu, msys2 {0}) (push) Waiting to run
Deny / audit (push) Waiting to run
Doc / build (push) Waiting to run
Doc / deploy (push) Blocked by required conditions
* Split `BlockBlobs` database table + misc fixes - Split the `BlockBlobs` database table into two new tables: `BlockHeaderBlobs` and `BlockTxsHashes`. - `add_block`, `pop_block` and `get_block_extended_header` have been edited consequently. - `VerifiedBlockInformation` now have a `mining_tx_index: u64` field. - Made `cuprate-helper`'s `thread` feature a dependency of the `service` feature - Edited service test mapping of output. It is now a full iterator. * fix fmt * Update storage/blockchain/src/types.rs Co-authored-by: Boog900 <boog900@tutanota.com> * Update storage/blockchain/src/ops/block.rs Co-authored-by: Boog900 <boog900@tutanota.com> * fix warning --------- Co-authored-by: Boog900 <boog900@tutanota.com>
110 lines
4.1 KiB
Rust
110 lines
4.1 KiB
Rust
//! Utilities for `cuprate_blockchain` testing.
|
|
//!
|
|
//! These types/fn's are only:
|
|
//! - enabled on #[cfg(test)]
|
|
//! - only used internally
|
|
|
|
//---------------------------------------------------------------------------------------------------- Import
|
|
use std::{borrow::Cow, fmt::Debug};
|
|
|
|
use pretty_assertions::assert_eq;
|
|
|
|
use cuprate_database::{DatabaseRo, Env, EnvInner};
|
|
use cuprate_types::{AltBlockInformation, ChainId, VerifiedBlockInformation};
|
|
|
|
use crate::{
|
|
config::ConfigBuilder,
|
|
tables::{OpenTables, Tables},
|
|
};
|
|
|
|
//---------------------------------------------------------------------------------------------------- Struct
|
|
/// Named struct to assert the length of all tables.
|
|
///
|
|
/// This is a struct with fields instead of a function
|
|
/// so that callers can name arguments, otherwise the call-site
|
|
/// is a little confusing, i.e. `assert_table_len(0, 25, 1, 123)`.
|
|
#[derive(Copy, Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
|
pub(crate) struct AssertTableLen {
|
|
pub(crate) block_infos: u64,
|
|
pub(crate) block_header_blobs: u64,
|
|
pub(crate) block_txs_hashes: u64,
|
|
pub(crate) block_heights: u64,
|
|
pub(crate) key_images: u64,
|
|
pub(crate) num_outputs: u64,
|
|
pub(crate) pruned_tx_blobs: u64,
|
|
pub(crate) prunable_hashes: u64,
|
|
pub(crate) outputs: u64,
|
|
pub(crate) prunable_tx_blobs: u64,
|
|
pub(crate) rct_outputs: u64,
|
|
pub(crate) tx_blobs: u64,
|
|
pub(crate) tx_ids: u64,
|
|
pub(crate) tx_heights: u64,
|
|
pub(crate) tx_unlock_time: u64,
|
|
}
|
|
|
|
impl AssertTableLen {
|
|
/// Assert the length of all tables.
|
|
pub(crate) fn assert(self, tables: &impl Tables) {
|
|
let other = Self {
|
|
block_infos: tables.block_infos().len().unwrap(),
|
|
block_header_blobs: tables.block_header_blobs().len().unwrap(),
|
|
block_txs_hashes: tables.block_txs_hashes().len().unwrap(),
|
|
block_heights: tables.block_heights().len().unwrap(),
|
|
key_images: tables.key_images().len().unwrap(),
|
|
num_outputs: tables.num_outputs().len().unwrap(),
|
|
pruned_tx_blobs: tables.pruned_tx_blobs().len().unwrap(),
|
|
prunable_hashes: tables.prunable_hashes().len().unwrap(),
|
|
outputs: tables.outputs().len().unwrap(),
|
|
prunable_tx_blobs: tables.prunable_tx_blobs().len().unwrap(),
|
|
rct_outputs: tables.rct_outputs().len().unwrap(),
|
|
tx_blobs: tables.tx_blobs().len().unwrap(),
|
|
tx_ids: tables.tx_ids().len().unwrap(),
|
|
tx_heights: tables.tx_heights().len().unwrap(),
|
|
tx_unlock_time: tables.tx_unlock_time().len().unwrap(),
|
|
};
|
|
|
|
assert_eq!(self, other);
|
|
}
|
|
}
|
|
|
|
//---------------------------------------------------------------------------------------------------- fn
|
|
/// Create an `Env` in a temporarily directory.
|
|
/// The directory is automatically removed after the `TempDir` is dropped.
|
|
///
|
|
pub(crate) fn tmp_concrete_env() -> (impl Env, tempfile::TempDir) {
|
|
let tempdir = tempfile::tempdir().unwrap();
|
|
let config = ConfigBuilder::new()
|
|
.db_directory(Cow::Owned(tempdir.path().into()))
|
|
.low_power()
|
|
.build();
|
|
let env = crate::open(config).unwrap();
|
|
|
|
(env, tempdir)
|
|
}
|
|
|
|
/// Assert all the tables in the environment are empty.
|
|
pub(crate) fn assert_all_tables_are_empty(env: &impl Env) {
|
|
let env_inner = env.env_inner();
|
|
let tx_ro = env_inner.tx_ro().unwrap();
|
|
let tables = env_inner.open_tables(&tx_ro).unwrap();
|
|
assert!(tables.all_tables_empty().unwrap());
|
|
assert_eq!(crate::ops::tx::get_num_tx(tables.tx_ids()).unwrap(), 0);
|
|
}
|
|
|
|
pub(crate) fn map_verified_block_to_alt(
|
|
verified_block: VerifiedBlockInformation,
|
|
chain_id: ChainId,
|
|
) -> AltBlockInformation {
|
|
AltBlockInformation {
|
|
block: verified_block.block,
|
|
block_blob: verified_block.block_blob,
|
|
txs: verified_block.txs,
|
|
block_hash: verified_block.block_hash,
|
|
pow_hash: verified_block.pow_hash,
|
|
height: verified_block.height,
|
|
weight: verified_block.weight,
|
|
long_term_weight: verified_block.long_term_weight,
|
|
cumulative_difficulty: verified_block.cumulative_difficulty,
|
|
chain_id,
|
|
}
|
|
}
|