zip-rs-wasm/benches/read_entry.rs
2021-06-07 02:51:06 +01:00

74 lines
2.2 KiB
Rust

use criterion::{BenchmarkId, Criterion, Throughput};
use criterion::{criterion_group, criterion_main};
use std::io::{Cursor, Read, Write};
use rand::Rng;
use zip::{CompressionMethod, ZipArchive, ZipWriter};
fn generate_random_archive(size: usize, method: Option<CompressionMethod>) -> Vec<u8> {
let data = Vec::new();
let mut writer = ZipWriter::new(Cursor::new(data));
let options = zip::write::FileOptions::default()
.compression_method(method.unwrap_or(CompressionMethod::Stored));
writer.start_file("random.dat", options).unwrap();
// Generate some random data.
let mut bytes = vec![0u8; size];
rand::thread_rng().fill(bytes.as_mut_slice());
writer.write_all(&bytes).unwrap();
writer.finish().unwrap().into_inner()
}
fn read_entry(bench: &mut Criterion) {
let size = 1024 * 1024;
let bytes = generate_random_archive(size, None);
//
let mut group = bench.benchmark_group("read_entry");
//
for method in CompressionMethod::supported_methods().iter() {
group.bench_with_input(BenchmarkId::from_parameter(method), method, |b, method| {
b.iter(|| {
let mut archive = ZipArchive::new(Cursor::new(bytes.as_slice())).unwrap();
let mut file = archive.by_name("random.dat").unwrap();
let mut buf = [0u8; 1024];
let mut total_bytes = 0;
loop {
let n = file.read(&mut buf).unwrap();
total_bytes += n;
if n == 0 {
return total_bytes
}
}
});
});
}
}
fn write_random_archive(bench: &mut Criterion) {
let size = 1024 * 1024;
//
let mut group = bench.benchmark_group("write_random_archive");
//
for method in CompressionMethod::supported_methods().iter() {
group.bench_with_input(BenchmarkId::from_parameter(method), method, |b, method| {
b.iter(|| {
generate_random_archive(size, Some(method.clone()));
})
});
}
group.finish();
}
criterion_group!(benches, read_entry, write_random_archive);
criterion_main!(benches);