From cd78241d67338589ea12316de416acf347491367 Mon Sep 17 00:00:00 2001 From: teor Date: Fri, 16 Jul 2021 07:34:22 +1000 Subject: [PATCH] Test consensus-critical `Amount` deserialization (#2487) * Add the constraint name to the Amount debug format * Test consensus-critical serialization for Amount Previously we were testing `serde` and `bincode` serialization, which uses a completely different code path. Co-authored-by: Alfredo Garcia --- Cargo.lock | 10 ---------- zebra-chain/Cargo.toml | 1 - zebra-chain/src/amount.rs | 34 ++++++++++++++++++++++------------ 3 files changed, 22 insertions(+), 23 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 7aab7ba30..52d7d288f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -300,15 +300,6 @@ dependencies = [ "crunchy 0.1.6", ] -[[package]] -name = "bincode" -version = "1.3.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1f45e9417d87227c7a56d22e471c6206462cba514c7590c09aff4cf6d1ddcad" -dependencies = [ - "serde", -] - [[package]] name = "bindgen" version = "0.57.0" @@ -4496,7 +4487,6 @@ dependencies = [ "aes", "bech32", "bigint", - "bincode", "bitflags", "bitvec", "blake2b_simd", diff --git a/zebra-chain/Cargo.toml b/zebra-chain/Cargo.toml index bc6c1f02e..c3ab51564 100644 --- a/zebra-chain/Cargo.toml +++ b/zebra-chain/Cargo.toml @@ -63,7 +63,6 @@ redjubjub = { git = "https://github.com/ZcashFoundation/redjubjub.git", rev = "f zebra-test = { path = "../zebra-test/", optional = true } [dev-dependencies] -bincode = "1" color-eyre = "0.5.11" criterion = { version = "0.3", features = ["html_reports"] } itertools = "0.10.1" diff --git a/zebra-chain/src/amount.rs b/zebra-chain/src/amount.rs index e18e39e29..a6de40bb7 100644 --- a/zebra-chain/src/amount.rs +++ b/zebra-chain/src/amount.rs @@ -24,13 +24,11 @@ type Result = std::result::Result; #[serde(bound = "C: Constraint")] pub struct Amount(i64, PhantomData); -// in a world where specialization existed -// https://github.com/rust-lang/rust/issues/31844 -// we could do much better here -// for now, drop the constraint impl std::fmt::Debug for Amount { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - f.debug_tuple("Amount").field(&self.0).finish() + f.debug_tuple(&format!("Amount<{}>", std::any::type_name::())) + .field(&self.0) + .finish() } } @@ -425,6 +423,8 @@ where #[cfg(test)] mod test { + use crate::serialization::ZcashDeserializeInto; + use super::*; use std::{collections::hash_map::RandomState, collections::HashSet, fmt::Debug}; @@ -593,20 +593,30 @@ mod test { fn deserialize_checks_bounds() -> Result<()> { zebra_test::init(); - let big = MAX_MONEY * 2; + let big = (MAX_MONEY * 2) + .try_into() + .expect("unexpectedly large constant: multiplied constant should be within range"); let neg = -10; - let big_bytes = bincode::serialize(&big)?; - let neg_bytes = bincode::serialize(&neg)?; + let mut big_bytes = Vec::new(); + (&mut big_bytes) + .write_u64::(big) + .expect("unexpected serialization failure: vec should be infalliable"); - bincode::deserialize::>(&big_bytes) + let mut neg_bytes = Vec::new(); + (&mut neg_bytes) + .write_i64::(neg) + .expect("unexpected serialization failure: vec should be infalliable"); + + Amount::::zcash_deserialize(big_bytes.as_slice()) .expect_err("deserialization should reject too large values"); - bincode::deserialize::>(&big_bytes) + Amount::::zcash_deserialize(big_bytes.as_slice()) .expect_err("deserialization should reject too large values"); - bincode::deserialize::>(&neg_bytes) + Amount::::zcash_deserialize(neg_bytes.as_slice()) .expect_err("NonNegative deserialization should reject negative values"); - let amount = bincode::deserialize::>(&neg_bytes) + let amount: Amount = neg_bytes + .zcash_deserialize_into() .expect("NegativeAllowed deserialization should allow negative values"); assert_eq!(amount.0, neg);