From e643230be0a814c57d48bf99fee8a137405470b9 Mon Sep 17 00:00:00 2001 From: OmarTawfik <15987992+OmarTawfik@users.noreply.github.com> Date: Thu, 9 Jan 2025 09:37:04 -0800 Subject: [PATCH] allow benchmark dry-runs in CI --- .github/workflows/benchmark.yml | 14 ++++++++++---- crates/infra/cli/src/utils.rs | 2 +- 2 files changed, 11 insertions(+), 5 deletions(-) diff --git a/.github/workflows/benchmark.yml b/.github/workflows/benchmark.yml index db25036c06..5eb26b794c 100644 --- a/.github/workflows/benchmark.yml +++ b/.github/workflows/benchmark.yml @@ -3,7 +3,13 @@ name: "benchmark" on: # Run using manual triggers from GitHub UI: # https://docs.github.com/en/actions/managing-workflow-runs/manually-running-a-workflow - workflow_dispatch: {} + workflow_dispatch: + inputs: + dryRun: + description: "Attempt a local run and report results here, without updating the bencher dashboard." + type: "boolean" + required: true + default: true # Run on pushes to 'main' branch: push: @@ -19,8 +25,8 @@ jobs: benchmark: runs-on: "ubuntu-22.04" # _SLANG_DEV_CONTAINER_BASE_IMAGE_ (keep in sync) - # Only run on the main repo (not forks): - if: "${{ github.repository == 'NomicFoundation/slang' }}" + # Only run on the main repo (not forks), unless it is a dry run: + if: "${{ github.repository == 'NomicFoundation/slang' || inputs.dryRun == true }}" steps: - name: "Checkout Repository" @@ -48,7 +54,7 @@ jobs: - name: "infra perf benchmark" uses: "./.github/actions/devcontainer/run" with: - runCmd: "./scripts/bin/infra perf benchmark" + runCmd: "./scripts/bin/infra perf benchmark ${{ inputs.dryRun == true && '--dry-run' || '' }}" env: | BENCHER_API_TOKEN=${{ secrets.BENCHER_API_TOKEN }} diff --git a/crates/infra/cli/src/utils.rs b/crates/infra/cli/src/utils.rs index e308537429..b50638c094 100644 --- a/crates/infra/cli/src/utils.rs +++ b/crates/infra/cli/src/utils.rs @@ -40,7 +40,7 @@ impl ClapExtensions for T { #[derive(Clone, Copy, Debug, Parser)] pub struct DryRun { - /// Attempt a dry run, instead of actually executing the command. + /// Attempt a local run and report results, without publishing any user-facing artifacts. #[arg(long)] dry_run: bool, }