Skip to content

Rewrite transaction code, to make it easier to move to client #606

Rewrite transaction code, to make it easier to move to client

Rewrite transaction code, to make it easier to move to client #606

Workflow file for this run

name: Benchmark PR vs main
on:
workflow_dispatch:
pull_request:
branches:
- main
paths:
- '**.swift'
- '**.yml'
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}-benchmark
cancel-in-progress: true
env:
ENABLE_VALKEY_BENCHMARKS: true
jobs:
benchmark-delta:
runs-on: ${{ matrix.os }}
timeout-minutes: 15
continue-on-error: true
permissions:
issues: write
pull-requests: write
contents: read
strategy:
matrix:
os: [ubuntu-latest]
image: ["swift:6.1"]
container:
image: ${{ matrix.image }}
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install jemalloc
run: |
apt-get -q update
apt-get install -y libjemalloc-dev
# https://github.com/actions/checkout/issues/766
- name: Mark the workspace as safe
run: git config --global --add safe.directory ${GITHUB_WORKSPACE}
- name: Miscellaneous
run: |
[ -d Benchmarks ] && echo "hasBenchmark=1" >> $GITHUB_ENV
echo "/opt/homebrew/bin:/usr/local/bin" >> $GITHUB_PATH
- name: Run benchmarks for PR branch
if: ${{ env.hasBenchmark == '1' }}
run: |
swift package --allow-writing-to-directory .benchmarkBaselines/ benchmark baseline update pull_request
- name: Checkout main
run: |
git checkout main
- name: Run benchmarks for branch 'main'
if: ${{ env.hasBenchmark == '1' }}
run: |
swift package --allow-writing-to-directory .benchmarkBaselines/ benchmark baseline update main
- name: Compare PR and main
if: ${{ env.hasBenchmark == '1' }}
id: benchmark
run: |
set +e
# if we had access to fd 3 we could do this in one call eg { var=$(cmd 3>&2 2>&1 1>&3); } 2>&1
# but unfortunately we don't so we have to run the baseline check twice once to extract stdout
# and once to extract stderr
BENCHMARK_STDERR=$(swift package benchmark baseline check main pull_request 2>&1)
echo "exit-status=$?" >> $GITHUB_OUTPUT
echo "benchmark-error=$(echo -e "$BENCHMARK_STDERR" | grep -e "^error: .*" | tail -n 1 | cut -c 8-)" >> $GITHUB_OUTPUT
set -e
- name: Pull request comment text
id: benchmark-comment
run: |
EXIT_CODE='${{steps.benchmark.outputs.exit-status}}'
case "${EXIT_CODE}" in
0)
echo "_✅ Pull request no significant performance differences ✅_" >> comment.md
echo "exitStatus=0" >> $GITHUB_ENV
;;
*)
# Get error string from benchmark output
BENCHMARK_ERROR='${{steps.benchmark.outputs.benchmark-error}}'
case "${BENCHMARK_ERROR}" in
"benchmarkThresholdRegression")
echo "_❌ Pull request has performance regressions ❌_" >> comment.md
echo "exitStatus=1" >> $GITHUB_ENV
;;
"benchmarkThresholdImprovement")
echo "_✅ Pull request has performance improvements ✅_" >> comment.md
echo "exitStatus=0" >> $GITHUB_ENV
;;
*)
echo "_❌ Benchmark comparison failed with error $BENCHMARK_ERROR ❌_" >> comment.md
echo "exitStatus=1" >> $GITHUB_ENV
;;
esac
;;
esac
set +e
echo "<details><summary>Summary</summary>" >> comment.md
swift package benchmark baseline check main pull_request --format markdown >> comment.md
echo "</details><details><summary>Full Benchmark Comparison</summary>" >> comment.md
swift package benchmark baseline compare main pull_request --no-progress --quiet --format markdown >> comment.md
echo "</details>" >> comment.md
set -e
- name: Comment PR
if: ${{ env.hasBenchmark == '1' }}
uses: thollander/actions-comment-pull-request@v3
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
file-path: comment.md
comment-tag: benchmark
- name: Exit with correct status
run: |
exit ${{env.exitStatus}}