Skip to content

Commit

Permalink
fix: replace u64 with usize internally
Browse files Browse the repository at this point in the history
Signed-off-by: Marin Veršić <[email protected]>
  • Loading branch information
mversic committed Jun 3, 2024
1 parent 9c58203 commit 950785c
Show file tree
Hide file tree
Showing 17 changed files with 169 additions and 131 deletions.
9 changes: 7 additions & 2 deletions client/tests/integration/events/pipeline.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
use std::thread::{self, JoinHandle};
use std::{
num::NonZeroUsize,
thread::{self, JoinHandle},
};

use eyre::Result;
use iroha::{
Expand Down Expand Up @@ -129,6 +132,8 @@ fn applied_block_must_be_available_in_kura() {
.as_ref()
.expect("Must be some")
.kura()
.get_block_by_height(event.header().height())
.get_block_by_height(
NonZeroUsize::new(event.header().height().try_into().unwrap()).unwrap(),
)
.expect("Block applied event was received earlier");
}
22 changes: 14 additions & 8 deletions core/src/block.rs
Original file line number Diff line number Diff line change
Expand Up @@ -48,9 +48,9 @@ pub enum BlockValidationError {
/// Mismatch between the actual and expected height of the latest block. Expected: {expected}, actual: {actual}
LatestBlockHeightMismatch {
/// Expected value
expected: u64,
expected: usize,
/// Actual value
actual: u64,
actual: usize,
},
/// Mismatch between the actual and expected hashes of the current block. Expected: {expected:?}, actual: {actual:?}
IncorrectHash {
Expand Down Expand Up @@ -145,13 +145,13 @@ mod pending {
}

fn make_header(
previous_height: u64,
previous_height: usize,
prev_block_hash: Option<HashOf<SignedBlock>>,
view_change_index: u64,
view_change_index: usize,
transactions: &[CommittedTransaction],
) -> BlockHeader {
BlockHeader {
height: previous_height + 1,
height: (previous_height + 1) as u64,
previous_block_hash: prev_block_hash,
transactions_hash: transactions
.iter()
Expand All @@ -164,7 +164,9 @@ mod pending {
.as_millis()
.try_into()
.expect("Time should fit into u64"),
view_change_index,
view_change_index: view_change_index
.try_into()
.expect("View change index should fit into u32"),
consensus_estimation_ms: DEFAULT_CONSENSUS_ESTIMATION
.as_millis()
.try_into()
Expand Down Expand Up @@ -205,7 +207,7 @@ mod pending {
/// Upon executing this method current timestamp is stored in the block header.
pub fn chain(
self,
view_change_index: u64,
view_change_index: usize,
state: &mut StateBlock<'_>,
) -> BlockBuilder<Chained> {
let transactions = Self::categorize_transactions(self.0.transactions, state);
Expand Down Expand Up @@ -273,7 +275,11 @@ mod valid {
state_block: &mut StateBlock<'_>,
) -> WithEvents<Result<ValidBlock, (SignedBlock, BlockValidationError)>> {
let expected_block_height = state_block.height() + 1;
let actual_height = block.header().height;
let actual_height = block
.header()
.height
.try_into()
.expect("Block height should fit into usize");

if expected_block_height != actual_height {
return WithEvents::new(Err((
Expand Down
15 changes: 10 additions & 5 deletions core/src/block_sync.rs
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,8 @@ impl BlockSynchronizer {

pub mod message {
//! Module containing messages for [`BlockSynchronizer`](super::BlockSynchronizer).
use std::num::NonZeroUsize;

use super::*;

/// Get blocks after some block
Expand Down Expand Up @@ -204,14 +206,17 @@ pub mod message {
error!(?prev_hash, "Block hash not found");
return;
}
Some(height) => height + 1, // It's get blocks *after*, so we add 1.
Some(height) => height.saturating_add(1), // It's get blocks *after*, so we add 1.
},
None => 1,
None => nonzero_ext::nonzero!(1_usize),
};

let blocks = (start_height..)
.take(1 + block_sync.gossip_max_size.get() as usize)
.map_while(|height| block_sync.kura.get_block_by_height(height))
let blocks = (start_height.get()..)
.take(block_sync.gossip_max_size.get() as usize + 1)
.map_while(|height| {
NonZeroUsize::new(height)
.and_then(|height| block_sync.kura.get_block_by_height(height))
})
.skip_while(|block| Some(block.hash()) == *latest_hash)
.map(|block| (*block).clone())
.collect::<Vec<_>>();
Expand Down
44 changes: 23 additions & 21 deletions core/src/kura.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ use std::{
fmt::Debug,
fs,
io::{BufWriter, Read, Seek, SeekFrom, Write},
num::NonZeroUsize,
path::{Path, PathBuf},
sync::Arc,
};
Expand Down Expand Up @@ -273,45 +274,46 @@ impl Kura {
}

/// Get the hash of the block at the provided height.
pub fn get_block_hash(&self, block_height: u64) -> Option<HashOf<SignedBlock>> {
pub fn get_block_hash(&self, block_height: NonZeroUsize) -> Option<HashOf<SignedBlock>> {
let hash_data_guard = self.block_data.lock();
if block_height == 0 || block_height > hash_data_guard.len() as u64 {

let block_height = block_height.get();
if hash_data_guard.len() < block_height {
return None;
}
let index: usize = (block_height - 1)
.try_into()
.expect("block_height fits in 32 bits or we are running on a 64 bit machine");
Some(hash_data_guard[index].0)

let block_index = block_height - 1;
Some(hash_data_guard[block_index].0)
}

/// Search through blocks for the height of the block with the given hash.
pub fn get_block_height_by_hash(&self, hash: &HashOf<SignedBlock>) -> Option<u64> {
pub fn get_block_height_by_hash(&self, hash: &HashOf<SignedBlock>) -> Option<NonZeroUsize> {
self.block_data
.lock()
.iter()
.position(|(block_hash, _block_arc)| block_hash == hash)
.map(|index| index as u64 + 1)
.and_then(NonZeroUsize::new)
.and_then(|index| index.checked_add(1))
}

/// Get a reference to block by height, loading it from disk if needed.
// The below lint suggests changing the code into something that does not compile due
// to the borrow checker.
pub fn get_block_by_height(&self, block_height: u64) -> Option<Arc<SignedBlock>> {
pub fn get_block_by_height(&self, block_height: NonZeroUsize) -> Option<Arc<SignedBlock>> {
let mut data_array_guard = self.block_data.lock();
if block_height == 0 || block_height > data_array_guard.len() as u64 {

if data_array_guard.len() < block_height.get() {
return None;
}
let block_number: usize = (block_height - 1)
.try_into()
.expect("Failed to cast to u32.");

if let Some(block_arc) = data_array_guard[block_number].1.as_ref() {
let block_index = block_height.get() - 1;
if let Some(block_arc) = data_array_guard[block_index].1.as_ref() {
return Some(Arc::clone(block_arc));
};

let block_store = self.block_store.lock();
let BlockIndex { start, length } = block_store
.read_block_index(block_number as u64)
.read_block_index(block_index as u64)
.expect("Failed to read block index from disk.");

let mut block_buf =
Expand All @@ -322,7 +324,7 @@ impl Kura {
let block = SignedBlock::decode_all_versioned(&block_buf).expect("Failed to decode block");

let block_arc = Arc::new(block);
data_array_guard[block_number].1 = Some(Arc::clone(&block_arc));
data_array_guard[block_index].1 = Some(Arc::clone(&block_arc));
Some(block_arc)
}

Expand All @@ -332,13 +334,13 @@ impl Kura {
/// then calls `get_block_by_height`. If you know the height of the block,
/// call `get_block_by_height` directly.
pub fn get_block_by_hash(&self, block_hash: &HashOf<SignedBlock>) -> Option<Arc<SignedBlock>> {
let index = self
.block_data
self.block_data
.lock()
.iter()
.position(|(hash, _arc)| hash == block_hash);

index.and_then(|index| self.get_block_by_height(index as u64 + 1))
.position(|(hash, _arc)| hash == block_hash)
.and_then(NonZeroUsize::new)
.and_then(|index| index.checked_add(1))
.and_then(|index| self.get_block_by_height(index))
}

/// Put a block in kura's in memory block store.
Expand Down
22 changes: 10 additions & 12 deletions core/src/metrics.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
//! Metrics and status reporting
use std::{sync::Arc, time::SystemTime};
use std::{num::NonZeroUsize, sync::Arc, time::SystemTime};

use eyre::{Result, WrapErr as _};
use iroha_telemetry::metrics::Metrics;
Expand All @@ -23,7 +23,7 @@ pub struct MetricsReporter {
queue: Arc<Queue>,
metrics: Metrics,
/// Latest observed and processed height by metrics reporter
latest_block_height: Arc<Mutex<u64>>,
latest_block_height: Arc<Mutex<usize>>,
}

impl MetricsReporter {
Expand Down Expand Up @@ -53,14 +53,10 @@ impl MetricsReporter {
/// - If either mutex is poisoned
#[allow(clippy::cast_precision_loss)]
pub fn update_metrics(&self) -> Result<()> {
let online_peers_count: u64 = self
.network
.online_peers(
#[allow(clippy::disallowed_types)]
std::collections::HashSet::len,
)
.try_into()
.expect("casting usize to u64");
let online_peers_count: usize = self.network.online_peers(
#[allow(clippy::disallowed_types)]
std::collections::HashSet::len,
);

let state_view = self.state.view();

Expand All @@ -70,7 +66,9 @@ impl MetricsReporter {
{
let mut block_index = start_index;
while block_index < state_view.height() {
let Some(block) = self.kura.get_block_by_height(block_index + 1) else {
let Some(block) = NonZeroUsize::new(block_index)
.and_then(|index| self.kura.get_block_by_height(index.saturating_add(1)))
else {
break;
};
block_index += 1;
Expand Down Expand Up @@ -126,7 +124,7 @@ impl MetricsReporter {
)
};

self.metrics.connected_peers.set(online_peers_count);
self.metrics.connected_peers.set(online_peers_count as u64);

self.metrics
.domains
Expand Down
5 changes: 5 additions & 0 deletions core/src/smartcontracts/isi/query.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,11 @@ impl LazyQueryOutput<'_> {
/// - sorting
/// - pagination
/// - batching
///
/// # Errors
///
/// - if fetch size is too big
/// - defined pagination parameter for a query that returns singular result
pub fn apply_postprocessing(
self,
filter: &PredicateBox,
Expand Down
8 changes: 4 additions & 4 deletions core/src/smartcontracts/wasm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1151,7 +1151,7 @@ impl<'wrld, 'block, 'state>
) -> Validate<SignedTransaction> {
Validate {
authority: state.authority.clone(),
block_height: state.state.0.height(),
block_height: state.state.0.height() as u64,
target: state.specific_state.to_validate.clone(),
}
}
Expand Down Expand Up @@ -1238,7 +1238,7 @@ impl<'wrld, 'block, 'state>
) -> Validate<InstructionBox> {
Validate {
authority: state.authority.clone(),
block_height: state.state.0.height(),
block_height: state.state.0.height() as u64,
target: state.specific_state.to_validate.clone(),
}
}
Expand Down Expand Up @@ -1341,7 +1341,7 @@ impl<'wrld, S: StateReadOnly>
) -> Validate<QueryBox> {
Validate {
authority: state.authority.clone(),
block_height: state.state.0.height(),
block_height: state.state.0.height() as u64,
target: state.specific_state.to_validate.clone(),
}
}
Expand Down Expand Up @@ -1419,7 +1419,7 @@ impl<'wrld, 'block, 'state>
state: &state::executor::Migrate<'wrld, 'block, 'state>,
) -> payloads::Migrate {
payloads::Migrate {
block_height: state.state.0.height(),
block_height: state.state.0.height() as u64,
}
}

Expand Down
7 changes: 4 additions & 3 deletions core/src/snapshot.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
//! This module contains [`State`] snapshot actor service.
use std::{
io::Read,
num::NonZeroUsize,
path::{Path, PathBuf},
sync::Arc,
time::Duration,
Expand Down Expand Up @@ -169,8 +170,8 @@ pub fn try_read_snapshot(
});
}
for height in 1..snapshot_height {
let kura_block_hash = kura
.get_block_hash(height as u64)
let kura_block_hash = NonZeroUsize::new(height)
.and_then(|height| kura.get_block_hash(height))
.expect("Kura has height at least as large as state height");
let snapshot_block_hash = state_view.block_hashes[height - 1];
if kura_block_hash != snapshot_block_hash {
Expand Down Expand Up @@ -286,7 +287,7 @@ mod tests {
&store_dir,
&Kura::blank_kura_for_testing(),
LiveQueryStore::test().start(),
BlockCount(usize::try_from(state.view().height()).unwrap()),
BlockCount(state.view().height()),
)
.unwrap();
}
Expand Down
Loading

0 comments on commit 950785c

Please sign in to comment.