summaryrefslogtreecommitdiff
path: root/src/bin/benchmark-index.rs
diff options
context:
space:
mode:
authorLars Wirzenius <liw@liw.fi>2020-11-25 08:38:01 +0000
committerLars Wirzenius <liw@liw.fi>2020-11-25 08:38:01 +0000
commit92645ef73253166296b5a6c8570729a933e55938 (patch)
treeeea17935c844844a6a4ca5620ee5dae4ede6ce14 /src/bin/benchmark-index.rs
parent02684a9c68ffc87d20ba89852fbcba43ed521039 (diff)
parentaf2c79d1963c49402d5b47e916ffb6b0210c79d1 (diff)
downloadobnam2-92645ef73253166296b5a6c8570729a933e55938.tar.gz
Merge branch 'benchmark-store' into 'main'
feat: add programs to benchmark server chunk storage See merge request larswirzenius/obnam!23
Diffstat (limited to 'src/bin/benchmark-index.rs')
-rw-r--r--src/bin/benchmark-index.rs33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/bin/benchmark-index.rs b/src/bin/benchmark-index.rs
new file mode 100644
index 0000000..5008660
--- /dev/null
+++ b/src/bin/benchmark-index.rs
@@ -0,0 +1,33 @@
+use obnam::benchmark::ChunkGenerator;
+use obnam::index::Index;
+use std::path::PathBuf;
+use structopt::StructOpt;
+
+#[derive(Debug, StructOpt)]
+#[structopt(
+ name = "benchmark-index",
+ about = "Benhcmark the store index in memory"
+)]
+struct Opt {
+ // We don't use this, but we accept it for command line
+ // compatibility with other benchmark programs.
+ #[structopt(parse(from_os_str))]
+ chunks: PathBuf,
+
+ #[structopt()]
+ num: u32,
+}
+
+fn main() -> anyhow::Result<()> {
+ pretty_env_logger::init();
+
+ let opt = Opt::from_args();
+ let gen = ChunkGenerator::new(opt.num);
+
+ let mut index = Index::default();
+ for (id, checksum, _, _) in gen {
+ index.insert(id, "sha25", &checksum);
+ }
+
+ Ok(())
+}