From 9e164eec962bb4ab131082adabbdaf2cf8605b11 Mon Sep 17 00:00:00 2001 From: Ryan Pavlik Date: Wed, 26 Oct 2022 16:18:14 -0500 Subject: [PATCH] ci: Improve Windows CI scripts --- .gitlab-ci.yml | 6 +- .gitlab-ci/ci.template | 2 +- .gitlab-ci/win_containers.yml | 4 +- .gitlab-ci/windows/Dockerfile.vs2022 | 4 +- .gitlab-ci/windows/monado_build.ps1 | 73 +++++++++++++++++++------ .gitlab-ci/windows/monado_container.ps1 | 30 +++++++--- 6 files changed, 86 insertions(+), 33 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 37bcfc024..4590ac822 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -175,8 +175,8 @@ arch:rolling:container_prep: inherit: default: false variables: - MONADO_WIN_BASE_TAG: "20220727.0" - MONADO_WIN_MAIN_TAG: "20220727.0" + MONADO_WIN_BASE_TAG: "20221026.0" + MONADO_WIN_MAIN_TAG: "20221026.0" MONADO_BASE_IMAGE_PATH: "win2022/vs2022_base" MONADO_MAIN_IMAGE_PATH: "win2022/vs2022" @@ -492,7 +492,7 @@ windows: extends: - .monado.image.windows script: - - ./.gitlab-ci/windows/monado_build.ps1 + - ./.gitlab-ci/windows/monado_build.ps1 -Install -RunTests artifacts: when: always paths: diff --git a/.gitlab-ci/ci.template b/.gitlab-ci/ci.template index 30aa058c2..e17406ce8 100644 --- a/.gitlab-ci/ci.template +++ b/.gitlab-ci/ci.template @@ -201,7 +201,7 @@ windows: extends: - .monado.image.windows script: - - ./.gitlab-ci/windows/monado_build.ps1 + - ./.gitlab-ci/windows/monado_build.ps1 -Install -RunTests artifacts: when: always paths: diff --git a/.gitlab-ci/win_containers.yml b/.gitlab-ci/win_containers.yml index 493aa780f..6d1a2a990 100644 --- a/.gitlab-ci/win_containers.yml +++ b/.gitlab-ci/win_containers.yml @@ -9,8 +9,8 @@ inherit: default: false variables: - MONADO_WIN_BASE_TAG: "20220727.0" - MONADO_WIN_MAIN_TAG: "20220727.0" + MONADO_WIN_BASE_TAG: "20221026.0" + MONADO_WIN_MAIN_TAG: "20221026.0" MONADO_BASE_IMAGE_PATH: "win2022/vs2022_base" MONADO_MAIN_IMAGE_PATH: "win2022/vs2022" diff --git a/.gitlab-ci/windows/Dockerfile.vs2022 b/.gitlab-ci/windows/Dockerfile.vs2022 index 8e79aa6be..945f658a7 100644 --- a/.gitlab-ci/windows/Dockerfile.vs2022 +++ b/.gitlab-ci/windows/Dockerfile.vs2022 @@ -12,5 +12,5 @@ FROM mcr.microsoft.com/windows/server:ltsc2022 SHELL ["powershell", "-ExecutionPolicy", "RemoteSigned", "-Command", "$ErrorActionPreference = 'Stop';"] ENV ErrorActionPreference='Stop' -COPY "monado_deps_vs2022.ps1" "C:/" -RUN "C:/monado_deps_vs2022.ps1" +COPY "monado_deps_vs2022.ps1" "C:\\" +RUN "powershell C:\\monado_deps_vs2022.ps1" diff --git a/.gitlab-ci/windows/monado_build.ps1 b/.gitlab-ci/windows/monado_build.ps1 index 6e2491acf..8053069f0 100644 --- a/.gitlab-ci/windows/monado_build.ps1 +++ b/.gitlab-ci/windows/monado_build.ps1 @@ -3,9 +3,24 @@ # SPDX-License-Identifier: MIT # Based on https://gitlab.freedesktop.org/mesa/mesa/-/blob/8396df5ad90aeb6ab2267811aba2187954562f81/.gitlab-ci/windows/mesa_build.ps1 -# force the CA cert cache to be rebuilt, in case Meson tries to access anything -Write-Host "Refreshing Windows TLS CA cache" -(New-Object System.Net.WebClient).DownloadString("https://github.com") > $null +[CmdletBinding()] +param ( + # Should we install the project? + [Parameter()] + [switch] + $Install = $false, + + # Should we package the project? + [Parameter()] + [switch] + $Package = $false, + + # Should we run the test suite? + [Parameter()] + [switch] + $RunTests = $false +) +$ErrorActionPreference = 'Stop' $env:PYTHONUTF8 = 1 @@ -22,19 +37,27 @@ Remove-Item -Recurse -Force $installdir -ErrorAction SilentlyContinue Write-Output "builddir:$builddir" Write-Output "installdir:$installdir" Write-Output "sourcedir:$sourcedir" +Write-Output "toolchainfile:$toolchainfile" -$installPath = & "C:\Program Files (x86)\Microsoft Visual Studio\Installer\vswhere.exe" -version 17 -property installationpath -Write-Output "vswhere.exe installPath: $installPath" +# $installPath = & "C:\Program Files (x86)\Microsoft Visual Studio\Installer\vswhere.exe" -version 17 -property installationpath +# Write-Information "vswhere.exe installPath: $installPath" +# if (!$installPath) { +# throw "Could not find VS2022 using vswhere!" +# } $installPath = "C:\BuildTools" -Write-Output "Final installPath: $installPath" +Write-Output "installPath: $installPath" # Note that we can't have $ErrorActionPreference as "Stop" here: # it "errors" (not finding some shared tool because of our mini build tools install) # but the error doesn't matter for our use case. +Write-Output "There may be a harmless error about 'Team Explorer' shown next, which may be ignored." +$ErrorActionPreference = 'Continue' Import-Module (Join-Path $installPath "Common7\Tools\Microsoft.VisualStudio.DevShell.dll") Enter-VsDevShell -VsInstallPath $installPath -SkipAutomaticLocation -DevCmdArguments '-arch=x64 -no_logo -host_arch=amd64' +$ErrorActionPreference = 'Stop' Push-Location $sourcedir + $cmakeArgs = @( "-S" "." @@ -44,18 +67,32 @@ $cmakeArgs = @( "-DCMAKE_BUILD_TYPE=RelWithDebInfo" "-DCMAKE_TOOLCHAIN_FILE=$toolchainfile" "-DCMAKE_INSTALL_PREFIX=$installdir" + "-DX_VCPKG_APPLOCAL_DEPS_INSTALL=ON" ) cmake @cmakeArgs - -ninja -C $builddir -ninja -C $builddir install test - -$buildstatus = $? -Pop-Location - -Get-Date - -if (!$buildstatus) { - Write-Host "Monado build or test failed" - Exit 1 +if (!$?) { + throw "cmake generate failed!" +} + +Write-Information "Building" +cmake --build $builddir +if (!$?) { + throw "cmake build failed!" +} + +if ($RunTests) { + Write-Information "Running tests" + cmake --build $builddir --target test + +} + +if ($Install) { + Write-Information "Installing" + cmake --build $builddir --target install +} + + +if ($Package) { + Write-Information "Packaging" + cmake --build $builddir --target package } diff --git a/.gitlab-ci/windows/monado_container.ps1 b/.gitlab-ci/windows/monado_container.ps1 index 430d92c51..d92ae03af 100644 --- a/.gitlab-ci/windows/monado_container.ps1 +++ b/.gitlab-ci/windows/monado_container.ps1 @@ -135,22 +135,32 @@ function Test-Image { return $false } +if ($BaseImage -and (!$BaseUpstreamImage)) { + $BaseUpstreamImage = $BaseImage +} + Write-Host "Will log in to $RegistryUri as $RegistryUsername" Write-Host "Will check for image $UserImage - if it does not exist but $UpstreamImage does, we copy that one, otherwise we need to build it." if ($BaseImage) { Write-Host "This image builds on $BaseImage so we will check for it." if ($BaseUpstreamImage) { Write-Host "If it is missing but $BaseUpstreamImage exists, we copy that one. If both are missing, we error out." - } else { + } + else { Write-Host "If it is missing, we error out." } } -# Start-Docker -ArgumentList ("login", "-u", "$RegistryUsername", "--password-stdin", "$RegistryPassword", "$RegistryUri") -$loginProc = Start-Process -FilePath "docker" -ArgumentList ($CommonDockerArgs + @("login", "-u", "$RegistryUsername", "--password", "$RegistryPassword", "$RegistryUri")) ` - -NoNewWindow -PassThru -WorkingDirectory "$PSScriptRoot" -Wait -if ($loginProc.ExitCode -ne 0) { - throw "docker login failed" +if ($RegistryPassword) { + # Start-Docker -ArgumentList ("login", "-u", "$RegistryUsername", "--password-stdin", "$RegistryPassword", "$RegistryUri") + $loginProc = Start-Process -FilePath "docker" -ArgumentList ($CommonDockerArgs + @("login", "-u", "$RegistryUsername", "--password", "$RegistryPassword", "$RegistryUri")) ` + -NoNewWindow -PassThru -WorkingDirectory "$PSScriptRoot" -Wait + if ($loginProc.ExitCode -ne 0) { + throw "docker login failed" + } +} +else { + Write-Host "Skipping docker login, password not available" } # if the image already exists, don't rebuild it @@ -194,4 +204,10 @@ Get-Date Write-Host "Done building image, now pushing $UserImage" Start-Docker -LogoutOnFailure -ArgumentList ("push", "$UserImage") -Start-Docker -ArgumentList ("logout", "$RegistryUri") + +if ($RegistryPassword) { + Start-Docker -ArgumentList ("logout", "$RegistryUri") +} +else { + Write-Host "Skipping docker logout, password not available so we did not login" +}