Wie man Bencher in GitHub Actions verwendet
Je nach Anwendungsfall können Sie Continuous Benchmarking in GitHub Actions für Ihre:
Stellen Sie sicher, dass Sie ein API-Token erstellt haben und es als Repository-Geheimnis mit dem Namen BENCHER_API_TOKEN festgelegt haben, bevor Sie fortfahren!
Navigieren Sie zu Ihr Repo -> Einstellungen -> Geheimnisse und Variablen -> Aktionen -> Neues Repository-Geheimnis.
Benennen Sie das Geheimnis BENCHER_API_TOKEN und setzen Sie den Geheimniswert auf Ihr API-Token.
In GitHub Actions werden
Geheimnisse nicht an den Runner übergeben, wenn ein Workflow von einem geforkten Repository ausgelöst wird.
Daher müssen Sie einen Branch aus demselben Repository verwenden,
wenn Sie eines der untenstehenden Workflows mit einem Pull Request zu Ihrem Repository hinzufügen.
Wenn Sie versuchen, Bencher mit einem Pull Request von einem Fork hinzuzufügen,
dann wird das BENCHER_API_TOKEN-Geheimnis nicht verfügbar sein.
${{ secrets.BENCHER_API_TOKEN }} wird eine leere Zeichenfolge sein.
Basis-Branch
Ein Grundpfeiler des Statistical Continuous Benchmarking ist, eine historische Basislinie für Ihren Basis-Branch zu haben. Diese historische Basislinie kann dann verwendet werden, um Leistungsregressionen in Pull Requests zu erkennen.
on: push: branches: main
jobs: benchmark_base_branch: name: Continuous Benchmarking with Bencher permissions: checks: write runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: bencherdev/bencher@main - name: Track base branch benchmarks with Bencher run: | bencher run \ --project project-abc4567-wxyz123456789 \ --token '${{ secrets.BENCHER_API_TOKEN }}' \ --branch main \ --testbed ubuntu-latest \ --threshold-measure latency \ --threshold-test t_test \ --threshold-max-sample-size 64 \ --threshold-upper-boundary 0.99 \ --thresholds-reset \ --err \ --adapter json \ --github-actions '${{ secrets.GITHUB_TOKEN }}' \ bencher mock- Erstellen Sie eine
workflow-Datei für GitHub Actions. (z.B.:.github/workflows/base_benchmarks.yml) - Ausführen bei
push-Ereignissen zummain-Branch. Siehe die GitHub ActionsonDokumentation und die GitHub ActionspushDokumentation für einen vollständigen Überblick. (z.B.:on: push: branches: main) - Erstellen Sie einen
jobfür GitHub Actions. (z.B.:jobs: benchmark_base_branch) - Setzen Sie die Berechtigungen für das
GITHUB_TOKENaufwritefürchecks. (z.B.:permissions: checks: write) - Legen Sie den Maschinentyp fest, auf dem der Job ausgeführt wird.
Siehe die GitHub Actions
runs-onDokumentation für einen vollständigen Überblick. (z.B.:runs-on: ubuntu-latest) - Checken Sie Ihren Basis-Branch Quellcode aus.
(z.B.:
uses: actions/checkout@v4) - Installieren Sie die Bencher CLI mithilfe der GitHub Action.
(z.B.:
uses: bencherdev/bencher@main) - Verwenden Sie das
bencher runCLI-Unterkommando, um Ihremain-Branch Benchmarks auszuführen. Siehe dasbencher runCLI-Unterkommando für einen vollständigen Überblick. (z.B.:bencher run) - Setzen Sie die
--projectOption auf den Project-Slug. Siehe die--projectDoku für weitere Details. (z.B.:--project project-abc4567-wxyz123456789) - Setzen Sie die
--tokenOption auf das Repository-GeheimnisBENCHER_API_TOKEN. Siehe die--tokenDoku für weitere Details. (z.B.:--token '${{ secrets.BENCHER_API_TOKEN }}') - Setzen Sie die
--branchOption auf den Basis-Branch Namen. Siehe die--branchDoku für einen vollständigen Überblick. (z.B.:--branch main) - Setzen Sie die
--testbedOption auf den Testbed-Namen. Dies sollte wahrscheinlich mit der inruns-onausgewählten Maschine übereinstimmen. Siehe die--testbedDoku für weitere Details. (z.B.:--testbed ubuntu-latest) - Setzen Sie den Threshold für den
mainBranch,ubuntu-latestTestbed und daslatencyMaß:- Setzen Sie die
--threshold-measureOption auf das eingebautelatencyMeasure, das vonbencher mockgeneriert wird. Siehe die--threshold-measureDoku für weitere Details. (z.B.:--threshold-measure latency) - Setzen Sie die
--threshold-testOption auf einen Student’s t-Test (t_test). Siehe die--threshold-testDoku für einen vollständigen Überblick. (z.B.:--threshold-test t_test) - Setzen Sie die
--threshold-max-sample-sizeOption auf die maximale Stichprobengröße von64. Siehe die--threshold-max-sample-sizeDoku für weitere Details. (z.B.:--threshold-max-sample-size 64) - Setzen Sie die
--threshold-upper-boundaryOption auf die obere Grenze von0.99. Siehe die--threshold-upper-boundaryDoku für weitere Details. (z.B.:--threshold-upper-boundary 0.99) - Setzen Sie die
--thresholds-resetFlag, damit nur der angegebene Threshold aktiv ist. Siehe die--thresholds-resetDoku für einen vollständigen Überblick. (z.B.:--thresholds-reset)
- Setzen Sie die
- Setzen Sie die
--errFlag, damit der Befehl fehlschlägt, wenn ein Alert generiert wird. Siehe die--errDoku für einen vollständigen Überblick. (z.B.:--err) - Setzen Sie die
--adapterOption auf das Bencher Metric Format JSON (json), das vonbencher mockgeneriert wird. Siehe benchmark harness adapters für einen vollständigen Überblick. (z.B.:--adapter json) - Setzen Sie die
--github-actionsOption auf das GitHub API-Authentifizierungstoken, um Ergebnisse als GitHub Checks Kommentar zu posten, mithilfe der GitHub ActionsGITHUB_TOKENUmgebungsvariable. Siehe die--github-actionsDoku für weitere Details. (z.B.:--github-actions '${{ secrets.GITHUB_TOKEN }}') - Geben Sie die Argumente des Benchmark-Befehls an.
Siehe benchmark command für einen vollständigen Überblick.
(z.B.:
bencher mock)
Pull Requests
Um Performance-Regressionen in Pull Requests zu erfassen, müssen Sie Ihre Benchmarks auf PRs ausführen. Wenn Sie nur PRs von Branches innerhalb desselben Repositories erwarten, können Sie einfach einen weiteren Workflow erstellen, der bei pull_request-Ereignissen aus demselben Repository ausgeführt wird.
⚠️ Diese Lösung funktioniert nur, wenn alle PRs aus demselben Repository stammen! Siehe unten Pull Requests aus Forks.
on: pull_request: types: [opened, reopened, edited, synchronize]
jobs: benchmark_pr_branch: name: Continuous Benchmarking PRs with Bencher # DO NOT REMOVE: For handling Fork PRs see Pull Requests from Forks if: github.event_name == 'pull_request' && github.event.pull_request.head.repo.full_name == github.repository permissions: pull-requests: write runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: bencherdev/bencher@main - name: Track PR Benchmarks with Bencher run: | bencher run \ --project project-abc4567-wxyz123456789 \ --token '${{ secrets.BENCHER_API_TOKEN }}' \ --branch "$GITHUB_HEAD_REF" \ --start-point "$GITHUB_BASE_REF" \ --start-point-hash '${{ github.event.pull_request.base.sha }}' \ --start-point-clone-thresholds \ --start-point-reset \ --testbed ubuntu-latest \ --err \ --adapter json \ --github-actions '${{ secrets.GITHUB_TOKEN }}' \ bencher mock-
Erstellen Sie eine GitHub Actions
workflow-Datei. (z.B.:.github/workflows/pr_benchmarks.yml) -
Ausführung bei
pull_request-Ereignissen:opened- Ein Pull Request wurde erstellt.reopened- Ein zuvor geschlossener Pull Request wurde wieder geöffnet.edited- Der Titel oder Inhalt eines Pull Requests wurde bearbeitet, oder der Basis-Branch eines Pull Requests wurde geändert.synchronize- Der Head-Branch eines Pull Requests wurde aktualisiert. Beispielsweise wurde der Head-Branch vom Basis-Branch aktualisiert oder neue Commits wurden zum Head-Branch gepusht.
Siehe die GitHub Actions
onDokumentation und die GitHub Actionspull_requestDokumentation für einen vollständigen Überblick. (z.B.:on: pull_request: types: [opened, reopened, edited, synchronize]) -
Erstellen Sie einen GitHub Actions
job. (z.B.:jobs: benchmark_pr_branch) -
Laufen Sie bei
pull_request-Ereignissen, wenn und nur wenn der Pull Request aus demselben Repository stammt. ⚠️ ENTFERNEN SIE NICHT DIESE ZEILE! Für die Handhabung von Fork PRs siehe unten Pull Requests aus Forks. (z.B.:if: github.event_name == 'pull_request' && github.event.pull_request.head.repo.full_name == github.repository) -
Legen Sie die Berechtigungen für das
GITHUB_TOKENaufwritefürpull-requestsfest. Je nach Ihren GitHub-Einstellungen ist dies möglicherweise nicht erforderlich. Aber für alle Organisationen und persönlichen Repos erstellt nach dem 02. Feb 2023, ist dies das standardmäßige Verhalten. Sehen Sie die GitHub Dokumentation für einen vollständigen Überblick. (z.B.:permissions: pull-requests: write) -
Legen Sie die Art der Maschine fest, auf der der Job läuft. Siehe die GitHub Actions
runs-onDokumentation für einen vollständigen Überblick. (z.B.:runs-on: ubuntu-latest) -
Checken Sie den Quellcode des PR-Branches aus. (z.B.:
uses: actions/checkout@v4) -
Installieren Sie die Bencher CLI mithilfe der GitHub Action. (z.B.:
uses: bencherdev/bencher@main) -
Verwenden Sie den
bencher runCLI-Unterbefehl, um Ihre Pull Request-Branch-Benchmarks auszuführen. Siehe denbencher runCLI-Unterbefehl für einen vollständigen Überblick. (z.B.:bencher run) -
Setzen Sie die
--project-Option auf das Projekt-Slug. Siehe die--projectDokumentation für weitere Details. (z.B.:--project project-abc4567-wxyz123456789) -
Setzen Sie die
--token-Option auf das Repository-GeheimnisBENCHER_API_TOKEN. Siehe die--tokenDokumentation für weitere Details. (z.B.:--token '${{ secrets.BENCHER_API_TOKEN }}') -
Setzen Sie die
--branch-Option auf den PR-Branch-Namen unter Verwendung der GitHub ActionsGITHUB_HEAD_REFStandard-Umgebungsvariable. Siehe die--branchDokumentation für einen vollständigen Überblick. (z.B.:--branch "$GITHUB_HEAD_REF") -
Setzen Sie den Startpunkt für den PR-Branch:
- Setzen Sie die
--start-point-Option auf den Startpunkt des PR-Branches unter Verwendung der GitHub ActionsGITHUB_BASE_REFStandard-Umgebungsvariable. Siehe die--start-pointDokumentation für einen vollständigen Überblick. (z.B.:--start-point "$GITHUB_BASE_REF") - Setzen Sie die
--start-point-hash-Option auf dengitHash des PR-Branch Startpunkts unter Verwendung der GitHub Actionspull_requestEreignis. Siehe die--start-point-hashDokumentation für einen vollständigen Überblick. (z.B.:--start-point-hash '${{ github.event.pull_request.base.sha }}') - Setzen Sie das
--start-point-clone-thresholdsFlag, um die Thresholds vom Startpunkt zu klonen. Siehe die--start-point-clone-thresholdsDokumentation für einen vollständigen Überblick. (z.B.:--start-point-clone-thresholds) - Setzen Sie das
--start-point-resetFlag, um den PR-Branch immer auf den Startpunkt zurückzusetzen. Dies wird Datenverschiebungen bei Benchmarks verhindern. Siehe die--start-point-resetDokumentation für einen vollständigen Überblick. (z.B.:--start-point-reset)
- Setzen Sie die
-
Setzen Sie die
--testbed-Option auf den Namen des Testbeds. Dies sollte wahrscheinlich auf die inruns-onausgewählte Maschine abgestimmt sein. Siehe die--testedDokumentation für mehr Details. (z.B.:--testbed ubuntu-latest) -
Setzen Sie das
--errFlag, um den Befehl zu beenden, wenn ein Alarm generiert wird. Siehe die--errDokumentation für einen vollständigen Überblick. (z.B.:--err) -
Setzen Sie die
--adapter-Option auf Bencher Metric Format JSON (json), das vonbencher mockgeneriert wird. Siehe Benchmark-Harness-Adapter für einen vollständigen Überblick. (z.B.:--adapter json) -
Setzen Sie die
--github-actions-Option auf das GitHub API-Authentifizierungstoken, um Ergebnisse als Kommentar im Pull Request zu posten, unter Verwendung der GitHub ActionsGITHUB_TOKENUmgebungsvariable. Siehe die--github-actionsDokumentation für mehr Details. (z.B.:--github-actions '${{ secrets.GITHUB_TOKEN }}') -
Geben Sie die Argumente für den Benchmark-Befehl an. Siehe Benchmark Befehl für einen vollständigen Überblick. (z.B.:
bencher mock)
Um den PR-Branch zu bereinigen, nachdem sein PR geschlossen wurde,
können Sie einen separaten Workflow erstellen, der bei on pull_request-Ereignissen mit dem Typ closed ausgeführt wird.
Dieser Workflow archiviert den PR-Branch mit dem Befehl bencher archive.
on: pull_request: types: [closed]
jobs: archive_pr_branch: name: Archive closed PR branch with Bencher # DO NOT REMOVE: For handling Fork PRs see Pull Requests from Forks if: github.event_name == 'pull_request' && github.event.pull_request.head.repo.full_name == github.repository runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: bencherdev/bencher@main - name: Archive closed PR branch with Bencher run: | bencher archive \ --project project-abc4567-wxyz123456789 \ --token '${{ secrets.BENCHER_API_TOKEN }}' \ --branch "$GITHUB_HEAD_REF"-
Erstellen Sie eine GitHub Actions
workflow-Datei. (z.B.:.github/workflows/pr_benchmarks_closed.yml) -
Ausführen bei
pull_request-Ereignissen:closed- Ein Pull-Request wurde geschlossen.
Siehe die GitHub Actions
onDokumentation und die GitHub Actionspull_requestDokumentation für einen vollständigen Überblick. (z.B.:on: pull_request: types: [closed]) -
Erstellen Sie einen GitHub Actions
job. (z.B.:jobs: archive_pr_branch) -
Ausführen bei
pull_request-Ereignissen, wenn und nur wenn der Pull-Request aus demselben Repository stammt. ⚠️ ENTFERNEN SIE DIESE ZEILE NICHT! Für die Handhabung von Fork-PRs siehe Pull Requests from Forks unten. (z.B.:if: github.event_name == 'pull_request' && github.event.pull_request.head.repo.full_name == github.repository) -
Legen Sie den Typ der Maschine fest, auf der der Job ausgeführt wird. Siehe die GitHub Actions
runs-onDokumentation für einen vollständigen Überblick. (z.B.:runs-on: ubuntu-latest) -
Checken Sie den PR-Branch-Quellcode aus. (z.B.:
uses: actions/checkout@v4) -
Installieren Sie das Bencher CLI mit dem GitHub Action. (z.B.:
uses: bencherdev/bencher@main) -
Verwenden Sie den
bencher archiveCLI-Unterbefehl, um den PR-Branch zu archivieren. (z.B.:bencher archive) -
Setzen Sie die
--projectOption auf den Project-Slug. Siehe die--projectDoku für weitere Details. (z.B.:--project project-abc4567-wxyz123456789) -
Setzen Sie die
--tokenOption auf das Repository-GeheimnisBENCHER_API_TOKEN. Siehe die--tokenDoku für weitere Details. (z.B.:--token '${{ secrets.BENCHER_API_TOKEN }}') -
Setzen Sie die
--branchOption auf den PR-Branch-Namen unter Verwendung der GitHub ActionsGITHUB_HEAD_REFStandardumgebungsvariable. (z.B.:--branch "$GITHUB_HEAD_REF")
Pull-Requests aus Forks
Wenn Sie planen, Pull-Requests aus Forks zu akzeptieren, wie es in öffentlichen Open-Source-Projekten oft der Fall ist,
müssen Sie die Dinge ein wenig anders handhaben.
Aus Sicherheitsgründen sind Geheimnisse wie Ihr BENCHER_API_TOKEN und der GITHUB_TOKEN in GitHub Actions für Fork-PRs nicht verfügbar.
Das bedeutet, dass, wenn ein externer Mitwirkender einen PR aus einem Fork öffnet, das obige Beispiel nicht funktioniert.
Siehe dieses GitHub Security Lab Artikel
und diesen Blog-Beitrag
über die Verhinderung von schädlichen Anfragen für einen vollständigen Überblick.
Dies ist der sichere und empfohlene Weg, um Kontinuierliches Benchmarking zu Fork-Pull-Requests hinzuzufügen.
Es erfordert zwei separate Workflows.
Der erste Workflow läuft und speichert die Benchmark-Ergebnisse im pull_request-Kontext.
Keine Geheimnisse wie Ihr BENCHER_API_TOKEN und der GITHUB_TOKEN sind dort verfügbar.
Dann lädt ein zweiter Workflow die zwischengespeicherten Benchmark-Ergebnisse im workflow_run-Kontext herunter und lädt sie zu Bencher hoch.
Dies funktioniert, weil workflow_run im Kontext des Standard-Branches des Repositorys läuft,
wo Geheimnisse wie Ihr BENCHER_API_TOKEN und der GITHUB_TOKEN verfügbar sind.
Die Pull-Request-Nummer, der Head-Branch und der Base-Branch, die im anfänglichen pull_request-Workflow verwendet werden,
müssen ebenfalls explizit in den workflow_run-Workflow übergeben werden, da sie dort nicht verfügbar sind.
Diese Workflows werden nur ausgeführt, wenn sie im Standard-Branch existieren.
Siehe Verwenden von Daten aus dem auslösenden Workflow für einen vollständigen Überblick.
name: Run Benchmarks
on: pull_request: types: [opened, reopened, edited, synchronize]
jobs: benchmark_fork_pr_branch: name: Run Fork PR Benchmarks runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - name: Mock Benchmarking run: | /bin/echo '{ "bencher::mock_0": { "latency": { "value": 1.0 } } }' > benchmark_results.json - name: Upload Benchmark Results uses: actions/upload-artifact@v4 with: name: benchmark_results.json path: ./benchmark_results.json - name: Upload GitHub Pull Request Event uses: actions/upload-artifact@v4 with: name: event.json path: ${{ github.event_path }}-
Erstellen Sie eine erste GitHub Actions
workflow-Datei. (z.B.:.github/workflows/fork_pr_benchmarks_run.yml) -
Benennen Sie diesen Workflow, sodass er vom zweiten Workflow referenziert werden kann. (z.B.:
name: Run Benchmarks) -
Führen Sie diese bei
pull_request-Ereignissen aus:opened- Ein Pull-Request wurde erstellt.reopened- Ein zuvor geschlossener Pull-Request wurde wieder geöffnet.edited- Der Titel oder der Hauptteil eines Pull-Requests wurde bearbeitet oder der Basisbranch eines Pull-Requests wurde geändert.synchronize- Der Kopfbranch eines Pull-Requests wurde aktualisiert. Zum Beispiel wurde der Kopfbranch vom Basisbranch aktualisiert oder neue Commits wurden zum Kopfbranch hinzugefügt.
Siehe die GitHub Actions
on-Dokumentation und die GitHub Actionspull_request-Dokumentation für einen vollständigen Überblick. (z.B.:on: pull_request: types: [opened, reopened, edited, synchronize]) -
Erstellen Sie einen GitHub Actions
job. (z.B.:jobs: benchmark_fork_pr_branch) -
Legen Sie den Maschinentyp fest, auf dem der Job ausgeführt wird. Siehe die GitHub Actions
runs-on-Dokumentation für einen vollständigen Überblick. (z.B.:runs-on: ubuntu-latest) -
Überprüfen Sie den Quellcode des Fork PR Branch. (z.B.:
uses: actions/checkout@v4) -
Führen Sie Ihre Benchmarks durch und speichern Sie die Ergebnisse in einer Datei. (z.B.:
/bin/echo '{ ... }' > benchmark_results.json) -
Laden Sie die Benchmark-Ergebnisdatei als Artefakt hoch. (z.B.:
uses: actions/upload-artifact@v4) -
Laden Sie das
pull_request-Ereignisobjekt als Artefakt hoch. (z.B.:uses: actions/upload-artifact@v4)
name: Track Benchmarks with Bencher
on: workflow_run: workflows: [Run Benchmarks] types: [completed]
jobs: track_fork_pr_branch: if: github.event.workflow_run.conclusion == 'success' permissions: pull-requests: write runs-on: ubuntu-latest env: BENCHMARK_RESULTS: benchmark_results.json PR_EVENT: event.json steps: - name: Download Benchmark Results uses: dawidd6/action-download-artifact@v6 with: name: ${{ env.BENCHMARK_RESULTS }} run_id: ${{ github.event.workflow_run.id }} - name: Download PR Event uses: dawidd6/action-download-artifact@v6 with: name: ${{ env.PR_EVENT }} run_id: ${{ github.event.workflow_run.id }} - name: Export PR Event Data uses: actions/github-script@v6 with: script: | let fs = require('fs'); let prEvent = JSON.parse(fs.readFileSync(process.env.PR_EVENT, {encoding: 'utf8'})); core.exportVariable("PR_HEAD", prEvent.pull_request.head.ref); core.exportVariable("PR_HEAD_SHA", prEvent.pull_request.head.sha); core.exportVariable("PR_BASE", prEvent.pull_request.base.ref); core.exportVariable("PR_BASE_SHA", prEvent.pull_request.base.sha); core.exportVariable("PR_NUMBER", prEvent.number); - uses: bencherdev/bencher@main - name: Track Benchmarks with Bencher run: | bencher run \ --project project-abc4567-wxyz123456789 \ --token '${{ secrets.BENCHER_API_TOKEN }}' \ --branch "$PR_HEAD" \ --hash "$PR_HEAD_SHA" \ --start-point "$PR_BASE" \ --start-point-hash "$PR_BASE_SHA" \ --start-point-clone-thresholds \ --start-point-reset \ --testbed ubuntu-latest \ --err \ --adapter json \ --github-actions '${{ secrets.GITHUB_TOKEN }}' \ --ci-number "$PR_NUMBER" \ --file "$BENCHMARK_RESULTS"- Erstellen Sie eine erste GitHub Actions
Workflow-Datei. (z.B.:.github/workflows/fork_pr_benchmarks_track.yml) - Benennen Sie diesen Workflow als zweiten Workflow.
(z.B.:
name: Track Benchmarks with Bencher) - Verketten Sie die beiden Workflows mit
dem
workflow_runEvent. (z.B.:on: workflow_run: ...) - Erstellen Sie einen GitHub Actions
Job. (z.B.:jobs: track_fork_pr_branch) - Führen Sie diesen Job nur aus, wenn der Abschluss des vorherigen Workflows erfolgreich war, unter Verwendung
des GitHub Actions
workflow_runEvents. (z.B.:if: github.event.workflow_run.conclusion == 'success') - Setzen Sie die Berechtigungen für den
GITHUB_TOKENaufwritefürpull-requests. Abhängig von Ihren GitHub-Einstellungen ist dies möglicherweise nicht erforderlich. Aber für alle Organisationen und persönlichen Repositories die nach dem 02. Feb 2023 erstellt wurden, ist dies das Standardverhalten. Siehe die GitHub-Dokumentation für einen vollständigen Überblick. (z.B.:permissions: pull-requests: write) - Setzen Sie den Typ der Maschine, auf der der Job ausgeführt wird.
Siehe die GitHub Actions
runs-onDokumentation für einen vollständigen Überblick. (z.B.:runs-on: ubuntu-latest) - Setzen Sie die Benchmark-Ergebnisse und die Dateinamen des
pull_requestEvent-Objekts als Umgebungsvariablen. (z.B.:env: ...) - Laden Sie die zwischengespeicherten Benchmark-Ergebnisse und das
pull_requestEvent herunter unter Verwendung der GitHub Actionaction-download-artifact. (z.B.:uses: dawidd6/action-download-artifact@v6) - Exportieren Sie die notwendigen Daten vom
pull_requestEvent als Zwischen-Umgebungsvariablen. (z.B.:core.exportVariable(...)) - Installieren Sie das Bencher CLI unter Verwendung der GitHub Action.
(z.B.:
uses: bencherdev/bencher@main) - Verwenden Sie den
bencher runCLI-Unterbefehl, um die Benchmarks Ihrer Fork-Pull-Branch zu verfolgen. Siehe denbencher runCLI-Unterbefehl für einen vollständigen Überblick. (z.B.:bencher run) - Setzen Sie die
--projectOption auf den Projektschlüssel. Siehe die--projectDokumentation für weitere Details. (z.B.:--project project-abc4567-wxyz123456789) - Setzen Sie die
--tokenOption auf das Repository-GeheimnisBENCHER_API_TOKEN. Siehe die--tokenDokumentation für weitere Details. (z.B.:--token '${{ secrets.BENCHER_API_TOKEN }}') - Setzen Sie die
--branchOption auf den Namen des Fork-PR-Branches unter Verwendung einer Zwischen-Umgebungsvariable. Siehe die--branchDokumentation für einen vollständigen Überblick. (z.B.:--branch "$PR_HEAD") - Setzen Sie die
--hashOption auf dengit-Hash des Fork-PR-Branches unter Verwendung einer Zwischen-Umgebungsvariable. Siehe die--hashDokumentation für einen vollständigen Überblick. (z.B.:--hash "$PR_HEAD_SHA") - Setzen Sie den Startpunkt für den Fork-PR-Branch:
- Setzen Sie die
--start-pointOption auf den Startpunkt des Fork-PR-Branches unter Verwendung einer Zwischen-Umgebungsvariable. Siehe die--start-pointDokumentation für einen vollständigen Überblick. (z.B.:--start-point "$PR_BASE") - Setzen Sie die
--start-point-hashOption auf dengit-Hash des Startpunktes vom Fork-PR-Branch unter Verwendung einer Zwischen-Umgebungsvariable. Siehe die--start-point-hashDokumentation für einen vollständigen Überblick. (z.B.:--start-point-hash "$PR_BASE_SHA") - Setzen Sie die
--start-point-clone-thresholdsFlagge, um die Schwellenwerte vom Startpunkt zu klonen. Siehe die--start-point-clone-thresholdsDokumentation für einen vollständigen Überblick. (z.B.:--start-point-clone-thresholds) - Setzen Sie die
--start-point-resetFlagge, um den Fork-PR-Branch immer zum Startpunkt zurückzusetzen. Dies verhindert ein Drift der Benchmark-Daten. Siehe die--start-point-resetDokumentation für einen vollständigen Überblick. (z.B.:--start-point-reset)
- Setzen Sie die
- Setzen Sie die
--testbedOption auf den Namen des Testbed. Dies sollte vermutlich mit der inruns-onausgewählten Maschine übereinstimmen. Siehe die--testedDokumentation für weitere Details. (z.B.:--testbed ubuntu-latest) - Setzen Sie die
--errFlagge, um den Befehl fehlschlagen zu lassen, wenn ein Alarm erzeugt wird. Siehe die--errDokumentation für einen vollständigen Überblick. (z.B.:--err) - Setzen Sie die
--adapterOption auf Bencher Metric Format JSON (json), das vonbencher mockerzeugt wird. Siehe Benchmark-Harness-Adapter für einen vollständigen Überblick. (z.B.:--adapter json) - Setzen Sie die
--github-actionsOption auf das GitHub API-Authentifizierungstoken, um Ergebnisse als Kommentar im Pull Request zu posten, unter Verwendung derGITHUB_TOKENUmgebungsvariable der GitHub Actions. Siehe die--github-actionsDokumentation für weitere Details. (z.B.:--github-actions '${{ secrets.GITHUB_TOKEN }}') - Setzen Sie die
--ci-numberOption auf die Nummer des Pull Requests unter Verwendung einer Zwischen-Umgebungsvariable. Siehe die--ci-numberDokumentation für weitere Details. (z.B.:--ci-number "$PR_NUMBER") - Setzen Sie die
--fileOption auf den Dateipfad der Benchmark-Ergebnisse. Siehe Benchmark-Befehl für einen vollständigen Überblick. (z.B.:--file "$BENCHMARK_RESULTS")
Um den Fork-PR-Branch zu bereinigen, nachdem sein PR geschlossen wurde,
können Sie einen separaten Workflow erstellen, der bei on pull_request_target-Ereignissen mit dem Typ closed ausgeführt wird.
Dieser Workflow archiviert den Fork-PR-Branch mit dem Befehl bencher archive.
on: pull_request_target: types: [closed]
jobs: archive_fork_pr_branch: name: Archive closed fork PR branch with Bencher runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: bencherdev/bencher@main - name: Archive closed fork PR branch with Bencher run: | bencher archive \ --project project-abc4567-wxyz123456789 \ --token '${{ secrets.BENCHER_API_TOKEN }}' \ --branch "$GITHUB_HEAD_REF"-
Erstellen Sie eine GitHub Actions
workflow-Datei. (z.B.:.github/workflows/fork_pr_benchmarks_closed.yml) -
Ausführen bei
pull_request_target-Ereignissen:closed- Ein Pull-Request wurde geschlossen.
Siehe die GitHub Actions
onDokumentation und GitHub Actionspull_request_targetDokumentation für einen vollständigen Überblick. (z.B.:on: pull_request_target: types: [closed]) -
Erstellen Sie einen GitHub Actions
job. (z.B.:jobs: archive_pr_branch) -
Legen Sie den Maschinentyp fest, auf dem der Job ausgeführt wird. Siehe die GitHub Actions
runs-onDokumentation für einen vollständigen Überblick. (z.B.:runs-on: ubuntu-latest) -
Checken Sie den Quellcode des PR-Branches aus. (z.B.:
uses: actions/checkout@v4) -
Installieren Sie die Bencher CLI mit der GitHub Action. (z.B.:
uses: bencherdev/bencher@main) -
Verwenden Sie den
bencher archiveCLI-Unterbefehl, um den PR-Branch zu archivieren. (z.B.:bencher archive) -
Setzen Sie die
--projectOption auf den Projektslug. Siehe die--projectDokumentation für weitere Details. (z.B.:--project project-abc4567-wxyz123456789) -
Setzen Sie die
--tokenOption auf das Repository-GeheimnisBENCHER_API_TOKEN. Siehe die--tokenDokumentation für weitere Details. (z.B.:--token '${{ secrets.BENCHER_API_TOKEN }}') -
Setzen Sie die
--branchOption auf den PR-Branch-Namen unter Verwendung der GitHub ActionsGITHUB_HEAD_REFStandard-Umgebungsvariable. (z.B.:--branch "$GITHUB_HEAD_REF")
🐰 Glückwunsch! Sie haben gelernt, wie man Bencher in GitHub Actions verwendet! 🎉