mirror of https://github.com/dswd/zvault
Benches and tests for chunkers
This commit is contained in:
parent
bf00a2b156
commit
3839ed943f
|
@ -0,0 +1,115 @@
|
||||||
|
#![feature(test)]
|
||||||
|
|
||||||
|
extern crate test;
|
||||||
|
extern crate chunking;
|
||||||
|
|
||||||
|
use chunking::*;
|
||||||
|
|
||||||
|
use std::io::{self, Write, Cursor};
|
||||||
|
use test::Bencher;
|
||||||
|
|
||||||
|
|
||||||
|
fn random_data(seed: u64, size: usize) -> Vec<u8> {
|
||||||
|
assert_eq!(size % 4, 0);
|
||||||
|
let mut data = vec![0; size];
|
||||||
|
let a = 6364136223846793005;
|
||||||
|
let c = 1442695040888963407;
|
||||||
|
let mut v = seed;
|
||||||
|
for i in 0..size/4 {
|
||||||
|
v = v.wrapping_mul(a).wrapping_add(c);
|
||||||
|
data[4*i] = ((v >> 24) & 0xff) as u8;
|
||||||
|
data[4*i+1] = ((v >> 16) & 0xff) as u8;
|
||||||
|
data[4*i+2] = ((v >> 8) & 0xff) as u8;
|
||||||
|
data[4*i+3] = (v & 0xff) as u8;
|
||||||
|
}
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
struct DevNull;
|
||||||
|
|
||||||
|
impl Write for DevNull {
|
||||||
|
fn write(&mut self, data: &[u8]) -> Result<usize, io::Error> {
|
||||||
|
Ok(data.len())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn flush(&mut self) -> Result<(), io::Error> {
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_fixed_init(b: &mut Bencher) {
|
||||||
|
b.iter(|| {
|
||||||
|
FixedChunker::new(8*1024);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_fixed_8192(b: &mut Bencher) {
|
||||||
|
let data = random_data(0, 1024*1024);
|
||||||
|
b.bytes = data.len() as u64;
|
||||||
|
b.iter(|| {
|
||||||
|
let mut chunker = FixedChunker::new(8*1024);
|
||||||
|
let mut cursor = Cursor::new(&data);
|
||||||
|
while chunker.chunk(&mut cursor, &mut DevNull).unwrap() == ChunkerStatus::Continue {}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_ae_init(b: &mut Bencher) {
|
||||||
|
b.iter(|| {
|
||||||
|
AeChunker::new(8*1024);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_ae_8192(b: &mut Bencher) {
|
||||||
|
let data = random_data(0, 1024*1024);
|
||||||
|
b.bytes = data.len() as u64;
|
||||||
|
b.iter(|| {
|
||||||
|
let mut chunker = AeChunker::new(8*1024);
|
||||||
|
let mut cursor = Cursor::new(&data);
|
||||||
|
while chunker.chunk(&mut cursor, &mut DevNull).unwrap() == ChunkerStatus::Continue {}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_rabin_init(b: &mut Bencher) {
|
||||||
|
b.iter(|| {
|
||||||
|
RabinChunker::new(8*1024, 0);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_rabin_8192(b: &mut Bencher) {
|
||||||
|
let data = random_data(0, 1024*1024);
|
||||||
|
b.bytes = data.len() as u64;
|
||||||
|
b.iter(|| {
|
||||||
|
let mut chunker = RabinChunker::new(8*1024, 0);
|
||||||
|
let mut cursor = Cursor::new(&data);
|
||||||
|
while chunker.chunk(&mut cursor, &mut DevNull).unwrap() == ChunkerStatus::Continue {}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_fastcdc_init(b: &mut Bencher) {
|
||||||
|
b.iter(|| {
|
||||||
|
FastCdcChunker::new(8*1024, 0);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
#[bench]
|
||||||
|
fn test_fastcdc_8192(b: &mut Bencher) {
|
||||||
|
let data = random_data(0, 1024*1024);
|
||||||
|
b.bytes = data.len() as u64;
|
||||||
|
b.iter(|| {
|
||||||
|
let mut chunker = FastCdcChunker::new(8*1024, 0);
|
||||||
|
let mut cursor = Cursor::new(&data);
|
||||||
|
while chunker.chunk(&mut cursor, &mut DevNull).unwrap() == ChunkerStatus::Continue {}
|
||||||
|
})
|
||||||
|
}
|
|
@ -0,0 +1,84 @@
|
||||||
|
extern crate chunking;
|
||||||
|
|
||||||
|
use chunking::*;
|
||||||
|
|
||||||
|
use std::io::Cursor;
|
||||||
|
|
||||||
|
|
||||||
|
fn random_data(seed: u64, size: usize) -> Vec<u8> {
|
||||||
|
assert_eq!(size % 4, 0);
|
||||||
|
let mut data = vec![0; size];
|
||||||
|
let a = 6364136223846793005;
|
||||||
|
let c = 1442695040888963407;
|
||||||
|
let mut v = seed;
|
||||||
|
for i in 0..size/4 {
|
||||||
|
v = v.wrapping_mul(a).wrapping_add(c);
|
||||||
|
data[4*i] = ((v >> 24) & 0xff) as u8;
|
||||||
|
data[4*i+1] = ((v >> 16) & 0xff) as u8;
|
||||||
|
data[4*i+2] = ((v >> 8) & 0xff) as u8;
|
||||||
|
data[4*i+3] = (v & 0xff) as u8;
|
||||||
|
}
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_chunking(chunker: &mut Chunker, data: &[u8]) -> usize {
|
||||||
|
let mut cursor = Cursor::new(&data);
|
||||||
|
let mut chunks = vec![];
|
||||||
|
let mut chunk = vec![];
|
||||||
|
while chunker.chunk(&mut cursor, &mut chunk).unwrap() == ChunkerStatus::Continue {
|
||||||
|
chunks.push(chunk);
|
||||||
|
chunk = vec![];
|
||||||
|
}
|
||||||
|
chunks.push(chunk);
|
||||||
|
let mut pos = 0;
|
||||||
|
for chunk in &chunks {
|
||||||
|
assert_eq!(&data[pos..pos+chunk.len()], chunk as &[u8]);
|
||||||
|
pos += chunk.len();
|
||||||
|
}
|
||||||
|
chunks.len()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_fixed() {
|
||||||
|
let data = random_data(0, 10*1024*1024);
|
||||||
|
for n in &[1usize,2,4,8,16,32,64,128,256,512,1024] {
|
||||||
|
let mut chunker = FixedChunker::new(1024*n);
|
||||||
|
let len = test_chunking(&mut chunker, &data);
|
||||||
|
assert!(len >= data.len()/n/1024/4);
|
||||||
|
assert!(len <= data.len()/n/1024*4);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_ae() {
|
||||||
|
let data = random_data(0, 10*1024*1024);
|
||||||
|
for n in &[1usize,2,4,8,16,32,64,128,256,512,1024] {
|
||||||
|
let mut chunker = AeChunker::new(1024*n);
|
||||||
|
let len = test_chunking(&mut chunker, &data);
|
||||||
|
assert!(len >= data.len()/n/1024/4);
|
||||||
|
assert!(len <= data.len()/n/1024*4);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_rabin() {
|
||||||
|
let data = random_data(0, 10*1024*1024);
|
||||||
|
for n in &[1usize,2,4,8,16,32,64,128,256,512,1024] {
|
||||||
|
let mut chunker = RabinChunker::new(1024*n, 0);
|
||||||
|
let len = test_chunking(&mut chunker, &data);
|
||||||
|
assert!(len >= data.len()/n/1024/4);
|
||||||
|
assert!(len <= data.len()/n/1024*4);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_fastcdc() {
|
||||||
|
let data = random_data(0, 10*1024*1024);
|
||||||
|
for n in &[1usize,2,4,8,16,32,64,128,256,512,1024] {
|
||||||
|
let mut chunker = FastCdcChunker::new(1024*n, 0);
|
||||||
|
let len = test_chunking(&mut chunker, &data);
|
||||||
|
assert!(len >= data.len()/n/1024/4);
|
||||||
|
assert!(len <= data.len()/n/1024*4);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue