Impl Arbitrary for Bctv14Proof
This commit is contained in:
parent
f4df61eb47
commit
7d520f8133
|
|
@ -1,5 +1,8 @@
|
||||||
use std::{fmt, io};
|
use std::{fmt, io};
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
use proptest::{arbitrary::Arbitrary, collection::vec, prelude::*};
|
||||||
|
|
||||||
use crate::serialization::{SerializationError, ZcashDeserialize, ZcashSerialize};
|
use crate::serialization::{SerializationError, ZcashDeserialize, ZcashSerialize};
|
||||||
|
|
||||||
/// An encoding of a BCTV14 proof, as used in Zcash.
|
/// An encoding of a BCTV14 proof, as used in Zcash.
|
||||||
|
|
@ -47,3 +50,20 @@ impl ZcashDeserialize for Bctv14Proof {
|
||||||
Ok(Self(bytes))
|
Ok(Self(bytes))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
impl Arbitrary for Bctv14Proof {
|
||||||
|
type Parameters = ();
|
||||||
|
|
||||||
|
fn arbitrary_with(_args: Self::Parameters) -> Self::Strategy {
|
||||||
|
(vec(any::<u8>(), 296))
|
||||||
|
.prop_map(|v| {
|
||||||
|
let mut bytes = [0; 296];
|
||||||
|
bytes.copy_from_slice(v.as_slice());
|
||||||
|
return Self(bytes);
|
||||||
|
})
|
||||||
|
.boxed()
|
||||||
|
}
|
||||||
|
|
||||||
|
type Strategy = BoxedStrategy<Self>;
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue