From da695c64a670c20cdeb043a68fc6f69e1426a0a1 Mon Sep 17 00:00:00 2001 From: Afonso Tinoco Date: Wed, 27 Nov 2024 13:26:17 -0500 Subject: [PATCH 1/2] Allow to parse generic cargo bench/criterion units --- src/extract.ts | 8 ++-- test/__snapshots__/extract.spec.ts.snap | 47 ++++++++++++++++++++++++ test/data/extract/cargo_output_units.txt | 9 +++++ test/extract.spec.ts | 4 ++ 4 files changed, 65 insertions(+), 3 deletions(-) create mode 100644 test/data/extract/cargo_output_units.txt diff --git a/src/extract.ts b/src/extract.ts index 014517667..011f55e55 100644 --- a/src/extract.ts +++ b/src/extract.ts @@ -315,7 +315,8 @@ function extractCargoResult(output: string): BenchmarkResult[] { const ret = []; // Example: // test bench_fib_20 ... bench: 37,174.25 ns/iter (+/- 7,527.43) - const reExtract = /^test (.+)\s+\.\.\. bench:\s+([0-9,.]+) ns\/iter \(\+\/- ([0-9,.]+)\)$/; + + const reExtract = /^test (.+)\s+\.\.\. bench:\s+([0-9,.]+) (\w+\/\w+) \(\+\/- ([0-9,.]+)\)$/; const reComma = /,/g; for (const line of lines) { @@ -326,13 +327,14 @@ function extractCargoResult(output: string): BenchmarkResult[] { const name = m[1].trim(); const value = parseFloat(m[2].replace(reComma, '')); - const range = m[3].replace(reComma, ''); + const unit = m[3].trim(); + const range = m[4].replace(reComma, ''); ret.push({ name, value, range: `± ${range}`, - unit: 'ns/iter', + unit: unit, }); } diff --git a/test/__snapshots__/extract.spec.ts.snap b/test/__snapshots__/extract.spec.ts.snap index 36b02e2ba..76d1e91a9 100644 --- a/test/__snapshots__/extract.spec.ts.snap +++ b/test/__snapshots__/extract.spec.ts.snap @@ -134,6 +134,53 @@ exports[`extractResult() extracts benchmark output from cargo - cargo_output.txt } `; +exports[`extractResult() extracts benchmark output from cargo - cargo_output_units.txt 1`] = ` +{ + "benches": [ + { + "name": "cmov", + "range": "± 14", + "unit": "cycles/iter", + "value": 2835, + }, + { + "name": "cmov2", + "range": "± 19", + "unit": "cycles/iter", + "value": 2845, + }, + { + "name": "mov", + "range": "± 17", + "unit": "cycles/iter", + "value": 1508, + }, + { + "name": "upload", + "range": "± 420", + "unit": "MS/s", + "value": 1911, + }, + { + "name": "download", + "range": "± 69", + "unit": "MS/s", + "value": 9001, + }, + ], + "commit": { + "author": null, + "committer": null, + "id": "123456789abcdef", + "message": "this is dummy", + "timestamp": "dummy timestamp", + "url": "https://github.com/dummy/repo", + }, + "date": 1712131503296, + "tool": "cargo", +} +`; + exports[`extractResult() extracts benchmark output from cargo - cargo_output2.txt 1`] = ` { "benches": [ diff --git a/test/data/extract/cargo_output_units.txt b/test/data/extract/cargo_output_units.txt new file mode 100644 index 000000000..8e09831cd --- /dev/null +++ b/test/data/extract/cargo_output_units.txt @@ -0,0 +1,9 @@ +test cmov ... bench: 2835 cycles/iter (+/- 14) + +test cmov2 ... bench: 2845 cycles/iter (+/- 19) + +test mov ... bench: 1508 cycles/iter (+/- 17) + +test upload ... bench: 1911 MS/s (+/- 420) + +test download ... bench: 9001 MS/s (+/- 69) \ No newline at end of file diff --git a/test/extract.spec.ts b/test/extract.spec.ts index 911e442b3..48a5c271a 100644 --- a/test/extract.spec.ts +++ b/test/extract.spec.ts @@ -71,6 +71,10 @@ describe('extractResult()', function () { tool: 'cargo', file: 'cargo_output3.txt', }, + { + tool: 'cargo', + file: 'cargo_output_units.txt', + }, { tool: 'cargo', file: 'criterion_output.txt', From 43715b209c1d5a1dd293360353e66479790fcae9 Mon Sep 17 00:00:00 2001 From: Afonso Tinoco Date: Wed, 27 Nov 2024 14:08:00 -0500 Subject: [PATCH 2/2] Fix lint --- src/extract.ts | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/extract.ts b/src/extract.ts index 011f55e55..ec7bc35e2 100644 --- a/src/extract.ts +++ b/src/extract.ts @@ -313,9 +313,6 @@ async function getCommit(githubToken?: string, ref?: string): Promise { function extractCargoResult(output: string): BenchmarkResult[] { const lines = output.split(/\r?\n/g); const ret = []; - // Example: - // test bench_fib_20 ... bench: 37,174.25 ns/iter (+/- 7,527.43) - const reExtract = /^test (.+)\s+\.\.\. bench:\s+([0-9,.]+) (\w+\/\w+) \(\+\/- ([0-9,.]+)\)$/; const reComma = /,/g;