Skip to content

Commit

Permalink
[refactor]: Fix CI lints after bump of toolchain version
Browse files Browse the repository at this point in the history
Signed-off-by: Marin Veršić <[email protected]>
  • Loading branch information
mversic committed Jan 15, 2024
1 parent 66072b4 commit ba8684d
Show file tree
Hide file tree
Showing 29 changed files with 75 additions and 123 deletions.
5 changes: 0 additions & 5 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -144,12 +144,10 @@ rust.nonstandard_style = "deny"
rust.rust_2018_idioms = "deny"
rust.trivial_casts = "deny"
rust.trivial_numeric_casts = "deny"
rust.unconditional_recursion = "deny"
rust.unsafe_code = "deny"
rust.unused = "deny"
rust.unused_import_braces = "deny"
rust.variant_size_differences = "deny"
rust.unused_tuple_struct_fields = "deny"
rust.explicit_outlives_requirements = "deny"
rust.non_ascii_idents = "deny"
rust.elided_lifetimes_in_paths = "allow"
Expand All @@ -159,9 +157,6 @@ rust.unused_lifetimes = "warn"
# TODO: reenable
# rust.unsafe_op_in_unsafe_fn = "deny"

# lower the priority to allow overriding later
clippy.all = { level = "deny", priority = -1 }

# pedantic
clippy.pedantic = { level = "warn", priority = -1 }
clippy.match_wildcard_for_single_variants = "allow"
Expand Down
2 changes: 1 addition & 1 deletion cli/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -528,7 +528,7 @@ pub fn read_config(
let mut cfg = config.override_with(ConfigurationProxy::from_path(&*actual_config_path));
let config_dir = actual_config_path
.parent()
.expect("If config file was read, than it should has a parent. It is a bug.");
.expect("If config file was read, than it should have a parent. It is a bug.");

// careful here: `genesis.file` might be a path relative to the config file.
// we need to resolve it before proceeding
Expand Down
2 changes: 0 additions & 2 deletions client/tests/integration/events/pipeline.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ use iroha_config::iroha::Configuration;
use test_network::*;

// Needed to re-enable ignored tests.
#[allow(dead_code)]
const PEER_COUNT: usize = 7;

#[ignore = "ignore, more in #2851"]
Expand All @@ -33,7 +32,6 @@ fn transaction_with_fail_instruction_should_be_rejected() -> Result<()> {
)
}

#[allow(dead_code, clippy::needless_range_loop, clippy::needless_pass_by_value)]
fn test_with_instruction_and_status_and_port(
instruction: Option<InstructionBox>,
should_be: PipelineStatusKind,
Expand Down
13 changes: 5 additions & 8 deletions client/tests/integration/unregister_peer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -112,14 +112,11 @@ fn init() -> Result<(
let asset_definition_id: AssetDefinitionId = "xor#domain".parse()?;
let create_asset =
Register::asset_definition(AssetDefinition::quantity(asset_definition_id.clone()));
let instructions = parameters.into_iter().chain(
[
create_domain.into(),
create_account.into(),
create_asset.into(),
]
.into_iter(),
);
let instructions = parameters.into_iter().chain([
create_domain.into(),
create_account.into(),
create_asset.into(),
]);
client.submit_all_blocking(instructions)?;
iroha_logger::info!("Init");
Ok((
Expand Down
2 changes: 1 addition & 1 deletion client_cli/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ impl FromStr for ValueArg {
.or_else(|_| s.parse::<Ipv6Addr>().map(Value::Ipv6Addr))
.or_else(|_| s.parse::<NumericValue>().map(Value::Numeric))
.or_else(|_| s.parse::<PublicKey>().map(Value::PublicKey))
.or_else(|_| serde_json::from_str::<Value>(s).map_err(std::convert::Into::into))
.or_else(|_| serde_json::from_str::<Value>(s).map_err(Into::into))
.map(ValueArg)
}
}
Expand Down
7 changes: 4 additions & 3 deletions config/src/path.rs
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,10 @@ impl Path {
/// If the path has an extension.
pub fn default(path: impl AsRef<std::path::Path>) -> Self {
let path = path.as_ref().to_path_buf();
if path.extension().is_some() {
panic!("Default config path is not supposed to have an extension. It is a bug.")
}
assert!(
path.extension().is_none(),
"Default config path is not supposed to have an extension. It is a bug."
);
Self(Default(path))
}

Expand Down
2 changes: 1 addition & 1 deletion core/src/block_sync.rs
Original file line number Diff line number Diff line change
Expand Up @@ -218,7 +218,7 @@ pub mod message {
.take(1 + block_sync.block_batch_size as usize)
.map_while(|height| block_sync.kura.get_block_by_height(height))
.skip_while(|block| Some(block.hash()) == *latest_hash)
.map(|block| SignedBlock::clone(&block))
.map(|block| (*block).clone())
.collect::<Vec<_>>();

if blocks.is_empty() {
Expand Down
1 change: 0 additions & 1 deletion core/src/kiso.rs
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,6 @@ impl Actor {
}

#[cfg(test)]
#[allow(unused)]
mod tests {
use std::time::Duration;

Expand Down
1 change: 0 additions & 1 deletion core/src/kura.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ const SIZE_OF_BLOCK_HASH: u64 = Hash::LENGTH as u64;
#[derive(Debug)]
pub struct Kura {
/// The mode of initialisation of [`Kura`].
#[allow(dead_code)]
mode: Mode,
/// The block storage
block_store: Mutex<BlockStore>,
Expand Down
5 changes: 2 additions & 3 deletions core/src/queue.rs
Original file line number Diff line number Diff line change
Expand Up @@ -250,9 +250,8 @@ impl Queue {
expired_transactions: &mut Vec<AcceptedTransaction>,
) -> Option<AcceptedTransaction> {
loop {
let Some(hash) = self.tx_hashes.pop() else {
return None;
};
let hash = self.tx_hashes.pop()?;

let entry = match self.accepted_txs.entry(hash) {
Entry::Occupied(entry) => entry,
// FIXME: Reachable under high load. Investigate, see if it's a problem.
Expand Down
2 changes: 1 addition & 1 deletion core/src/smartcontracts/isi/account.rs
Original file line number Diff line number Diff line change
Expand Up @@ -581,7 +581,7 @@ pub mod query {
let id = &self.id;
let key = &self.key;
iroha_logger::trace!(%id, %key);
wsv.map_account(id, |account| account.metadata.get(key).map(Clone::clone))?
wsv.map_account(id, |account| account.metadata.get(key).cloned())?
.ok_or_else(|| FindError::MetadataKey(key.clone()).into())
.map(Into::into)
}
Expand Down
4 changes: 1 addition & 3 deletions core/src/smartcontracts/isi/block.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,7 @@ impl ValidQuery for FindAllBlocks {
wsv: &'wsv WorldStateView,
) -> Result<Box<dyn Iterator<Item = SignedBlock> + 'wsv>, QueryExecutionFail> {
Ok(Box::new(
wsv.all_blocks()
.rev()
.map(|block| SignedBlock::clone(&block)),
wsv.all_blocks().rev().map(|block| (*block).clone()),
))
}
}
Expand Down
2 changes: 1 addition & 1 deletion core/src/smartcontracts/isi/domain.rs
Original file line number Diff line number Diff line change
Expand Up @@ -334,7 +334,7 @@ pub mod query {
let id = &self.id;
let key = &self.key;
iroha_logger::trace!(%id, %key);
wsv.map_domain(id, |domain| domain.metadata.get(key).map(Clone::clone))?
wsv.map_domain(id, |domain| domain.metadata.get(key).cloned())?
.ok_or_else(|| FindError::MetadataKey(key.clone()).into())
.map(Into::into)
}
Expand Down
14 changes: 6 additions & 8 deletions core/src/tx.rs
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,7 @@ impl AcceptedTransaction {
match &transaction.payload().instructions {
Executable::Instructions(instructions) => {
let instruction_count = instructions.len();
if u64::try_from(instruction_count).expect("`usize` should always fit into `u64`")
> limits.max_instruction_number
{
if Self::len_u64(instruction_count) > limits.max_instruction_number {
return Err(AcceptTransactionFail::TransactionLimit(
TransactionLimitError {
reason: format!(
Expand All @@ -76,13 +74,9 @@ impl AcceptedTransaction {
//
// Should we allow infinite instructions in wasm? And deny only based on fuel and size
Executable::Wasm(smart_contract) => {
let size_bytes = Self::len_u64(smart_contract.size_bytes());
let max_wasm_size_bytes = limits.max_wasm_size_bytes;

let size_bytes: u64 = smart_contract
.size_bytes()
.try_into()
.expect("`u64` should always fit in `u64`");

if size_bytes > max_wasm_size_bytes {
return Err(AcceptTransactionFail::TransactionLimit(
TransactionLimitError {
Expand Down Expand Up @@ -113,6 +107,10 @@ impl AcceptedTransaction {
pub(crate) fn merge_signatures(&mut self, other: Self) -> bool {
self.0.merge_signatures(other.0)
}

fn len_u64(instruction_count: usize) -> u64 {
u64::try_from(instruction_count).expect("`usize` should always fit into `u64`")
}
}

impl From<AcceptedTransaction> for SignedTransaction {
Expand Down
4 changes: 2 additions & 2 deletions core/src/wsv.rs
Original file line number Diff line number Diff line change
Expand Up @@ -770,7 +770,7 @@ impl WorldStateView {
.assets
.get(id)
.ok_or_else(|| QueryExecutionFail::from(FindError::Asset(id.clone())))
.map(Clone::clone)
.cloned()
},
)?
}
Expand Down Expand Up @@ -1102,7 +1102,7 @@ impl WorldStateView {
.asset_definitions
.get(asset_id)
.ok_or_else(|| FindError::AssetDefinition(asset_id.clone()))
.map(Clone::clone)
.cloned()
}

/// Get total amount of [`Asset`].
Expand Down
2 changes: 2 additions & 0 deletions crypto/src/hash.rs
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,8 @@ impl<T> Clone for HashOf<T> {
impl<T> Copy for HashOf<T> {}

impl<T> PartialEq for HashOf<T> {
// NOTE: False positive
#[allow(clippy::unconditional_recursion)]
fn eq(&self, other: &Self) -> bool {
self.0.eq(&other.0)
}
Expand Down
5 changes: 0 additions & 5 deletions crypto/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -113,10 +113,6 @@ impl FromStr for Algorithm {

/// Options for key generation
#[cfg(not(feature = "ffi_import"))]
#[cfg_attr(
any(not(feature = "std"), feature = "ffi_import"),
allow(unused_tuple_struct_fields)
)]
#[derive(Debug, Clone)]
pub enum KeyGenOption {
/// Use seed
Expand Down Expand Up @@ -474,7 +470,6 @@ impl<'de> Deserialize<'de> for PrivateKey {
}

/// A session key derived from a key exchange. Will usually be used for a symmetric encryption afterwards
#[allow(unused_tuple_struct_fields)]
pub struct SessionKey(ConstVec<u8>);

impl SessionKey {
Expand Down
5 changes: 1 addition & 4 deletions crypto/src/signature/bls/implementation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,6 @@ use sha2::Sha256;

pub(super) const MESSAGE_CONTEXT: &[u8; 20] = b"for signing messages";

// it is not unused? Why am I getting the unused lint here?
#[allow(dead_code)]
const PUBLICKEY_CONTEXT: &[u8; 47] = b"for signing public keys for proof of possession";

use super::PRIVATE_KEY_SIZE;
use crate::{
Algorithm, ConstVec, Error, KeyGenOption, PrivateKey as IrohaPrivateKey,
Expand Down Expand Up @@ -61,6 +57,7 @@ pub trait BlsConfiguration {
}

fn hash_key(pk: &PublicKey<Self>, context: Option<&'static [u8]>) -> Self::SignatureGroup {
const PUBLICKEY_CONTEXT: &[u8; 47] = b"for signing public keys for proof of possession";
let ctx: &[u8] = context.unwrap_or(PUBLICKEY_CONTEXT);
Self::hash_to_point(pk.to_bytes(), ctx)
}
Expand Down
Loading

0 comments on commit ba8684d

Please sign in to comment.