Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,7 @@ signing_method = { path = "validator_client/signing_method" }
slasher = { path = "slasher", default-features = false }
slashing_protection = { path = "validator_client/slashing_protection" }
slot_clock = { path = "common/slot_clock" }
smallvec = { version = "1.11.2", features = ["arbitrary"] }
smallvec = "1"
snap = "1"
ssz_types = { version = "0.14.0", features = ["context_deserialize", "runtime_types"] }
state_processing = { path = "consensus/state_processing" }
Expand Down
4 changes: 3 additions & 1 deletion consensus/state_processing/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ edition = { workspace = true }
default = []
fake_crypto = ["bls/fake_crypto"]
arbitrary-fuzz = [
"dep:arbitrary",
"smallvec/arbitrary",
"types/arbitrary-fuzz",
"merkle_proof/arbitrary",
"ethereum_ssz/arbitrary",
Expand All @@ -17,7 +19,7 @@ arbitrary-fuzz = [
portable = ["bls/supranational-portable"]

[dependencies]
arbitrary = { workspace = true }
arbitrary = { workspace = true, optional = true }
bls = { workspace = true }
educe = { workspace = true }
ethereum_hashing = { workspace = true }
Expand Down
12 changes: 9 additions & 3 deletions consensus/state_processing/src/verify_operation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ use crate::per_block_processing::{
verify_attester_slashing, verify_bls_to_execution_change, verify_exit,
verify_proposer_slashing,
};
#[cfg(feature = "arbitrary-fuzz")]
use arbitrary::Arbitrary;
use educe::Educe;
use smallvec::{SmallVec, smallvec};
Expand Down Expand Up @@ -39,13 +40,17 @@ pub trait TransformPersist {
///
/// The inner `op` field is private, meaning instances of this type can only be constructed
/// by calling `validate`.
#[derive(Educe, Debug, Clone, Arbitrary)]
#[derive(Educe, Debug, Clone)]
#[cfg_attr(feature = "arbitrary-fuzz", derive(Arbitrary))]
#[educe(
PartialEq,
Eq,
Hash(bound(T: TransformPersist + std::hash::Hash, E: EthSpec))
)]
#[arbitrary(bound = "T: TransformPersist + Arbitrary<'arbitrary>, E: EthSpec")]
#[cfg_attr(
feature = "arbitrary-fuzz",
arbitrary(bound = "T: TransformPersist + Arbitrary<'arbitrary>, E: EthSpec")
)]
pub struct SigVerifiedOp<T: TransformPersist, E: EthSpec> {
op: T,
verified_against: VerifiedAgainst,
Expand Down Expand Up @@ -133,7 +138,8 @@ struct SigVerifiedOpDecode<P: Decode> {
///
/// We need to store multiple `ForkVersion`s because attester slashings contain two indexed
/// attestations which may be signed using different versions.
#[derive(Debug, PartialEq, Eq, Clone, Hash, Encode, Decode, TestRandom, Arbitrary)]
#[derive(Debug, PartialEq, Eq, Clone, Hash, Encode, Decode, TestRandom)]
#[cfg_attr(feature = "arbitrary-fuzz", derive(Arbitrary))]
pub struct VerifiedAgainst {
fork_versions: SmallVec<[ForkVersion; MAX_FORKS_VERIFIED_AGAINST]>,
}
Expand Down
1 change: 1 addition & 0 deletions consensus/types/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ sqlite = ["dep:rusqlite"]
arbitrary = [
"dep:arbitrary",
"bls/arbitrary",
"kzg/arbitrary",
"ethereum_ssz/arbitrary",
"milhouse/arbitrary",
"ssz_types/arbitrary",
Expand Down
4 changes: 2 additions & 2 deletions crypto/bls/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ authors = ["Paul Hauner <paul@paulhauner.com>"]
edition = { workspace = true }

[features]
arbitrary = []
arbitrary = ["dep:arbitrary"]
default = ["supranational"]
fake_crypto = []
supranational = ["blst"]
Expand All @@ -14,7 +14,7 @@ supranational-force-adx = ["supranational", "blst/force-adx"]

[dependencies]
alloy-primitives = { workspace = true }
arbitrary = { workspace = true }
arbitrary = { workspace = true, optional = true }
blst = { version = "0.3.3", optional = true }
ethereum_hashing = { workspace = true }
ethereum_serde_utils = { workspace = true }
Expand Down
3 changes: 2 additions & 1 deletion crypto/kzg/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,11 @@ edition = "2021"

[features]
default = []
arbitrary = ["dep:arbitrary"]
fake_crypto = []

[dependencies]
arbitrary = { workspace = true }
arbitrary = { workspace = true, optional = true }
c-kzg = { workspace = true }
educe = { workspace = true }
ethereum_hashing = { workspace = true }
Expand Down
1 change: 1 addition & 0 deletions crypto/kzg/src/kzg_commitment.rs
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,7 @@ impl Debug for KzgCommitment {
}
}

#[cfg(feature = "arbitrary")]
impl arbitrary::Arbitrary<'_> for KzgCommitment {
fn arbitrary(u: &mut arbitrary::Unstructured<'_>) -> arbitrary::Result<Self> {
let mut bytes = [0u8; BYTES_PER_COMMITMENT];
Expand Down
1 change: 1 addition & 0 deletions crypto/kzg/src/kzg_proof.rs
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ impl Debug for KzgProof {
}
}

#[cfg(feature = "arbitrary")]
impl arbitrary::Arbitrary<'_> for KzgProof {
fn arbitrary(u: &mut arbitrary::Unstructured<'_>) -> arbitrary::Result<Self> {
let mut bytes = [0u8; BYTES_PER_PROOF];
Expand Down
4 changes: 2 additions & 2 deletions validator_client/slashing_protection/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,11 @@ edition = { workspace = true }
autotests = false

[features]
arbitrary-fuzz = ["types/arbitrary-fuzz", "eip_3076/arbitrary-fuzz"]
arbitrary-fuzz = ["dep:arbitrary", "types/arbitrary-fuzz", "eip_3076/arbitrary-fuzz"]
portable = ["types/portable"]

[dependencies]
arbitrary = { workspace = true, features = ["derive"] }
arbitrary = { workspace = true, features = ["derive"], optional = true }
bls = { workspace = true }
eip_3076 = { workspace = true, features = ["json"] }
ethereum_serde_utils = { workspace = true }
Expand Down