-
Notifications
You must be signed in to change notification settings - Fork 21
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
## Limitations * **Statistical outliers:** Caused by other jobs still running in parallel. The current workaround is to re-run the job. To completely fix this however, this benchmark must be set to be after all other jobs have been completed, which requires touching other workflows. * **No windows:** Executing this on Windows CI is just too hard: cannot use powershell because of execution policy, and cannot use bash because it points to WSL which causes error. * **No macOS:** The benchmark values are too chaotic and unreliable. * **No clean install yet:** It's too slow.
- Loading branch information
Showing
7 changed files
with
198 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
name: Cargo B(inary)Install | ||
|
||
description: Install binaries with cargo-binstall | ||
|
||
inputs: | ||
packages: | ||
description: List of arguments to pass to `cargo binstall` | ||
required: true | ||
|
||
runs: | ||
using: composite | ||
|
||
steps: | ||
- name: Install cargo-binstall | ||
uses: taiki-e/install-action@cargo-binstall | ||
|
||
- name: Running cargo-binstall with provided arguments | ||
shell: bash | ||
run: cargo binstall --no-confirm ${{ inputs.packages }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,152 @@ | ||
name: Integrated-Benchmark | ||
|
||
on: | ||
workflow_dispatch: | ||
pull_request: | ||
types: [opened, synchronize] | ||
|
||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} | ||
cancel-in-progress: true | ||
|
||
permissions: | ||
issues: write | ||
pull-requests: write | ||
|
||
jobs: | ||
benchmark: | ||
strategy: | ||
max-parallel: 1 | ||
matrix: | ||
os: [ubuntu-latest] # windows is skipped because of complexity, macos is skipped because of inconsistency | ||
name: Run benchmark on ${{ matrix.os }} | ||
runs-on: ${{ matrix.os }} | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
|
||
- name: Make main branch visible | ||
shell: bash | ||
run: | | ||
subsection() { | ||
echo >&2 | ||
echo -e "\033[0;33m$*\033[0m" >&2 | ||
} | ||
subsection 'Configuring git...' | ||
git config --global advice.detachedHead false | ||
subsection 'Checking out main branch...' | ||
git checkout main | ||
git log --oneline -n 3 | ||
subsection 'Switching back...' | ||
git checkout - | ||
git log --oneline -n 3 | ||
subsection 'Inspecting branches...' | ||
git branch | ||
- name: Cache verdaccio | ||
uses: actions/cache@v3 | ||
with: | ||
key: integrated-benchmark-verdaccio | ||
path: | | ||
~/.local/share/verdaccio/storage | ||
timeout-minutes: 1 | ||
continue-on-error: true | ||
|
||
- name: Cache Rust builds | ||
uses: actions/cache@v3 | ||
with: | ||
key: integrated-benchmark-builds-${{ matrix.os }} | ||
path: | | ||
~/.cargo/registry | ||
~/.cargo/git | ||
target | ||
bench-work-env/*/pacquet/target | ||
timeout-minutes: 1 | ||
continue-on-error: true | ||
|
||
- name: Install Rust Toolchain | ||
uses: ./.github/actions/rustup | ||
with: | ||
shared-key: integrated-benchmark | ||
restore-cache: false # it's insufficient | ||
save-cache: false # it's insufficient | ||
|
||
- name: Install pnpm | ||
uses: pnpm/action-setup@v2 | ||
with: | ||
version: 8 | ||
run_install: false | ||
standalone: true | ||
|
||
- name: Cache pnpm | ||
uses: actions/cache@v3 | ||
with: | ||
key: integrated-benchmark-pnpm | ||
path: | | ||
${{ env.PNPM_HOME }}/store/v3 | ||
timeout-minutes: 1 | ||
continue-on-error: true | ||
|
||
- name: Install verdaccio | ||
run: pnpm install --global verdaccio | ||
|
||
- name: Install hyperfine | ||
uses: ./.github/actions/binstall | ||
with: | ||
packages: [email protected] | ||
|
||
- name: Build the benchmark executor | ||
run: cargo build --bin=integrated-benchmark | ||
|
||
- name: 'Benchmark: Frozen Lockfile' | ||
shell: bash | ||
run: | | ||
cargo run --bin=integrated-benchmark -- --scenario=frozen-lockfile --verdaccio HEAD main | ||
cp bench-work-env/BENCHMARK_REPORT.md bench-work-env/BENCHMARK_REPORT_FROZEN_LOCKFILE.md | ||
# - name: 'Benchmark: Clean Install' | ||
# shell: bash | ||
# run: | | ||
# cargo run --bin=integrated-benchmark -- --scenario=clean-install --verdaccio HEAD main | ||
# cp bench-work-env/BENCHMARK_REPORT.md bench-work-env/BENCHMARK_REPORT_CLEAN_INSTALL.md | ||
|
||
- name: Generate summary | ||
shell: bash | ||
run: | | ||
( | ||
echo '## Integrated-Benchmark Report (${{ runner.os }})' | ||
echo | ||
echo '### Scenario: Frozen Lockfile' | ||
echo | ||
cat bench-work-env/BENCHMARK_REPORT_FROZEN_LOCKFILE.md | ||
# echo | ||
# echo '### Scenario: Clean Install' | ||
# echo | ||
# cat bench-work-env/BENCHMARK_REPORT_CLEAN_INSTALL.md | ||
) > bench-work-env/SUMMARY.md | ||
- name: Find Comment | ||
# Check if the event is not triggered by a fork | ||
if: github.event.pull_request.head.repo.full_name == github.repository | ||
uses: peter-evans/find-comment@v2 | ||
id: fc | ||
with: | ||
issue-number: ${{ github.event.pull_request.number }} | ||
comment-author: 'github-actions[bot]' | ||
body-includes: Integrated-Benchmark Report (${{ runner.os }}) | ||
|
||
- name: Create or update comment | ||
# Check if the event is not triggered by a fork | ||
if: github.event.pull_request.head.repo.full_name == github.repository | ||
uses: peter-evans/create-or-update-comment@v3 | ||
with: | ||
issue-number: ${{ github.event.pull_request.number }} | ||
edit-mode: replace | ||
comment-id: ${{ steps.fc.outputs.comment-id }} | ||
body-file: bench-work-env/SUMMARY.md |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,3 +3,4 @@ | |
node_modules | ||
.npmrc | ||
/bench-work-env | ||
*.tmp |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters