CI #223
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: CI | |
on: | |
push: | |
pull_request: | |
schedule: | |
- cron: "0 10 * * 1" # At 10:00 on Monday. | |
defaults: | |
run: | |
shell: pwsh | |
jobs: | |
build: | |
strategy: | |
matrix: | |
os: [ubuntu-latest, macos-latest, windows-latest] | |
runs-on: ${{ matrix.os }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Test with Pester | |
run: ./test.ps1 | |
- name: Invoke action | |
env: | |
TEMP: ${{ runner.temp }} | |
run: | | |
$env:PWSH_SCRIPT_ACTION_TEXT = 'Write-Host "ok"; return "value"' | |
$output = pwsh -file ./action.ps1 | |
if ($LASTEXITCODE -ne 0) { | |
Write-Host "::error::Action exited with exit code $LASTEXITCODE and outputted: $output" | |
throw | |
} | |
$diff = Compare-Object @('ok') $output -CaseSensitive | |
if ($diff) { | |
$diff | Format-Table | Write-Host | |
Write-Host "::error::Action output differed from the expected, see above." | |
throw "Action output differed from the expected" | |
} | |
$outFile = Get-Content $env:GITHUB_OUTPUT | |
$diff = Compare-Object @('result=value') $outFile | |
if ($diff) { | |
$diff | Format-Table | Write-Host | |
Write-Host "::error::Action output file differed from the expected, see above." | |
throw "Action output file differed from the expected" | |
} | |
build-docs: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Build module docs | |
uses: ./ | |
with: | |
script: | | |
./build-docs.ps1 -Clean | |
git status --porcelain || $(throw "Documentation isn't up to date. Run 'build-docs.ps1' and commit changes.") | |
self-testing: | |
strategy: | |
matrix: | |
os: [ubuntu-latest, macos-latest, windows-latest] | |
runs-on: ${{ matrix.os }} | |
steps: | |
- uses: actions/checkout@v4 | |
# return string result | |
- name: Test that returned result string is not json serialized (act) | |
uses: ./ | |
id: test-result-string | |
with: | |
script: return "testmsg" | |
- name: Test that returned result string is not json serialized (assert) | |
run: | | |
$result = '${{ steps.test-result-string.outputs.result }}' | |
if ($result -cne 'testmsg') { | |
Write-Host "::error::unexpected - Return string test failed: invalid result.`n$result" | |
exit 1 | |
} | |
# return object result | |
- name: Test that returned result object is json serialized (act) | |
uses: ./ | |
id: test-result-object | |
with: | |
script: return [ordered]@{ a = 1; b = "c" } | |
- name: Test that returned result object is json serialized (assert) | |
run: | | |
$result = '${{ steps.test-result-object.outputs.result }}' | |
if ($result -cne '{"a":1,"b":"c"}') { | |
Write-Host "::error::unexpected - Return object test failed: invalid result.`n$result" | |
exit 1 | |
} | |
# throw | |
- name: Test that throwing causes action to fail (act) | |
uses: ./ | |
id: test-throwing-fails-action | |
continue-on-error: true | |
with: | |
script: 'throw "expected: test error message"' | |
- name: Test that throwing causes action to fail (assert) | |
run: | | |
$outcome = '${{ steps.test-throwing-fails-action.outcome }}' | |
if ($outcome -cne 'failure') { | |
Write-Host "::error::unexpected - Throwing test failed: invalid outcome.`n$outcome" | |
exit 1 | |
} | |
$errMsg = '${{ steps.test-throwing-fails-action.outputs.error }}' | |
if ($errMsg -cne 'expected: test error message') { | |
Write-Host "::error::unexpected - Throwing test failed: invalid error output.`n$errMsg" | |
exit 1 | |
} | |
# check access to contexts | |
- name: Test that workflow contexts are available | |
uses: ./ | |
with: | |
script: | | |
function Test-Value ($expression, $expected) { | |
$actual = Invoke-Expression $expression | |
if ($actual -cne $expected) { | |
throw "unexpected: Failed assertion:'$expression' evaluated to '$actual', expected '$expected'." | |
} | |
} | |
Test-Value '$github.token' '${{ github.token }}' | |
Test-Value '$job.status' '${{ job.status }}' | |
Test-Value '$runner.os' '${{ runner.os }}' | |
Test-Value '$strategy."fail-fast"' ([bool]'${{ strategy.fail-fast }}') | |
Test-Value '$matrix.os' '${{ matrix.os }}' | |
# Get-ActionInput | |
# Get-ActionInput isn't really testable in a script | |
- name: Get-ActionInput test | |
if: "false" | |
uses: ./ | |
with: | |
custom-input: "test" | |
script: | | |
$script = Get-ActionInput script | |
if ($script -notlike '$script = Get-ActionInput script*') { | |
throw "unexpected: Get-ActionInput for 'script' failed.`n$script" | |
} | |
$custom = Get-ActionInput custom-input | |
if ($custom -cne 'test') { | |
throw "unexpected: Get-ActionInput for 'custom-input' failed.`n$custom" | |
} | |
# Set-ActionOutput | |
- name: Set-ActionOutput test (act) | |
id: Set-ActionOutput | |
run: | | |
Import-Module ./lib/GitHubActionsCore -Force | |
Set-ActionOutput testout testval | |
Set-ActionOutput testout-multiline "testval`n new line `n 3rd line" | |
Get-Content $env:GITHUB_OUTPUT -Raw | Write-Host | |
- name: Set-ActionOutput test (assert) | |
uses: ./ | |
env: | |
testout_output: ${{ steps.Set-ActionOutput.outputs.testout }} | |
testout_multiline_output: ${{ steps.Set-ActionOutput.outputs.testout-multiline }} | |
with: | |
script: | | |
$output = $env:testout_output | |
if ($output -cne 'testval') { | |
throw "unexpected: Set-ActionOutput failed.`n$output" | |
} | |
$output = $env:testout_multiline_output | |
if ($output -cne "testval`n new line `n 3rd line") { | |
throw "unexpected: Set-ActionOutput failed.`n$output" | |
} | |
# Add-ActionPath | |
- name: Add-ActionPath test (act) | |
uses: ./ | |
with: | |
script: Add-ActionPath 'testing add-path' | |
- name: Add-ActionPath test (assert) | |
uses: ./ | |
with: | |
script: | | |
if ($env:PATH -notlike "*testing add-path$([System.IO.Path]::PathSeparator)*") { | |
throw "unexpected: Add-ActionPath failed.`n$env:PATH" | |
} | |
# Add-ActionSecret | |
- name: Add-ActionSecret test (manual check whether host-sent value is masked) | |
uses: ./ | |
with: | |
script: | | |
$secret = [System.Guid]::NewGuid() | |
Add-ActionSecret $secret | |
Write-Host $secret | |
# Set-ActionVariable | |
- name: Set-ActionVariable test (act and first assert) | |
uses: ./ | |
with: | |
script: | | |
$props = [ordered]@{ a = 1; b = 'c' } | |
Set-ActionVariable testvar $props | |
Set-ActionVariable testvar_multiline "line1`nline2`nline3" | |
Get-Content $env:GITHUB_ENV -Raw | Write-Host | |
if ($env:testvar -cne '{"a":1,"b":"c"}') { | |
throw "unexpected: Set-ActionVariable failed.`n$env:testvar" | |
} | |
- name: Set-ActionVariable test (second assert) | |
uses: ./ | |
with: | |
script: | | |
if ($env:testvar -cne '{"a":1,"b":"c"}') { | |
throw "unexpected: Set-ActionVariable failed.`n$env:testvar" | |
} | |
if ($env:testvar_multiline -cne "line1`nline2`nline3") { | |
throw "unexpected: Set-ActionVariable failed.`n$env:testvar_multiline" | |
} | |
# Set-ActionCommandEcho | |
- name: Set-ActionCommandEcho test (manual check whether commands are shown in log) | |
uses: ./ | |
with: | |
script: | | |
Set-ActionCommandEcho $false | |
Set-ActionOutput echo-off "unexpected to show up" # shouldn't show up in logs | |
Set-ActionCommandEcho $true | |
Set-ActionOutput echo-on "expected to show up" # should show up in logs | |
Set-ActionCommandEcho $false | |
# Set-ActionFailed | |
- name: Set-ActionFailed test (act) | |
uses: ./ | |
id: Set-ActionFailed | |
continue-on-error: true | |
with: | |
script: | | |
Set-ActionFailed "expected: test error (this action should have exit code 1 in logs)" | |
- name: Set-ActionFailed test (assert) | |
uses: ./ | |
with: | |
script: | | |
$result = '${{ steps.Set-ActionFailed.outcome }}' | |
if ($result -cne 'failure') { | |
throw "unexpected: Set-ActionFailed failed.`n$result" | |
} | |
# Get-ActionIsDebug | |
- name: Get-ActionIsDebug test | |
uses: ./ | |
with: | |
script: | | |
$result = Get-ActionIsDebug | |
if ($result -ne ($env:RUNNER_DEBUG -eq '1')) { | |
throw "unexpected: Get-ActionIsDebug failed.`n$result" | |
} | |
# Invoke-ActionNoCommandsBlock | |
- name: Invoke-ActionNoCommandsBlock test (manual check) | |
id: Invoke-ActionNoCommandsBlock | |
run: | | |
Import-Module ./lib/GitHubActionsCore -Force | |
Invoke-ActionNoCommandsBlock -GenerateToken { | |
Write-ActionError "unexpected: this should not be visible as error" | |
} | |
# Write-Action -Debug, -Info, -Warning, -Error and Grouping are not testable in any sensible manner | |
- name: Write-Action... and Group... sample runs (manual check) | |
uses: ./ | |
continue-on-error: true # since we're printing errors | |
with: | |
script: | | |
Enter-ActionOutputGroup 'testing log levels' | |
Write-ActionDebug "dbg msg" | |
Write-ActionInfo "expected: info msg" | |
Write-ActionWarning "expected: wrn msg" | |
Write-ActionError "expected: err msg" | |
Exit-ActionOutputGroup | |
Invoke-ActionGroup "Invoke-ActionGroup group" { | |
Write-Host "expected: output within Invoke-ActionGroup" | |
} |