From 10f155f7efb393309c77441bb8701146ab1f570f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edu=20G=C3=B3mez=20Escandell?= Date: Wed, 13 Sep 2023 16:33:19 +0200 Subject: [PATCH] Create qa-azure workflow --- .github/workflows/qa-azure.yaml | 123 ++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 .github/workflows/qa-azure.yaml diff --git a/.github/workflows/qa-azure.yaml b/.github/workflows/qa-azure.yaml new file mode 100644 index 000000000..a27b793c1 --- /dev/null +++ b/.github/workflows/qa-azure.yaml @@ -0,0 +1,123 @@ +name: QA on Azure +# QA checks on Azure, allowing the use of a real WSL back-en + +concurrency: azure-vm + +on: + pull_request: + workflow_dispatch: + push: + branches: [main] + +env: + az_name: wsl-ci-3 + az_resource_group: wsl + +jobs: + vm-setup: + name: Set up Azure VM + runs-on: ubuntu-latest + steps: + - name: Azure login + uses: azure/login@v1 + 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 + steps: + - name: Set up git + uses: canonical/ubuntu-pro-for-windows/.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" + - name: Set up Go + # actions/setup-go is broken + shell: powershell + run: | + winget install GoLang.Go + Exit(0) + - name: Download Appx + uses: dawidd6/action-download-artifact@v2 + with: + workflow: qa.yaml + workflow_conclusion: success + name: UbuntuProForWindows+.* + name_is_regexp: true + path: ci-artifacts + - name: Download Wsl-Pro-Service + uses: dawidd6/action-download-artifact@v2 + with: + workflow: qa.yaml + workflow_conclusion: success + name: wsl-pro-service_.* + name_is_regexp: true + path: ci-artifacts + - name: Set up artifacts + shell: powershell + working-directory: ci-artifacts + run: | + Write-Output "::group::Set up AppxPackage" + Get-AppxPackage -Name "CanonicalGroupLimited.UbuntuProForWindows" | Remove-AppxPackage -ErrorAction Ignore + + New-Item -Name "windows-agent" -ItemType Directory + Move-Item -Path "UbuntuProForWindows_*/UbuntuProForWindows_*/*" -Destination "windows-agent/" + Remove-Item -Recurse "UbuntuProForWindows_*" + + $pwd = ConvertTo-SecureString '${{ secrets.CERTIFICATE_PASSWORD }}' -AsPlainText -Force + Import-PfxCertificate -Password $pwd -CertStoreLocation Cert:LocalMachine\Trust -FilePath "windows-agent/UbuntuProForWindows_*.cer" + + Write-Output "::endgroup::" + + Write-Output "::group::Set up WSL Pro Service" + Rename-Item -Path "wsl-pro-service_*/" -NewName "wsl-pro-service" + Write-Output "::endgroup::" + - 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.UbuntuProForWindows" | Remove-AppxPackage -ErrorAction Ignore + + 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@v1 + 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 }}