fix(agent): Don't bail out if we cannot find a WSL adapter #2072
Workflow file for this run
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: Build and run end-to-end tests | |
# Builds the project, and runs end-to-end tests using the generated artifacts. | |
concurrency: azure-vm | |
on: | |
pull_request: | |
paths-ignore: | |
- docs/** | |
- '*.md' | |
workflow_dispatch: | |
push: | |
branches: [main] | |
env: | |
az_name: wsl-ci-3 | |
az_resource_group: wsl | |
jobs: | |
build-wsl-pro-service: | |
name: Build wsl-pro-service debian package | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v4 | |
with: | |
fetch-tags: true | |
fetch-depth: 0 | |
- name: Build debian package | |
uses: canonical/desktop-engineering/gh-actions/common/build-debian@main | |
with: | |
source-dir: wsl-pro-service | |
token: ${{ secrets.GITHUB_TOKEN }} | |
docker-image: ubuntu:devel | |
env: | |
UP4W_SKIP_INTERNAL_DEPENDENCY_UPDATE: "1" | |
build-ubuntu-pro-for-wsl: | |
strategy: | |
matrix: | |
mode: ["production", "end_to_end_tests"] | |
name: Build Windows Agent Appx | |
runs-on: windows-latest | |
steps: | |
- name: Set up git | |
uses: canonical/ubuntu-pro-for-wsl/.github/actions/setup-git@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Check out repository | |
uses: actions/checkout@v4 | |
with: | |
fetch-tags: true | |
fetch-depth: 0 | |
- uses: actions/setup-go@v5 | |
with: | |
go-version-file: go.work | |
- name: Read flutter version | |
id: flutter-version | |
uses: ./.github/actions/read-file | |
with: | |
path: tools/flutter-version | |
- uses: subosito/flutter-action@v2 | |
with: | |
channel: stable | |
flutter-version: ${{ steps.flutter-version.outputs.contents }} | |
- name: Setup MSBuild (PATH) | |
uses: microsoft/setup-msbuild@v2 | |
- name: Install certificate | |
shell: powershell | |
run: | | |
New-Item -ItemType directory -Path certificate | |
Set-Content -Path certificate\certificate.txt -Value '${{ secrets.CERTIFICATE }}' | |
certutil -decode certificate\certificate.txt certificate\certificate.pfx | |
$pwd = ConvertTo-SecureString '${{ secrets.CERTIFICATE_PASSWORD }}' -AsPlainText -Force | |
Import-PfxCertificate -Password $pwd -CertStoreLocation Cert:LocalMachine\Trust -FilePath certificate\certificate.pfx | |
Import-PfxCertificate -Password $pwd -CertStoreLocation Cert:CurrentUser\My -FilePath certificate\certificate.pfx | |
- name: Build Bundle | |
run: | | |
# Set up the full version (displayed in logs) | |
$env:UP4W_FULL_VERSION=$(go run .\tools\build\compute_version.go) | |
# Set up the numeric version (used in the AppxManifest) | |
$UP4W_VERSION=$(go run .\tools\build\compute_version.go --numeric) | |
[Reflection.Assembly]::LoadWithPartialName("System.Xml.Linq") | |
$path = "$PWD/Msix/UbuntuProForWSL/Package.appxmanifest" | |
$doc = [System.Xml.Linq.XDocument]::Load($path) | |
$xName = [System.Xml.Linq.XName]::Get("{http://schemas.microsoft.com/appx/manifest/foundation/windows10}Identity") | |
$doc.Root.Element($xName).Attribute("Version").Value = "$UP4W_VERSION.0"; | |
$doc.Save($path) | |
# Set up the mock | |
$env:UP4W_TEST_WITH_MS_STORE_MOCK=${{ matrix.mode == 'end_to_end_tests' && '1' || '$null'}} | |
# Build | |
msbuild ` | |
.\msix\msix.sln ` | |
-target:Build ` | |
-maxCpuCount ` | |
-nodeReuse:false ` | |
-property:Configuration=${{ matrix.mode == 'production' && 'Release' || 'Debug'}} ` | |
-property:AppxBundle=Always ` | |
-property:AppxBundlePlatforms=x64 ` | |
-property:UapAppxPackageBuildMode=SideloadOnly ` | |
-property:Version=0.0.1+${{ github.sha }} ` | |
-property:UP4W_END_TO_END=${{ matrix.mode == 'end_to_end_tests' }} ` | |
-nologo ` | |
-verbosity:normal | |
- name: Upload sideload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: UbuntuProForWSL+${{ github.sha }}-${{ matrix.mode }} | |
path: | | |
msix/UbuntuProForWSL/AppPackages/UbuntuProForWSL_*/UbuntuProForWSL_*.cer | |
msix/UbuntuProForWSL/AppPackages/UbuntuProForWSL_*/UbuntuProForWSL_*.msixbundle | |
vm-setup: | |
name: Set up Azure VM | |
runs-on: ubuntu-latest | |
steps: | |
- name: Azure login | |
uses: azure/login@v2 | |
with: | |
creds: ${{ secrets.AZURE_VM_CREDS }} | |
- name: Start the Runner | |
shell: bash | |
run: | | |
az vm start --name ${{ env.az_name }} --resource-group ${{ env.az_resource_group }} | |
qa: | |
name: Run end-to-end tests on the Azure VM | |
runs-on: [self-hosted, Windows] | |
needs: [vm-setup, build-wsl-pro-service, build-ubuntu-pro-for-wsl] | |
steps: | |
- name: Set up git | |
uses: canonical/ubuntu-pro-for-wsl/.github/actions/setup-git@main | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Set up Ubuntu | |
uses: Ubuntu/WSL/.github/actions/wsl-install@main | |
with: | |
distro: "Ubuntu-Preview" | |
- name: Set up Go | |
# actions/setup-go is broken | |
shell: powershell | |
run: | | |
winget install GoLang.Go --accept-source-agreements --accept-package-agreements --silent --verbose | |
# Cannot check for error: there is no way to distinguish the two: | |
# - Legitimate error | |
# - Error because no updates found (Golang.Go is already up to date) | |
# | |
# We can check that Go works, though. | |
go version | |
- name: Download artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
# name: is left blank so that all artifacts are downloaded | |
path: ci-artifacts | |
- name: Set up artifacts | |
shell: powershell | |
working-directory: ci-artifacts | |
run: | | |
Write-Output "::group::Set up AppxPackage" | |
Get-AppxPackage -Name "CanonicalGroupLimited.UbuntuPro" | Remove-AppxPackage -ErrorAction Ignore | |
New-Item -Name "windows-agent" -ItemType Directory | |
Move-Item -Path "UbuntuProForWSL+*-end_to_end_tests/UbuntuProForWSL_*/*.msixbundle" -Destination "windows-agent/" | |
Move-Item -Path "UbuntuProForWSL+*-end_to_end_tests/UbuntuProForWSL_*/*.cer" -Destination "windows-agent/" | |
Remove-Item -Recurse "UbuntuProForWSL+*/" | |
$cert = "$(Get-ChildItem windows-agent/UbuntuProForWSL_*.cer)" | |
Import-Certificate -FilePath "${cert}" -CertStoreLocation Cert:LocalMachine\TrustedPeople | |
Write-Output "::endgroup::" | |
Write-Output "::group::Set up WSL Pro Service" | |
New-Item -Name "wsl-pro-service" -ItemType Directory | |
Move-Item -Path "wsl-pro-service_*/wsl-pro-service_*.deb" -Destination "wsl-pro-service/" | |
Remove-Item -Recurse "wsl-pro-service_*/" | |
Write-Output "::endgroup::" | |
# Installing a debug version of VCLibs from the SDK is required, otherwise installing the Ubuntu pro debug appx will fail. | |
- name: Install Debug version of VCLibs | |
shell: powershell | |
run: Add-AppxPackage "C:\Program Files (x86)\Microsoft SDKs\Windows Kits\10\ExtensionSDKs\Microsoft.VCLibs.Desktop\14.0\Appx\Debug\x64\Microsoft.VCLibs.x64.Debug.14.00.Desktop.appx" | |
- name: Test | |
shell: powershell | |
env: | |
GIT_TERMINAL_PROMPT: "0" | |
UP4W_TEST_OVERRIDE_DESTRUCTIVE_CHECKS: "1" | |
UP4W_TEST_BUILD_PATH: "../ci-artifacts" | |
UP4W_TEST_PRO_TOKEN: "${{ secrets.UBUNTU_PRO_TOKEN }}" | |
run: | | |
go env -w "GOPRIVATE=github.com/${{ github.repository }}" | |
go test .\end-to-end -shuffle=on -timeout 20m | |
if ( "$LastExitCode" -ne "0" ) { Exit(1) } | |
- name: Clean up | |
if: always() | |
shell: powershell | |
run: | | |
# Clean up artifacts | |
# Remove .gitconfig so that the github URL overrides do not stack | |
Remove-Item -Recurse -Path "${HOME}\.gitconfig" -ErrorAction Ignore | |
# Uninstall Appx | |
Get-AppxPackage -Name "CanonicalGroupLimited.UbuntuPro" | Remove-AppxPackage -ErrorAction Ignore | |
# Uninstall certificate | |
$thumbprint = (Get-PfxCertificate -FilePath "ci-artifacts\windows-agent\UbuntuProForWSL_*.cer").Thumbprint | |
Remove-Item -Path "Cert:LocalMachine\TrustedPeople\${thumbprint}" | |
stop-vm: | |
name: Clean up the Azure VM | |
runs-on: ubuntu-latest | |
needs: [vm-setup, qa] | |
if: always() | |
steps: | |
- name: Azure login | |
uses: azure/login@v2 | |
with: | |
creds: ${{ secrets.AZURE_VM_CREDS }} | |
- name: Deallocate the Runner | |
shell: bash | |
run: | | |
az vm deallocate --name ${{ env.az_name }} --resource-group ${{ env.az_resource_group }} |