mrrc 0.8.2

A Rust library for reading, writing, and manipulating MARC bibliographic records in ISO 2709 binary format
Documentation
name: "Benchmarks: Python"

on:
  push:
    branches: [main]
    paths-ignore:
      - '**.md'
      - 'docs/**'
      - 'mkdocs.yml'
      - 'LICENSE'
      - '.gitignore'
      - '.beads/**'
  pull_request:
    branches: [main]
    paths-ignore:
      - '**.md'
      - 'docs/**'
      - 'mkdocs.yml'
      - 'LICENSE'
      - '.gitignore'
      - '.beads/**'

concurrency:
  group: ${{ github.workflow }}-${{ github.ref }}
  cancel-in-progress: true

jobs:
  codspeed:
    name: Codspeed Performance Regression Detection
    runs-on: ubuntu-22.04  # CodSpeed only supports Ubuntu 20.04/22.04
    timeout-minutes: 30
    # Dependency bumps don't need the CodSpeed perf gate; skip for dependabot.
    if: github.actor != 'dependabot[bot]'
    steps:
      - uses: actions/checkout@v6.0.3

      - name: Set up Python
        uses: actions/setup-python@v6
        with:
          python-version: "3.12"

      - name: Install Rust
        uses: dtolnay/rust-toolchain@stable

      - name: Install uv
        uses: astral-sh/setup-uv@v8.1.0

      - name: Build mrrc wheel
        uses: PyO3/maturin-action@v1
        with:
          manylinux: off
          args: --release --out dist

      - name: Install mrrc and dependencies
        run: |
          uv pip install --system --no-index --find-links dist mrrc
          uv pip install --system pytest pytest-benchmark pytest-codspeed

      - name: Run benchmarks with Codspeed (1k/10k only)
        uses: CodSpeedHQ/action@v4.17.0
        with:
          # NOTE: Only enabled if CODSPEED_TOKEN is set as a repo secret
          token: ${{ secrets.CODSPEED_TOKEN }}
          # Simulation mode measures instruction counts under Valgrind:
          # deterministic on standard runners, unlike walltime, which cannot
          # distinguish real regressions from runner-speed variance.
          mode: simulation
          # Parallel-throughput benchmarks are excluded: Valgrind serializes
          # threads, so multi-threaded speedup cannot be measured under
          # simulation. Measure parallel throughput with real walltime runs
          # on controlled hardware instead.
          # Note: Don't use --benchmark-only here; CodSpeed handles benchmarks differently
          run: >-
            pytest tests/python/ -m "benchmark and not slow" -v
            --ignore=tests/python/test_benchmark_parallel.py
            --ignore=tests/python/test_benchmark_pipeline_parallel.py