mirror of
https://github.com/actions/runner-images.git
synced 2025-12-11 11:37:00 +00:00
201 lines
6.5 KiB
PowerShell
201 lines
6.5 KiB
PowerShell
function Get-CommandResult {
|
|
Param (
|
|
[Parameter(Mandatory)][string] $Command
|
|
)
|
|
# CMD trick to suppress and show error output because some commands write to stderr (for example, "python --version")
|
|
[string[]]$output = & $env:comspec /c "$Command 2>&1"
|
|
$exitCode = $LASTEXITCODE
|
|
|
|
return @{
|
|
Output = $output
|
|
ExitCode = $exitCode
|
|
}
|
|
}
|
|
|
|
# Gets path to the tool, analogue of 'which tool'
|
|
function Get-WhichTool($tool) {
|
|
return (Get-Command $tool).Path
|
|
}
|
|
|
|
# Gets value of environment variable by the name
|
|
function Get-EnvironmentVariable($variable) {
|
|
return [System.Environment]::GetEnvironmentVariable($variable, "Machine")
|
|
}
|
|
|
|
# Update environment variables without reboot
|
|
function Update-Environment {
|
|
$variables = [Environment]::GetEnvironmentVariables("Machine")
|
|
$variables.Keys | ForEach-Object {
|
|
$key = $_
|
|
$value = $variables[$key]
|
|
Set-Item -Path "env:$key" -Value $value
|
|
}
|
|
# We need to refresh PATH the latest one because it could include other variables "%M2_HOME%/bin"
|
|
$env:PATH = [Environment]::GetEnvironmentVariable("PATH", "Machine")
|
|
}
|
|
|
|
# Run Pester tests for specific tool
|
|
function Invoke-PesterTests {
|
|
Param(
|
|
[Parameter(Mandatory)][string] $TestFile,
|
|
[string] $TestName
|
|
)
|
|
|
|
$testPath = "C:\image\Tests\${TestFile}.Tests.ps1"
|
|
if (-not (Test-Path $testPath)) {
|
|
throw "Unable to find test file '$TestFile' on '$testPath'."
|
|
}
|
|
|
|
$configuration = [PesterConfiguration] @{
|
|
Run = @{ Path = $testPath; PassThru = $true }
|
|
Output = @{ Verbosity = "Detailed"; RenderMode = "Plaintext"}
|
|
}
|
|
if ($TestName) {
|
|
$configuration.Filter.FullName = $TestName
|
|
}
|
|
if ($TestFile -eq "*") {
|
|
$configuration.TestResult.Enabled = $true
|
|
$configuration.TestResult.OutputPath = "C:\image\Tests\testResults.xml"
|
|
}
|
|
|
|
# Update environment variables without reboot
|
|
Update-Environment
|
|
|
|
# Switch ErrorActionPreference to Stop temporary to make sure that tests will on silent errors too
|
|
$backupErrorActionPreference = $ErrorActionPreference
|
|
$ErrorActionPreference = "Stop"
|
|
$results = Invoke-Pester -Configuration $configuration
|
|
$ErrorActionPreference = $backupErrorActionPreference
|
|
|
|
# Fail in case if no tests are run
|
|
if (-not ($results -and ($results.FailedCount -eq 0) -and ($results.PassedCount -gt 0))) {
|
|
$results
|
|
throw "Test run has failed"
|
|
}
|
|
}
|
|
|
|
# Pester Assert to check exit code of command
|
|
function ShouldReturnZeroExitCode {
|
|
Param(
|
|
[String] $ActualValue,
|
|
[switch] $Negate,
|
|
[string] $Because
|
|
)
|
|
|
|
$result = Get-CommandResult $ActualValue
|
|
|
|
[bool]$succeeded = $result.ExitCode -eq 0
|
|
if ($Negate) { $succeeded = -not $succeeded }
|
|
|
|
if (-not $succeeded)
|
|
{
|
|
$commandOutputIndent = " " * 4
|
|
$commandOutput = ($result.Output | ForEach-Object { "${commandOutputIndent}${_}" }) -join "`n"
|
|
$failureMessage = "Command '${ActualValue}' has finished with exit code ${actualExitCode}`n${commandOutput}"
|
|
}
|
|
|
|
return [PSCustomObject] @{
|
|
Succeeded = $succeeded
|
|
FailureMessage = $failureMessage
|
|
}
|
|
}
|
|
|
|
# Pester Assert to check exit code of command with given parameter, the assertion performed up to 3 checks (without '-', with 1 and 2 '-') until succeeded
|
|
function ShouldReturnZeroExitCodeWithParam {
|
|
param (
|
|
[Parameter(Mandatory)] [string] $ActualValue,
|
|
[switch] $Negate,
|
|
[string] $CallParameter = "version",
|
|
[string] $CallerSessionState
|
|
)
|
|
|
|
$delimiterCharacter = ""
|
|
|
|
while ($delimiterCharacter.Length -le 2)
|
|
{
|
|
$callParameterWithDelimiter = $delimiterCharacter + $CallParameter
|
|
$commandToCheck = "$ActualValue $callParameterWithDelimiter"
|
|
[bool]$succeeded = (ShouldReturnZeroExitCode -ActualValue $commandToCheck).Succeeded
|
|
|
|
if ($succeeded)
|
|
{
|
|
break
|
|
}
|
|
$delimiterCharacter += '-'
|
|
}
|
|
if ($Negate) { $succeeded = -not $succeeded }
|
|
|
|
if (-not $succeeded)
|
|
{
|
|
$failureMessage = "Tool '$ActualValue' has not returned 0 exit code for any of these flags: '$CallParameter' or '-$CallParameter' or '--$CallParameter'"
|
|
}
|
|
|
|
return [PSCustomObject] @{
|
|
Succeeded = $succeeded
|
|
FailureMessage = $failureMessage
|
|
}
|
|
}
|
|
|
|
# Pester Assert to match output of command
|
|
function ShouldMatchCommandOutput {
|
|
Param(
|
|
[String] $ActualValue,
|
|
[String] $RegularExpression,
|
|
[switch] $Negate
|
|
)
|
|
|
|
$output = (Get-CommandResult $ActualValue).Output | Out-String
|
|
[bool] $succeeded = $output -cmatch $RegularExpression
|
|
|
|
if ($Negate) {
|
|
$succeeded = -not $succeeded
|
|
}
|
|
|
|
$failureMessage = ''
|
|
|
|
if (-not $succeeded) {
|
|
if ($Negate) {
|
|
$failureMessage = "Expected regular expression '$RegularExpression' for '$ActualValue' command to not match '$output', but it did match."
|
|
}
|
|
else {
|
|
$failureMessage = "Expected regular expression '$RegularExpression' for '$ActualValue' command to match '$output', but it did not match."
|
|
}
|
|
}
|
|
|
|
return [PSCustomObject] @{
|
|
Succeeded = $succeeded
|
|
FailureMessage = $failureMessage
|
|
}
|
|
}
|
|
|
|
If (Get-Command -Name Add-ShouldOperator -ErrorAction SilentlyContinue) {
|
|
Add-ShouldOperator -Name ReturnZeroExitCode -InternalName ShouldReturnZeroExitCode -Test ${function:ShouldReturnZeroExitCode}
|
|
Add-ShouldOperator -Name ReturnZeroExitCodeWithParam -InternalName ShouldReturnZeroExitCodeWithParam -Test ${function:ShouldReturnZeroExitCodeWithParam}
|
|
Add-ShouldOperator -Name MatchCommandOutput -InternalName ShouldMatchCommandOutput -Test ${function:ShouldMatchCommandOutput}
|
|
}
|
|
|
|
Function Get-ModuleVersionAsJob {
|
|
Param (
|
|
[Parameter(Mandatory)]
|
|
[String] $modulePath,
|
|
[Parameter(Mandatory)]
|
|
[String] $moduleName
|
|
)
|
|
# Script block to run commands in separate PowerShell environment
|
|
$testJob = Start-Job -ScriptBlock {
|
|
param (
|
|
$modulePath,
|
|
$moduleName
|
|
)
|
|
# Disable warning messages to prevent additional warnings about Az and Azurerm modules in the same session
|
|
$WarningPreference = "SilentlyContinue"
|
|
$env:PsModulePath = "$modulePath;$env:PsModulePath"
|
|
Import-Module -Name $moduleName
|
|
(Get-Module -Name $moduleName).Version.ToString()
|
|
|
|
} -ArgumentList $modulePath, $moduleName
|
|
|
|
$testJob | Wait-Job | Receive-Job | Out-File -FilePath "${env:TEMP}\module-version.txt"
|
|
Remove-Job $testJob
|
|
}
|