load-tests #8
This file contains hidden or 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
name: load-tests | |
on: | |
push: | |
tags: | |
- "v[0-9]+.[0-9]+.[0-9]+*" | |
workflow_dispatch: | |
schedule: | |
- cron: "27 0,12 * * *" # Run at 00:27 and 12:27 UTC every day. | |
# Do not cancel this workflow on main. See https://github.com/open-telemetry/opentelemetry-collector-contrib/pull/16616 | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | |
cancel-in-progress: true | |
env: | |
# Make sure to exit early if cache segment download times out after 2 minutes. | |
# We limit cache download as a whole to 5 minutes. | |
SEGMENT_DOWNLOAD_TIMEOUT_MINS: 2 | |
permissions: read-all | |
jobs: | |
setup-environment: | |
timeout-minutes: 30 | |
runs-on: equinix-bare-metal | |
if: ${{ github.actor != 'dependabot[bot]' }} | |
outputs: | |
loadtest_matrix: ${{ steps.splitloadtest.outputs.loadtest_matrix }} | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5 | |
with: | |
go-version: 1.23.10 | |
cache: false | |
- name: Cache Go | |
id: go-cache | |
timeout-minutes: 5 | |
uses: actions/cache@5a3ec84eff668545956fd18022155c47e93e2684 # v4 | |
with: | |
path: | | |
~/go/bin | |
~/go/pkg/mod | |
~/.cache/go-build | |
key: loadtest-${{ runner.os }}-go-${{ hashFiles('**/go.sum') }} | |
- name: Install Dependencies | |
if: steps.go-cache.outputs.cache-hit != 'true' | |
run: make -j2 gomoddownload | |
- name: Install Tools | |
if: steps.go-cache.outputs.cache-hit != 'true' | |
run: make install-tools | |
- run: make genoteltestbedcol | |
- run: make oteltestbedcol | |
- name: Upload Testbed Binaries | |
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4 | |
with: | |
name: testbed-binaries | |
path: ./bin/* | |
- name: Split Loadtest Jobs | |
id: splitloadtest | |
run: ./.github/workflows/scripts/setup_e2e_tests.sh | |
loadtest: | |
runs-on: equinix-bare-metal | |
needs: [setup-environment] | |
strategy: | |
fail-fast: false | |
matrix: ${{ fromJson(needs.setup-environment.outputs.loadtest_matrix) }} | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5 | |
with: | |
go-version: 1.23.10 | |
cache: false | |
- name: Cache Go | |
id: go-cache | |
timeout-minutes: 5 | |
uses: actions/cache@5a3ec84eff668545956fd18022155c47e93e2684 # v4 | |
with: | |
path: | | |
~/go/bin | |
~/go/pkg/mod | |
~/.cache/go-build | |
key: loadtest-${{ runner.os }}-go-${{ hashFiles('**/go.sum') }} | |
- name: Install Dependencies | |
if: steps.go-cache.outputs.cache-hit != 'true' | |
run: make -j2 gomoddownload | |
- name: Install Tools | |
if: steps.go-cache.outputs.cache-hit != 'true' | |
run: make install-tools | |
- run: mkdir -p results && touch results/TESTRESULTS.md | |
- name: Download Testbed Binaries | |
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4 | |
with: | |
name: testbed-binaries | |
path: bin/ | |
- run: chmod +x bin/* | |
- name: Loadtest | |
run: make -C testbed run-tests | |
env: | |
TEST_ARGS: "-test.run=${{ matrix.test }}" | |
- name: Set results filename | |
if: ${{ failure() || success() }} | |
id: filename | |
run: echo "name=$(echo '${{ matrix.test }}' | sed -e 's/|/_/g')" >> $GITHUB_OUTPUT | |
- name: Create Test Result Archive | |
if: ${{ failure() || success() }} | |
continue-on-error: true | |
run: tar -cvf test_results_${{steps.filename.outputs.name}}.tar testbed/tests/results | |
- name: Upload Test Results | |
if: ${{ failure() || success() }} | |
continue-on-error: true | |
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4 | |
with: | |
name: test-result-archive-${{steps.filename.outputs.name}} | |
path: ./*.tar | |
- run: cp testbed/tests/results/benchmarks.json testbed/tests/results/${{steps.filename.outputs.name}}.json | |
- name: Upload benchmarks.json | |
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4 | |
with: | |
name: benchmark-results-${{steps.filename.outputs.name}} | |
path: testbed/tests/results/${{steps.filename.outputs.name}}.json | |
update-benchmarks: | |
runs-on: ubuntu-24.04 | |
needs: [loadtest] | |
permissions: | |
# deployments permission to deploy GitHub pages website | |
deployments: write | |
# contents permission to update benchmark contents in gh-pages branch | |
contents: write | |
if: github.event_name != 'pull_request' | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
- uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4 | |
with: | |
pattern: benchmark-results-* | |
merge-multiple: true | |
path: results | |
- run: jq -s 'map(.[])' results/*.json > output.json | |
- uses: benchmark-action/github-action-benchmark@d48d326b4ca9ba73ca0cd0d59f108f9e02a381c7 # v1 | |
with: | |
tool: "customSmallerIsBetter" | |
output-file-path: output.json | |
gh-pages-branch: benchmarks | |
max-items-in-chart: 100 | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
benchmark-data-dir-path: "docs/benchmarks/loadtests" | |
auto-push: true |