Feature-gate all uses of arbitrary (#8867)

Feature gate all uses of `arbitrary` so it is not compiled during release builds.


Co-Authored-By: Mac L <mjladson@pm.me>
This commit is contained in:
Mac L
2026-02-19 23:32:46 +04:00
committed by GitHub
parent 2d91009ab4
commit 9cb72100d4
9 changed files with 22 additions and 10 deletions

View File

@@ -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" }

View File

@@ -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",
@@ -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 }

View File

@@ -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};
@@ -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,
@@ -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]>,
}

View File

@@ -16,6 +16,7 @@ sqlite = ["dep:rusqlite"]
arbitrary = [
"dep:arbitrary",
"bls/arbitrary",
"kzg/arbitrary",
"ethereum_ssz/arbitrary",
"milhouse/arbitrary",
"ssz_types/arbitrary",

View File

@@ -5,7 +5,7 @@ authors = ["Paul Hauner <paul@paulhauner.com>"]
edition = { workspace = true }
[features]
arbitrary = []
arbitrary = ["dep:arbitrary"]
default = ["supranational"]
fake_crypto = []
supranational = ["blst"]
@@ -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 }

View File

@@ -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 }

View File

@@ -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];

View File

@@ -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];

View File

@@ -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 }