From fbab7f3cf36ce30791448bb0a7b6cfa943bfebac Mon Sep 17 00:00:00 2001 From: Gav Wood Date: Wed, 2 Dec 2015 02:37:26 +0100 Subject: [PATCH] Random trie tests. --- src/trie.rs | 46 ++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 44 insertions(+), 2 deletions(-) diff --git a/src/trie.rs b/src/trie.rs index 4fc2b3a70..2fb05ccfb 100644 --- a/src/trie.rs +++ b/src/trie.rs @@ -1,3 +1,5 @@ +extern crate rand; + use std::fmt; use memorydb::*; use sha3::*; @@ -6,6 +8,7 @@ use hash::*; use nibbleslice::*; use bytes::*; use rlp::*; + //use log::*; pub const NULL_RLP: [u8; 1] = [0x80; 1]; @@ -509,10 +512,12 @@ impl Trie for TrieDB { mod tests { use rustc_serialize::hex::FromHex; use triehash::*; + use hash::*; use super::*; use nibbleslice::*; use rlp; use env_logger; + use rand::random; #[test] fn test_node_leaf() { @@ -605,8 +610,8 @@ mod tests { t.insert(&key, &val); } - trace!("{:?}", t); - println!("{:?}", t); +// trace!("{:?}", t); +// println!("{:?}", t); // check lifetime // let _q = t.at(&[b'd', b'o']).unwrap(); @@ -614,6 +619,43 @@ mod tests { assert_eq!(*t.root(), trie_root(v)); } + fn random_key() -> Vec { + let chars = b"abcdefgrstuvwABCDEFGRSTUVW"; + let mut ret: Vec = Vec::new(); + let r = random::() % 4 + 1; + for _ in 0..r { + ret.push(chars[random::() % chars.len()]); + } + ret + } + + #[test] + fn stress() { + for _ in 0..1000 { + let mut x: Vec<(Vec, Vec)> = Vec::new(); + for j in 0..100u32 { + let key = random_key(); + x.push((key, rlp::encode(&j))); + } + let real = trie_root(x.clone()); + + let mem = trie_root_mem(&x); + assert_eq!(mem, real); + } + } + + fn trie_root_mem(v: &Vec<(Vec, Vec)>) -> H256 { + let mut t = TrieDB::new_memory(); + + for i in 0..v.len() { + let key: &[u8]= &v[i].0; + let val: &[u8] = &v[i].1; + t.insert(&key, &val); + } + + t.root().clone() + } + #[test] fn test_at_dog() { env_logger::init().ok();