test pr #10
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
name: Benchmark | |
on: | |
pull_request: | |
# branches: [main] | |
paths-ignore: | |
- "**/*.md" | |
- "**/*.txt" | |
- "hack/**" | |
- "scripts/**" | |
- ".github/**" | |
defaults: | |
run: | |
shell: pwsh | |
env: | |
GO_VERSION: "1.19.x" | |
GO_BUILD_TEST_CMD: "go test -mod=mod -gcflags=all=-d=checkptr -c -tags functional" | |
# NOTE: Merge branch is ${{ github.ref }} (at ${{ github.sha}}), merging into ${{ github.base_ref }} | |
jobs: | |
benchmark: | |
name: Run Functional Benchmarks | |
env: | |
BENCH_FILE: "${{ matrix.name }}_bench.txt" | |
# TEST_COUNT: "10" | |
# BENCH_TIME: "50x" | |
TEST_COUNT: "1" | |
BENCH_TIME: "5x" | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [windows-2019] | |
# os: [windows-2019, windows-2022] # TODO | |
ref: ["${{ github.ref }}", "${{ github.base_ref }}"] | |
include: | |
# add names to identify the instance (mostly because branch names are potentially invalid artifact names) | |
- ref: "${{ github.ref }}" | |
name: "pr" | |
- ref: "${{ github.base_ref }}" | |
name: "base" | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Checkout ${{ matrix.ref}} | |
uses: actions/checkout@v4 | |
with: | |
ref: "${{ matrix.ref }}" | |
show-progress: false | |
- name: Install go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
cache-dependency-path: | | |
go.sum | |
test/go.sum | |
- name: Install benchstat | |
run: | | |
go install golang.org/x/perf/cmd/benchstat@latest | |
# Download PsExec so we can run (functional) tests as 'NT Authority\System'. | |
# Needed for hostprocess tests, as well ensuring backup and restore privileges for | |
# unpacking WCOW images. | |
- name: Install PsExec.exe | |
run: | | |
New-Item -ItemType Directory -Force '${{ github.workspace }}\bin' > $null | |
'${{ github.workspace }}\bin' | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append | |
curl.exe -L --no-progress-meter --fail-with-body -o 'C:\PSTools.zip' ` | |
'https://download.sysinternals.com/files/PSTools.zip' 2>&1 | |
if ( $LASTEXITCODE ) { | |
Write-Output '::error::Could not download PSTools.zip' | |
exit $LASTEXITCODE | |
} | |
tar.exe xf 'C:\PSTools.zip' -C '${{ github.workspace }}\bin' 'PsExec*' 2>&1 | |
if ( $LASTEXITCODE ) { | |
Write-Output '::error::Could not extract PsExec.exe' | |
exit $LASTEXITCODE | |
} | |
# accept the eula | |
& '${{ github.workspace }}/bin/psexec' -accepteula -nobanner cmd /c "exit 0" 2>$null | |
- name: Set version info | |
run: | | |
# ignore errors since they won't affect build | |
try { | |
./scripts/Set-VersionInfo.ps1 | |
} catch { | |
Write-Output "::warning::Could not set hcsshim version info: $_" | |
} finally { | |
$LASTEXITCODE = 0 | |
} | |
- name: Build and run functional benchmarks | |
working-directory: test | |
run: ${{ env.GO_BUILD_TEST_CMD }} ./functional | |
- name: Run functional benchmarks | |
working-directory: test | |
continue-on-error: true # allow results to be processes below | |
timeout-minutes: 60 # `-test.timeout` flag doesn't apply to benchmarks | |
run: | | |
# don't run uVM (ie, nested virt) or LCOW integrity tests | |
$cmd = 'functional.test.exe -exclude="LCOW,LCOWIntegrity,uVM" ' + ` | |
'-test.shuffle=on -test.run=^^# -test.bench=. -test.benchmem ' + ` | |
'-test.v ' + ` | |
'-test.count=${{ env.TEST_COUNT }} -test.benchtime=${{ env.BENCH_TIME }}' | |
Write-Output "Benchmark command: $cmd" | |
# Write benchmarks to file | |
psexec -nobanner -w (Get-Location) -s cmd /c "$cmd > ${{ env.BENCH_FILE }} 2>&1" | |
if ( $LASTEXITCODE ) { | |
Write-Output '::error::Benchmarks failed' | |
} | |
- name: Show benchmark results | |
working-directory: test | |
run: | | |
if ( -not (Test-Path -PathType Leaf ${{ env.BENCH_FILE }}) ) { | |
Write-Output '::error::Benchmarks did not produce any output' | |
exit 1 | |
} | |
Write-Output "::group::Benmark results (${{ env.BENCH_FILE }})" | |
Get-Content -Path "${{ env.BENCH_FILE }}" | |
Write-Output "::endgroup::" | |
Write-Output "::group::Benmark statistics" | |
benchstat -table="" ${{ env.BENCH_FILE }} | |
Write-Output "::endgroup::" | |
- uses: actions/upload-artifact@v3 | |
name: Upload benchmark results | |
with: | |
name: benchmark_${{ matrix.os }}_${{ matrix.name }} | |
path: test/{{ env.BENCH_FILE }} | |
retention-days: 7 # one week, instead of the default 90 days | |
benchmark-perf: | |
name: Analyze Functional Benchmarks | |
needs: [benchmark] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [windows-2019] | |
# os: [windows-2019, windows-2022] # TODO | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Download ${{ github.ref }} results | |
uses: actions/download-artifact@v3 | |
with: | |
name: benchmark_${{ matrix.os }}_pr | |
- name: Download ${{ github.base_ref }} results | |
uses: actions/download-artifact@v3 | |
with: | |
name: benchmark_${{ matrix.os }}_base | |
- name: Install go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
cache: false | |
- name: Install benchstat | |
run: | | |
go install golang.org/x/perf/cmd/benchstat@latest | |
- name: Compare benchmarks | |
run: | | |
benchstat -table="" base_bench.txt pr_bench.txt |