From 12706424e3d39ddfabcd11f88cc39b4038767521 Mon Sep 17 00:00:00 2001 From: Stefano Amorelli Date: Sun, 17 Aug 2025 14:01:09 +0300 Subject: [PATCH] fix: update benchmarks to use available test fixtures - Add parse_str method to Parser - Update benchmark to use existing fixtures or minimal inline XBRL - Remove unused crabrl_bench.rs --- benches/parser.rs | 46 +++++++++++++++++++++++++++-------------- src/bin/crabrl_bench.rs | 41 ------------------------------------ src/simple_parser.rs | 4 ++++ 3 files changed, 34 insertions(+), 57 deletions(-) delete mode 100644 src/bin/crabrl_bench.rs diff --git a/benches/parser.rs b/benches/parser.rs index 3d5156e..f3058ad 100644 --- a/benches/parser.rs +++ b/benches/parser.rs @@ -1,23 +1,37 @@ use crabrl::Parser; use criterion::{black_box, criterion_group, criterion_main, Criterion}; +use std::path::Path; -fn parse_small_file(c: &mut Criterion) { +fn parse_sample_sec_file(c: &mut Criterion) { let parser = Parser::new(); - let content = include_bytes!("../tests/fixtures/small.xml"); - - c.bench_function("parse_small", |b| { - b.iter(|| parser.parse_bytes(black_box(content))); - }); + let sample_file = Path::new("fixtures/sample-sec.xml"); + + if sample_file.exists() { + c.bench_function("parse_sample_sec", |b| { + b.iter(|| parser.parse_file(black_box(&sample_file))); + }); + } else { + // If no fixtures exist, use a minimal inline XBRL for benchmarking + let minimal_xbrl = r#" + + + + 0000000000 + + + 2023-12-31 + + + + iso4217:USD + +"#; + + c.bench_function("parse_minimal", |b| { + b.iter(|| parser.parse_str(black_box(minimal_xbrl))); + }); + } } -fn parse_medium_file(c: &mut Criterion) { - let parser = Parser::new(); - let content = include_bytes!("../tests/fixtures/medium.xml"); - - c.bench_function("parse_medium", |b| { - b.iter(|| parser.parse_bytes(black_box(content))); - }); -} - -criterion_group!(benches, parse_small_file, parse_medium_file); +criterion_group!(benches, parse_sample_sec_file); criterion_main!(benches); diff --git a/src/bin/crabrl_bench.rs b/src/bin/crabrl_bench.rs deleted file mode 100644 index 8549146..0000000 --- a/src/bin/crabrl_bench.rs +++ /dev/null @@ -1,41 +0,0 @@ -use crabrl::Parser; -use std::env; -use std::time::Instant; - -fn main() { - let args: Vec = env::args().collect(); - if args.len() != 2 { - eprintln!("Usage: {} ", args[0]); - std::process::exit(1); - } - - let filepath = &args[1]; - let parser = Parser::new(); - - let start = Instant::now(); - match parser.parse_file(filepath) { - Ok(doc) => { - let elapsed = start.elapsed(); - let ms = elapsed.as_secs_f64() * 1000.0; - println!( - "crabrl found: {} facts, {} contexts, {} units (in {:.3}ms)", - doc.facts.len(), - doc.contexts.len(), - doc.units.len(), - ms - ); - - // Additional stats - println!("Facts: {}", doc.facts.len()); - println!("Contexts: {}", doc.contexts.len()); - println!("Units: {}", doc.units.len()); - println!("Tuples: {}", doc.tuples.len()); - println!("Footnotes: {}", doc.footnotes.len()); - println!("Time: {:.3}ms", ms); - } - Err(e) => { - eprintln!("Error parsing file: {}", e); - std::process::exit(1); - } - } -} diff --git a/src/simple_parser.rs b/src/simple_parser.rs index acd9fe4..ae98025 100644 --- a/src/simple_parser.rs +++ b/src/simple_parser.rs @@ -14,6 +14,10 @@ impl Parser { Self::default() } + pub fn parse_str(&self, content: &str) -> Result { + self.parse_bytes(content.as_bytes()) + } + pub fn parse_file>(&self, path: P) -> Result { let content = std::fs::read(path)?; self.parse_bytes(&content)