Skip to content

Commit

Permalink
ci: Benchmark with CodSpeed.io (#187)
Browse files Browse the repository at this point in the history
Experimentally replace the
[bencher.dev](https://bencher.dev/perf/portgraph) CI with
[codspeed's](https://codspeed.io/CQCL/portgraph).

On first review I had overlooked codspeed's criterion wrapper that
replaces the multi-run benchmarks with a single-run equivalent, similar
to iai's.
  • Loading branch information
aborgna-q authored Feb 18, 2025
1 parent aebb42e commit b0c0cfc
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 75 deletions.
20 changes: 0 additions & 20 deletions .github/workflows/archive-bencher.yml

This file was deleted.

62 changes: 12 additions & 50 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ jobs:
run: cargo miri test

benches:
name: continuous Benchmarking
name: continuous benchmarking
# Not required, we can ignore it for the merge queue check.
if: github.event_name != 'merge_group'
runs-on: ubuntu-latest
Expand All @@ -67,56 +67,18 @@ jobs:
- uses: Swatinem/rust-cache@v2
with:
prefix-key: v0

# The installed iai-callgrind-runner version must match the
# version of iai-callgrind in the Cargo.toml
- uses: cargo-bins/cargo-binstall@main
- name: Install iai-callgrind-runner
run: |
version=$(cargo metadata --format-version=1 |\
jq '.packages[] | select(.name == "iai-callgrind").version' |\
tr -d '"'
)
cargo binstall --no-confirm iai-callgrind-runner --version $version --force
- uses: bencherdev/bencher@main
- name: Install valgrind
run: sudo apt update && sudo apt install -y valgrind

- name: Track base branch IAI benchmarks
if: github.event_name == 'push'
run: |
bencher run \
--project portgraph \
--token '${{ secrets.BENCHER_API_TOKEN }}' \
--branch main \
--testbed ubuntu-latest \
--threshold-measure instructions \
--threshold-test t_test \
--threshold-max-sample-size 64 \
--threshold-upper-boundary 0.99 \
--thresholds-reset \
--err \
--github-actions '${{ secrets.HUGRBOT_PAT }}' \
--adapter rust_iai_callgrind \
"cargo bench --bench iai_benches"
- name: Track PR IAI benchmarks
if: github.event_name == 'pull_request'
run: |
bencher run \
--project portgraph \
--token '${{ secrets.BENCHER_API_TOKEN }}' \
--branch "${{ github.event.pull_request.head.ref }}" \
--testbed ubuntu-latest \
--start-point "${{ github.event.pull_request.base.ref }}" \
--start-point-clone-thresholds \
--start-point-reset \
--err \
--github-actions '${{ secrets.HUGRBOT_PAT }}' \
--adapter rust_iai_callgrind \
"cargo bench --bench iai_benches"
# --start-point-hash '${{ github.event.pull_request.base.sha }}' \
- name: Install cargo-codspeed
run: cargo binstall cargo-codspeed --force
- name: Override criterion with the CodSpeed harness
run: cargo add --dev codspeed-criterion-compat --rename criterion
- name: Build benchmarks
run: cargo codspeed build criterion_benches --profile bench
- name: Run benchmarks
uses: CodSpeedHQ/action@v3
with:
token: ${{ secrets.CODSPEED_TOKEN }}
run: "cargo codspeed run criterion_benches"

tests:
runs-on: ubuntu-latest
Expand Down
10 changes: 7 additions & 3 deletions DEVELOPMENT.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,11 +59,15 @@ This is the simplest kind of benchmark. To run the, use:
cargo bench --bench criterion_benches
```

We run these on CI to track historical performance using a special single-shot test harness,
and upload them to [codspeed.io](https://codspeed.io/CQCL/portgraph).

### Single-shot benchmarking

These benchmarks are useful when running in noisy environments, in addition to
being faster than criterion. We run these on CI to track historical performance
in [bencher.dev](https://bencher.dev/perf/portgraph).
We use [`iai-callgrind`](https://iai-callgrind.github.io/iai-callgrind) for
single-shot benchmarking, measuring instruction counts rather than wall-clock
time. These benchmarks are more precise when running in noisy environments, in
addition to being faster than criterion.

To run these, you must have [`valgrind`](https://valgrind.org/) installed.
Support for Apple Silicon (M1/M2/...) macs is
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ portgraph
[![crates][]](https://crates.io/crates/portgraph)
[![msrv][]](https://github.com/CQCL/portgraph)
[![codecov][]](https://codecov.io/gh/CQCL/portgraph)
[![bencher][]](https://bencher.dev/perf/portgraph)
[![codspeed][]](https://codspeed.io/CQCL/portgraph)

Data structure library for directed graphs with first-level ports. Includes
secondary data structures for node and port weights, and node hierarchies.
Expand Down Expand Up @@ -38,5 +38,5 @@ This project is licensed under Apache License, Version 2.0 ([LICENSE][] or http:
[LICENSE]: LICENCE
[msrv]: https://img.shields.io/badge/rust-1.75.0%2B-blue.svg?maxAge=3600
[codecov]: https://img.shields.io/codecov/c/gh/CQCL/portgraph?logo=codecov
[bencher]: https://img.shields.io/badge/bencher-.dev-blue.svg?logo=
[codspeed]: https://img.shields.io/endpoint?url=https://codspeed.io/badge.json
[CHANGELOG]: CHANGELOG.md

0 comments on commit b0c0cfc

Please sign in to comment.