chore(deps-dev): Bump electron from 33.3.1 to 34.0.0 #211
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: Podman Desktop SSO E2E Nightly | |
on: | |
push: | |
branches: | |
- main | |
workflow_dispatch: | |
inputs: | |
fork: | |
default: 'podman-desktop' | |
description: 'Podman Desktop repo fork' | |
type: string | |
required: true | |
branch: | |
default: 'main' | |
description: 'Podman Desktop repo branch' | |
type: string | |
required: true | |
ext_repo_options: | |
default: 'REPO=podman-desktop-redhat-account-ext,FORK=redhat-developer,BRANCH=main' | |
description: 'Podman Desktop Extension repo, fork and branch' | |
type: string | |
required: true | |
ext_tests: | |
default: '1' | |
description: 'Run E2E tests from extension' | |
type: string | |
required: true | |
npm_target: | |
default: 'test:e2e' | |
description: 'npm target to run tests' | |
type: string | |
required: true | |
podman_remote_url: | |
default: 'https://github.com/containers/podman/releases/download/v5.3.1/podman-5.3.1-setup.exe' | |
description: 'podman setup exe' | |
type: string | |
required: true | |
podman_options: | |
default: 'INIT=1,START=1,ROOTFUL=1,NETWORKING=0' | |
description: 'Podman machine configuration options, no spaces' | |
type: 'string' | |
required: true | |
env_vars: | |
default: 'TEST_PODMAN_MACHINE=true' | |
description: 'Env. Variables passed into target machine, ie: VAR1=xxx,VAR2=true,VAR3=15,VAR4="Pass me along"' | |
type: 'string' | |
required: true | |
podman_provider: | |
default: 'wsl' | |
description: 'Podman virtualization provider' | |
type: 'string' | |
required: true | |
jobs: | |
windows: | |
name: windows-${{ matrix.windows-version }}-${{ matrix.windows-featurepack }} | |
runs-on: ubuntu-latest | |
env: | |
MAPT_VERSION: v0.7.2 | |
MAPT_IMAGE: quay.io/redhat-developer/mapt | |
strategy: | |
fail-fast: false | |
matrix: | |
windows-version: ['11'] | |
windows-featurepack: ['24h2-ent'] | |
steps: | |
- name: Get Podman version used by Desktop | |
run: | | |
version=$(curl https://raw.githubusercontent.com/containers/podman-desktop/main/extensions/podman/packages/extension/src/podman5.json | jq -r '.version') | |
echo "Default Podman Version from Podman Desktop: ${version}" | |
echo "PD_PODMAN_VERSION=${version}" >> $GITHUB_ENV | |
- name: Set the default env. variables | |
env: | |
DEFAULT_FORK: 'podman-desktop' | |
DEFAULT_BRANCH: 'main' | |
DEFAULT_EXT_TESTS: '1' | |
DEFAULT_NPM_TARGET: 'test:e2e' | |
DEFAULT_ENV_VARS: 'TEST_PODMAN_MACHINE=true' | |
DEFAULT_PODMAN_OPTIONS: 'INIT=1,START=1,ROOTFUL=1,NETWORKING=0' | |
DEFAULT_PODMAN_PROVIDER: 'wsl' | |
DEFAULT_EXT_REPO_OPTIONS: 'REPO=podman-desktop-redhat-account-ext,FORK=redhat-developer,BRANCH=main' | |
DEFAULT_URL: "https://github.com/containers/podman/releases/download/v$DEFAULT_VERSION/podman-$DEFAULT_VERSION-setup.exe" | |
DEFAULT_IMAGES_VERSIONS: 'BUILDER="v0.0.3",PODMAN="v0.0.3",RUNNER="v0.0.3"' | |
run: | | |
echo "FORK=${{ github.event.inputs.fork || env.DEFAULT_FORK }}" >> $GITHUB_ENV | |
echo "BRANCH=${{ github.event.inputs.branch || env.DEFAULT_BRANCH }}" >> $GITHUB_ENV | |
echo "NPM_TARGET=${{ github.event.inputs.npm_target || env.DEFAULT_NPM_TARGET }}" >> $GITHUB_ENV | |
echo "ENV_VARS=${{ github.event.inputs.env_vars || env.DEFAULT_ENV_VARS }}" >> $GITHUB_ENV | |
echo "PODMAN_PROVIDER=${{ github.event.inputs.podman_provider || env.DEFAULT_PODMAN_PROVIDER }}" >> $GITHUB_ENV | |
echo "PODMAN_URL=${{ github.event.inputs.podman_remote_url || env.DEFAULT_URL }}" >> $GITHUB_ENV | |
echo "EXT_TESTS=${{ github.event.inputs.ext_tests || env.DEFAULT_EXT_TESTS }}" >> $GITHUB_ENV | |
echo "${{ github.event.inputs.podman_options || env.DEFAULT_PODMAN_OPTIONS }}" | awk -F ',' \ | |
'{for (i=1; i<=NF; i++) {split($i, kv, "="); print "PODMAN_"kv[1]"="kv[2]}}' >> $GITHUB_ENV | |
echo "${{ github.event.inputs.ext_repo_options || env.DEFAULT_EXT_REPO_OPTIONS }}" | awk -F ',' \ | |
'{for (i=1; i<=NF; i++) {split($i, kv, "="); print "EXT_"kv[1]"="kv[2]}}' >> $GITHUB_ENV | |
- name: Create instance | |
run: | | |
# Create instance | |
podman run -d --name windows-create --rm \ | |
-v ${PWD}:/workspace:z \ | |
-e ARM_TENANT_ID=${{ secrets.ARM_TENANT_ID }} \ | |
-e ARM_SUBSCRIPTION_ID=${{ secrets.ARM_SUBSCRIPTION_ID }} \ | |
-e ARM_CLIENT_ID=${{ secrets.ARM_CLIENT_ID }} \ | |
-e ARM_CLIENT_SECRET='${{ secrets.ARM_CLIENT_SECRET }}' \ | |
${{ env.MAPT_IMAGE }}:${{ env.MAPT_VERSION }} azure \ | |
windows create \ | |
--project-name 'windows-desktop' \ | |
--backed-url 'file:///workspace' \ | |
--conn-details-output '/workspace' \ | |
--windows-version '${{ matrix.windows-version }}' \ | |
--windows-featurepack '${{ matrix.windows-featurepack }}' \ | |
--nested-virt \ | |
--cpus 8 \ | |
--memory 16 \ | |
--tags project=podman-desktop \ | |
--spot | |
# Check logs | |
podman logs -f windows-create | |
- name: Check instance system info | |
run: | | |
ssh -i id_rsa \ | |
-o StrictHostKeyChecking=no \ | |
-o UserKnownHostsFile=/dev/null \ | |
-o ServerAliveInterval=30 \ | |
-o ServerAliveCountMax=1200 \ | |
$(cat username)@$(cat host) "systeminfo" | |
- name: Emulate X session | |
run: | | |
# use fake rdp to emulate an active x session | |
podman run -d --name x-session \ | |
-e RDP_HOST=$(cat host) \ | |
-e RDP_USER=$(cat username) \ | |
-e RDP_PASSWORD=$(cat userpassword) \ | |
quay.io/rhqp/frdp:v0.0.1 | |
# Wait until the x session has been created | |
podman wait --condition running x-session | |
# Check logs for the x session | |
podman logs x-session | |
- name: Download Podman nightly, do not initialize and start | |
run: | | |
podman run --rm -d --name pde2e-podman-run \ | |
-e TARGET_HOST=$(cat host) \ | |
-e TARGET_HOST_USERNAME=$(cat username) \ | |
-e TARGET_HOST_KEY_PATH=/data/id_rsa \ | |
-e TARGET_FOLDER=pd-e2e \ | |
-e TARGET_CLEANUP=false \ | |
-e TARGET_RESULTS=results \ | |
-e OUTPUT_FOLDER=/data \ | |
-e DEBUG=true \ | |
-v $PWD:/data:z \ | |
quay.io/odockal/pde2e-podman:${{ env.PDE2E_PODMAN }}-windows \ | |
pd-e2e/podman.ps1 \ | |
-downloadUrl ${{ env.PODMAN_URL }} \ | |
-targetFolder pd-e2e \ | |
-resultsFolder results \ | |
-podmanProvider ${{ env.PODMAN_PROVIDER }} \ | |
-initialize 0 \ | |
-rootful 0 \ | |
-start 0 \ | |
-installWSL 0 | |
# check logs | |
podman logs -f pde2e-podman-run | |
- name: Run Podman Desktop Playwright E2E tests | |
run: | | |
podman run -d --name pde2e-runner-run \ | |
-e TARGET_HOST=$(cat host) \ | |
-e TARGET_HOST_USERNAME=$(cat username) \ | |
-e TARGET_HOST_KEY_PATH=/data/id_rsa \ | |
-e TARGET_FOLDER=pd-e2e \ | |
-e TARGET_RESULTS=results \ | |
-e TARGET_CLEANUP=false \ | |
-e OUTPUT_FOLDER=/data \ | |
-e DEBUG=true \ | |
-v $PWD:/data:z \ | |
quay.io/odockal/pde2e-runner:${{ env.PDE2E_RUNNER }}-windows \ | |
pd-e2e/runner.ps1 \ | |
-targetFolder pd-e2e \ | |
-resultsFolder results \ | |
-podmanPath $(cat results/podman-location.log) \ | |
-fork ${{ env.FORK }} \ | |
-branch ${{ env.BRANCH }} \ | |
-extRepo ${{ env.EXT_REPO }} \ | |
-extFork ${{ env.EXT_FORK }} \ | |
-extBranch ${{ env.EXT_BRANCH }} \ | |
-extTests ${{ env.EXT_TESTS }} \ | |
-npmTarget ${{ env.NPM_TARGET }} \ | |
-initialize ${{ env.PODMAN_INIT }} \ | |
-rootful ${{ env.PODMAN_ROOTFUL }} \ | |
-start ${{ env.PODMAN_START }} \ | |
-userNetworking ${{ env.PODMAN_NETWORKING }} \ | |
-podmanProvider ${{ env.PODMAN_PROVIDER }} \ | |
-envVars ${{ env.ENV_VARS }} | |
# check logs | |
podman logs -f pde2e-runner-run | |
- name: Destroy instance | |
if: always() | |
run: | | |
# Destroy instance | |
podman run -d --name windows-destroy --rm \ | |
-v ${PWD}:/workspace:z \ | |
-e ARM_TENANT_ID=${{ secrets.ARM_TENANT_ID }} \ | |
-e ARM_SUBSCRIPTION_ID=${{ secrets.ARM_SUBSCRIPTION_ID }} \ | |
-e ARM_CLIENT_ID=${{ secrets.ARM_CLIENT_ID }} \ | |
-e ARM_CLIENT_SECRET='${{ secrets.ARM_CLIENT_SECRET }}' \ | |
${{ env.MAPT_IMAGE }}:${{ env.MAPT_VERSION }} azure \ | |
windows destroy \ | |
--project-name 'windows-desktop' \ | |
--backed-url 'file:///workspace' | |
# Check logs | |
podman logs -f windows-destroy | |
- name: Publish Test Report | |
uses: mikepenz/action-junit-report@v5 | |
if: always() # always run even if the previous step fails | |
with: | |
fail_on_failure: true | |
include_passed: true | |
annotate_only: true | |
detailed_summary: true | |
require_tests: true | |
report_paths: '**/*results.xml' | |
- name: Upload test artifacts | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: results-e2e-${{ matrix.windows-version }}${{ matrix.windows-featurepack }} | |
path: | | |
results/* |