2020-06-25 16:36:28 -07:00
|
|
|
# Copyright (c) Microsoft Corporation.
|
|
|
|
# SPDX-License-Identifier: MIT
|
|
|
|
#
|
|
|
|
|
|
|
|
<#
|
|
|
|
.SYNOPSIS
|
|
|
|
Runs the 'Test Modified Ports' part of the vcpkg CI system for all platforms.
|
|
|
|
|
|
|
|
.PARAMETER Triplet
|
|
|
|
The triplet to test.
|
|
|
|
|
|
|
|
.PARAMETER WorkingRoot
|
|
|
|
The location used as scratch space for 'installed', 'packages', and 'buildtrees' vcpkg directories.
|
|
|
|
|
2020-09-21 17:27:35 -07:00
|
|
|
.PARAMETER ArtifactStagingDirectory
|
2020-06-25 16:36:28 -07:00
|
|
|
The Azure Pipelines artifacts directory. If not supplied, defaults to the current directory.
|
|
|
|
|
2020-09-28 13:54:10 -07:00
|
|
|
.PARAMETER ArchivesRoot
|
2020-11-18 12:21:23 -08:00
|
|
|
Equivalent to '-BinarySourceStub "files,$ArchivesRoot"'
|
|
|
|
|
|
|
|
.PARAMETER BinarySourceStub
|
|
|
|
The type and parameters of the binary source. Shared across runs of this script. If
|
|
|
|
this parameter is not set, binary caching will not be used. Example: "files,W:\"
|
2020-09-28 13:54:10 -07:00
|
|
|
|
2020-06-25 16:36:28 -07:00
|
|
|
.PARAMETER BuildReason
|
2021-11-01 20:18:28 +01:00
|
|
|
The reason Azure Pipelines is running this script. For invocations caused by `PullRequest`,
|
|
|
|
modified ports are identified by changed hashes with regard to git HEAD~1 (subject to NoParentHashes),
|
|
|
|
and ports marked as failing in the CI baseline (or which depend on such ports) are skipped.
|
|
|
|
If BinarySourceStub is set and this parameter is set to a non-empty value other than `PullRequest`,
|
|
|
|
binary caching will be in write-only mode.
|
|
|
|
|
|
|
|
.PARAMETER NoParentHashes
|
|
|
|
Indicates to not use parent hashes even for pull requests.
|
2021-07-19 19:55:00 -07:00
|
|
|
|
|
|
|
.PARAMETER PassingIsPassing
|
|
|
|
Indicates that 'Passing, remove from fail list' results should not be emitted as failures. (For example, this is used
|
|
|
|
when using vcpkg to test a prerelease MSVC++ compiler)
|
2020-06-25 16:36:28 -07:00
|
|
|
#>
|
|
|
|
|
2020-11-18 12:21:23 -08:00
|
|
|
[CmdletBinding(DefaultParameterSetName="ArchivesRoot")]
|
2020-06-25 16:36:28 -07:00
|
|
|
Param(
|
2020-06-26 12:37:53 -07:00
|
|
|
[Parameter(Mandatory = $true)]
|
2020-06-25 16:36:28 -07:00
|
|
|
[ValidateNotNullOrEmpty()]
|
|
|
|
[string]$Triplet,
|
2020-06-26 12:37:53 -07:00
|
|
|
[Parameter(Mandatory = $true)]
|
2020-06-25 16:36:28 -07:00
|
|
|
[ValidateNotNullOrEmpty()]
|
|
|
|
$WorkingRoot,
|
|
|
|
[ValidateNotNullOrEmpty()]
|
2020-09-21 17:27:35 -07:00
|
|
|
$ArtifactStagingDirectory = '.',
|
2020-11-18 12:21:23 -08:00
|
|
|
[Parameter(ParameterSetName='ArchivesRoot')]
|
2020-09-28 13:54:10 -07:00
|
|
|
$ArchivesRoot = $null,
|
2020-11-18 12:21:23 -08:00
|
|
|
[Parameter(ParameterSetName='BinarySourceStub')]
|
|
|
|
$BinarySourceStub = $null,
|
2021-09-29 13:15:25 -07:00
|
|
|
[String]$BuildReason = $null,
|
2021-11-01 20:18:28 +01:00
|
|
|
[switch]$NoParentHashes = $false,
|
2024-04-25 18:25:03 -07:00
|
|
|
[switch]$PassingIsPassing = $false
|
2020-06-25 16:36:28 -07:00
|
|
|
)
|
|
|
|
|
2021-01-08 11:55:31 -08:00
|
|
|
if (-Not ((Test-Path "triplets/$Triplet.cmake") -or (Test-Path "triplets/community/$Triplet.cmake"))) {
|
2020-06-25 16:36:28 -07:00
|
|
|
Write-Error "Incorrect triplet '$Triplet', please supply a valid triplet."
|
2024-08-01 12:41:09 -07:00
|
|
|
exit 1
|
2020-06-25 16:36:28 -07:00
|
|
|
}
|
|
|
|
|
2021-09-03 00:02:29 -07:00
|
|
|
if ((-Not [string]::IsNullOrWhiteSpace($ArchivesRoot))) {
|
|
|
|
if ((-Not [string]::IsNullOrWhiteSpace($BinarySourceStub))) {
|
|
|
|
Write-Error "Only one binary caching setting may be used."
|
2024-08-01 12:41:09 -07:00
|
|
|
exit 1
|
2020-12-22 14:52:58 -08:00
|
|
|
}
|
2021-09-03 00:02:29 -07:00
|
|
|
|
|
|
|
$BinarySourceStub = "files,$ArchivesRoot"
|
2020-12-22 14:52:58 -08:00
|
|
|
}
|
|
|
|
|
2023-12-18 10:27:45 -08:00
|
|
|
$buildtreesRoot = Join-Path $WorkingRoot 'b'
|
2020-06-25 16:36:28 -07:00
|
|
|
$installRoot = Join-Path $WorkingRoot 'installed'
|
2023-12-18 10:27:45 -08:00
|
|
|
$packagesRoot = Join-Path $WorkingRoot 'p'
|
2020-09-28 13:54:10 -07:00
|
|
|
|
2021-09-03 00:02:29 -07:00
|
|
|
$commonArgs = @(
|
2020-06-25 16:36:28 -07:00
|
|
|
"--x-buildtrees-root=$buildtreesRoot",
|
|
|
|
"--x-install-root=$installRoot",
|
2020-08-01 01:48:52 +02:00
|
|
|
"--x-packages-root=$packagesRoot",
|
|
|
|
"--overlay-ports=scripts/test_ports"
|
2020-06-25 16:36:28 -07:00
|
|
|
)
|
2021-11-01 20:18:28 +01:00
|
|
|
$cachingArgs = @()
|
2020-06-25 16:36:28 -07:00
|
|
|
|
2022-03-31 19:08:09 -07:00
|
|
|
$skipFailuresArg = @()
|
2021-09-03 00:02:29 -07:00
|
|
|
if ([string]::IsNullOrWhiteSpace($BinarySourceStub)) {
|
2021-11-01 20:18:28 +01:00
|
|
|
$cachingArgs = @('--no-binarycaching')
|
2021-09-03 00:02:29 -07:00
|
|
|
} else {
|
2021-11-01 20:18:28 +01:00
|
|
|
$cachingArgs = @('--binarycaching')
|
2020-09-28 13:54:10 -07:00
|
|
|
$binaryCachingMode = 'readwrite'
|
|
|
|
if ([string]::IsNullOrWhiteSpace($BuildReason)) {
|
|
|
|
Write-Host 'Build reason not specified, defaulting to using binary caching in read write mode.'
|
|
|
|
}
|
|
|
|
elseif ($BuildReason -eq 'PullRequest') {
|
|
|
|
Write-Host 'Build reason was Pull Request, using binary caching in read write mode, skipping failures.'
|
2022-03-31 19:08:09 -07:00
|
|
|
$skipFailuresArg = @('--skip-failures')
|
2020-09-28 13:54:10 -07:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
Write-Host "Build reason was $BuildReason, using binary caching in write only mode."
|
|
|
|
$binaryCachingMode = 'write'
|
|
|
|
}
|
2020-12-22 14:52:58 -08:00
|
|
|
|
2021-11-01 20:18:28 +01:00
|
|
|
$cachingArgs += @("--binarysource=clear;$BinarySourceStub,$binaryCachingMode")
|
2020-09-28 13:54:10 -07:00
|
|
|
}
|
2020-06-26 12:37:53 -07:00
|
|
|
|
2024-04-25 18:25:03 -07:00
|
|
|
if ($IsWindows) {
|
2020-06-25 16:36:28 -07:00
|
|
|
$executableExtension = '.exe'
|
2024-04-25 18:25:03 -07:00
|
|
|
} else {
|
|
|
|
$executableExtension = [string]::Empty
|
2020-06-25 16:36:28 -07:00
|
|
|
}
|
|
|
|
|
2020-09-21 17:27:35 -07:00
|
|
|
$failureLogs = Join-Path $ArtifactStagingDirectory 'failure-logs'
|
2022-06-15 11:20:52 -07:00
|
|
|
$xunitFile = Join-Path $ArtifactStagingDirectory "$Triplet-results.xml"
|
2020-07-02 20:20:07 -07:00
|
|
|
|
2024-04-25 18:25:03 -07:00
|
|
|
if ($IsWindows) {
|
2021-10-20 22:51:29 -07:00
|
|
|
mkdir empty
|
|
|
|
cmd /c "robocopy.exe empty `"$buildtreesRoot`" /MIR /NFL /NDL /NC /NP > nul"
|
|
|
|
cmd /c "robocopy.exe empty `"$packagesRoot`" /MIR /NFL /NDL /NC /NP > nul"
|
|
|
|
cmd /c "robocopy.exe empty `"$installRoot`" /MIR /NFL /NDL /NC /NP > nul"
|
|
|
|
rmdir empty
|
|
|
|
}
|
|
|
|
|
2020-06-25 16:36:28 -07:00
|
|
|
& "./vcpkg$executableExtension" x-ci-clean @commonArgs
|
2024-08-01 12:41:09 -07:00
|
|
|
$lastLastExitCode = $LASTEXITCODE
|
|
|
|
if ($lastLastExitCode -ne 0)
|
2021-09-14 17:46:38 -07:00
|
|
|
{
|
2024-08-01 12:41:09 -07:00
|
|
|
Write-Error "vcpkg clean failed"
|
|
|
|
exit $lastLastExitCode
|
2021-09-14 17:46:38 -07:00
|
|
|
}
|
|
|
|
|
2021-12-13 12:54:16 -08:00
|
|
|
$parentHashes = @()
|
|
|
|
if (($BuildReason -eq 'PullRequest') -and -not $NoParentHashes)
|
|
|
|
{
|
2023-04-12 08:11:59 +02:00
|
|
|
$headBaseline = Get-Content "$PSScriptRoot/../ci.baseline.txt" -Raw
|
|
|
|
|
2021-12-13 12:54:16 -08:00
|
|
|
# Prefetch tools for better output
|
2022-03-07 20:39:32 +01:00
|
|
|
foreach ($tool in @('cmake', 'ninja', 'git')) {
|
|
|
|
& "./vcpkg$executableExtension" fetch $tool
|
2024-08-01 12:41:09 -07:00
|
|
|
$lastLastExitCode = $LASTEXITCODE
|
|
|
|
if ($lastLastExitCode -ne 0)
|
2022-03-07 20:39:32 +01:00
|
|
|
{
|
2024-08-01 12:41:09 -07:00
|
|
|
Write-Error "Failed to fetch $tool"
|
|
|
|
exit $lastLastExitCode
|
2022-03-07 20:39:32 +01:00
|
|
|
}
|
|
|
|
}
|
2021-12-13 12:54:16 -08:00
|
|
|
|
2023-04-12 08:11:59 +02:00
|
|
|
Write-Host "Comparing with HEAD~1"
|
2022-03-07 20:39:32 +01:00
|
|
|
& git revert -n -m 1 HEAD | Out-Null
|
2024-08-01 12:41:09 -07:00
|
|
|
$lastLastExitCode = $LASTEXITCODE
|
|
|
|
if ($lastLastExitCode -ne 0)
|
|
|
|
{
|
|
|
|
Write-Error "git revert failed"
|
|
|
|
exit $lastLastExitCode
|
|
|
|
}
|
|
|
|
|
2023-04-12 08:11:59 +02:00
|
|
|
$parentBaseline = Get-Content "$PSScriptRoot/../ci.baseline.txt" -Raw
|
|
|
|
if ($parentBaseline -eq $headBaseline)
|
|
|
|
{
|
|
|
|
Write-Host "CI baseline unchanged, determining parent hashes"
|
|
|
|
$parentHashesFile = Join-Path $ArtifactStagingDirectory 'parent-hashes.json'
|
|
|
|
$parentHashes = @("--parent-hashes=$parentHashesFile")
|
|
|
|
# The vcpkg.cmake toolchain file is not part of ABI hashing,
|
|
|
|
# but changes must trigger at least some testing.
|
|
|
|
Copy-Item "scripts/buildsystems/vcpkg.cmake" -Destination "scripts/test_ports/cmake"
|
|
|
|
Copy-Item "scripts/buildsystems/vcpkg.cmake" -Destination "scripts/test_ports/cmake-user"
|
|
|
|
& "./vcpkg$executableExtension" ci "--triplet=$Triplet" --dry-run "--ci-baseline=$PSScriptRoot/../ci.baseline.txt" @commonArgs --no-binarycaching "--output-hashes=$parentHashesFile"
|
2024-08-01 12:41:09 -07:00
|
|
|
$lastLastExitCode = $LASTEXITCODE
|
|
|
|
if ($lastLastExitCode -ne 0)
|
|
|
|
{
|
|
|
|
Write-Error "Generating parent hashes failed; this is usually an infrastructure problem with vcpkg"
|
|
|
|
exit $lastLastExitCode
|
|
|
|
}
|
2023-04-12 08:11:59 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Write-Host "CI baseline was modified, not using parent hashes"
|
|
|
|
}
|
2024-08-01 12:41:09 -07:00
|
|
|
|
2023-04-12 08:11:59 +02:00
|
|
|
Write-Host "Running CI for HEAD"
|
2022-03-07 20:39:32 +01:00
|
|
|
& git reset --hard HEAD
|
2024-08-01 12:41:09 -07:00
|
|
|
$lastLastExitCode = $LASTEXITCODE
|
|
|
|
if ($lastLastExitCode -ne 0)
|
|
|
|
{
|
|
|
|
Write-Error "git reset failed"
|
|
|
|
exit $lastLastExitCode
|
|
|
|
}
|
2021-12-13 12:54:16 -08:00
|
|
|
}
|
2021-11-01 20:18:28 +01:00
|
|
|
|
2022-03-24 00:16:17 +01:00
|
|
|
# The vcpkg.cmake toolchain file is not part of ABI hashing,
|
|
|
|
# but changes must trigger at least some testing.
|
|
|
|
Copy-Item "scripts/buildsystems/vcpkg.cmake" -Destination "scripts/test_ports/cmake"
|
|
|
|
Copy-Item "scripts/buildsystems/vcpkg.cmake" -Destination "scripts/test_ports/cmake-user"
|
2022-06-15 11:20:52 -07:00
|
|
|
& "./vcpkg$executableExtension" ci "--triplet=$Triplet" --failure-logs=$failureLogs --x-xunit=$xunitFile "--ci-baseline=$PSScriptRoot/../ci.baseline.txt" @commonArgs @cachingArgs @parentHashes @skipFailuresArg
|
2024-08-01 12:41:09 -07:00
|
|
|
$lastLastExitCode = $LASTEXITCODE
|
2021-09-28 23:00:33 +02:00
|
|
|
|
2021-12-13 12:54:16 -08:00
|
|
|
$failureLogsEmpty = (-Not (Test-Path $failureLogs) -Or ((Get-ChildItem $failureLogs).count -eq 0))
|
|
|
|
Write-Host "##vso[task.setvariable variable=FAILURE_LOGS_EMPTY]$failureLogsEmpty"
|
2021-09-14 17:46:38 -07:00
|
|
|
|
2024-08-01 12:41:09 -07:00
|
|
|
Write-Host "##vso[task.setvariable variable=XML_RESULTS_FILE]$xunitFile"
|
|
|
|
|
|
|
|
if ($lastLastExitCode -ne 0)
|
2021-12-13 12:54:16 -08:00
|
|
|
{
|
2024-08-01 12:41:09 -07:00
|
|
|
Write-Error "vcpkg ci testing failed; this is usually a bug in a port. Check for failure logs attached to the run in Azure Pipelines."
|
2021-09-29 13:15:25 -07:00
|
|
|
}
|
2022-06-15 11:20:52 -07:00
|
|
|
|
2024-08-01 12:41:09 -07:00
|
|
|
exit $lastLastExitCode
|