From a9e39d23e16fe0a5ef8e039c79f7070d21d8a2f3 Mon Sep 17 00:00:00 2001 From: Greg Fitzgerald Date: Fri, 4 May 2018 11:50:13 -0600 Subject: [PATCH] Limit 256 events per entry Attempt to keep blob size under 64kb --- src/recorder.rs | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/src/recorder.rs b/src/recorder.rs index faf07593577759..38cc6d87a103b4 100644 --- a/src/recorder.rs +++ b/src/recorder.rs @@ -79,6 +79,13 @@ impl Recorder { } Signal::Event(event) => { self.events.push(event); + + // Record an entry early if we anticipate its serialized size will + // be larger than 64kb. At the time of this writing, we assume each + // event will be well under 256 bytes. + if self.events.len() >= 65_536 / 256 { + self.record_entry()?; + } } }, Err(TryRecvError::Empty) => return Ok(()), @@ -87,3 +94,34 @@ impl Recorder { } } } + +#[cfg(test)] +mod tests { + use super::*; + use bincode::serialize; + use signature::{KeyPair, KeyPairUtil}; + use transaction::Transaction; + use std::sync::mpsc::sync_channel; + + #[test] + fn test_sub64k_entry_size() { + let (signal_sender, signal_receiver) = sync_channel(500); + let (entry_sender, entry_receiver) = sync_channel(10); + let zero = Hash::default(); + let mut recorder = Recorder::new(signal_receiver, entry_sender, zero); + let alice_keypair = KeyPair::new(); + let bob_pubkey = KeyPair::new().pubkey(); + for _ in 0..256 { + let tx = Transaction::new(&alice_keypair, bob_pubkey, 1, zero); + let event = Event::Transaction(tx); + signal_sender.send(Signal::Event(event)).unwrap(); + } + + recorder.process_events(Instant::now(), None).unwrap(); + + drop(recorder.sender); + let entries: Vec<_> = entry_receiver.iter().collect(); + assert_eq!(entries.len(), 1); + assert!(serialize(&entries[0]).unwrap().len() <= 65_536); + } +}