snarkvm_ledger_puzzle/partial_solution/
bytes.rs1use super::*;
17
18impl<N: Network> FromBytes for PartialSolution<N> {
19 fn read_le<R: Read>(mut reader: R) -> IoResult<Self> {
21 let epoch_hash = N::BlockHash::read_le(&mut reader)?;
22 let address = Address::<N>::read_le(&mut reader)?;
23 let counter = u64::read_le(&mut reader)?;
24
25 Self::new(epoch_hash, address, counter).map_err(error)
26 }
27}
28
29impl<N: Network> ToBytes for PartialSolution<N> {
30 fn write_le<W: Write>(&self, mut writer: W) -> IoResult<()> {
32 self.epoch_hash.write_le(&mut writer)?;
33 self.address.write_le(&mut writer)?;
34 self.counter.write_le(&mut writer)
35 }
36}
37
38#[cfg(test)]
39mod tests {
40 use super::*;
41 use console::{account::PrivateKey, network::MainnetV0};
42
43 type CurrentNetwork = MainnetV0;
44
45 #[test]
46 fn test_bytes() -> Result<()> {
47 let mut rng = TestRng::default();
48 let private_key = PrivateKey::<CurrentNetwork>::new(&mut rng)?;
49 let address = Address::try_from(private_key)?;
50
51 let expected = PartialSolution::new(rng.gen(), address, u64::rand(&mut rng)).unwrap();
53
54 let expected_bytes = expected.to_bytes_le()?;
56 assert_eq!(expected, PartialSolution::read_le(&expected_bytes[..])?);
57 assert!(PartialSolution::<CurrentNetwork>::read_le(&expected_bytes[1..]).is_err());
58
59 Ok(())
60 }
61}