Skip to content

Commit

Permalink
test(e2e): draft of the tests on windows
Browse files Browse the repository at this point in the history
test(e2e): added windows to pr check

test(e2e): fixed ubuntu error

test(e2e): fixed windows error

test(e2e): fixed windows error - part 2

test(e2e): fixed windows error - part 3

test(e2e): triggering pr-check

test(e2e): ditch jq in windows

test(e2e): testing why podman is not found

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): install podman in the tests workflow for windows

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): use docker to build extension image

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): swap docker's execution mode to linux

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): revert previous commit

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): new version of build step

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): building locally the extension

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): fix relative path

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): build extension once before test matrix

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): revert - build extension once before test matrix

This reverts commit de5650b.

test(e2e): swap pnpm to yarn

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): add cache management + frozen lockfile

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): remove frozen lockfile, add previous steps to run only on windows

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): try to sync yarn dependencies

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): fix encoding issue package.json

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): new version of getting podman desktop version

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): add missing working directory

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): add --platform to docker pull

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): add buildx to use linux images on windows

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): revert -  add buildx to use linux images on windows

This reverts commit 76ff106.

test(e2e): build sso image locally too

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): missing pnpm install on sso extension

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): clean up, fix artifact upload

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): more cleanup + squash

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): added stacktrace to check why the test breaks

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): change path of sso extension build to correct one

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): revert try-catch clause, added e2e-tests job to e2e-main

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): removed unnecesary 'page'

Signed-off-by: Daniel Villanueva <[email protected]>

test(e2e): skip local build on linux

Signed-off-by: Daniel Villanueva <[email protected]>
  • Loading branch information
danivilla9 committed Dec 16, 2024
1 parent 40acd61 commit 10c3944
Show file tree
Hide file tree
Showing 3 changed files with 154 additions and 25 deletions.
101 changes: 85 additions & 16 deletions .github/workflows/e2e-main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,19 +41,18 @@ on:

jobs:
e2e-tests:
name: Run E2E tests
runs-on: ubuntu-24.04
name: e2e tests for ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [windows-2022, ubuntu-24.04] #, macos-14
runs-on: ${{ matrix.os }}
env:
SKIP_INSTALLATION: true
steps:
# Checkout crc extension
- uses: actions/checkout@v4
if: github.event_name == 'workflow_dispatch'
with:
repository: ${{ github.event.inputs.organization }}/${{ github.event.inputs.repositoryName }}
ref: ${{ github.event.inputs.branch }}
path: ${{ github.event.inputs.repositoryName }}

- uses: actions/checkout@v4
if: github.event_name == 'schedule'
with:
path: crc-extension

# Checkout podman desktop
Expand All @@ -63,6 +62,14 @@ jobs:
ref: main
path: podman-desktop

# Checkout sso extension
- uses: actions/checkout@v4
if: matrix.os == 'windows-2022'
with:
repository: redhat-developer/podman-desktop-redhat-account-ext
ref: main
path: sso-extension

- uses: actions/setup-node@v4
with:
node-version: 20
Expand All @@ -73,39 +80,101 @@ jobs:
run_install: false
package_json_file: ./podman-desktop/package.json

- name: Execute pnpm
- name: Install Podman Desktop dependencies
working-directory: ./podman-desktop
run: pnpm install

- name: Install SSO extension dependencies
if: matrix.os == 'windows-2022'
working-directory: ./sso-extension
run: pnpm install

- name: Build Podman Desktop for E2E tests
working-directory: ./podman-desktop
run: pnpm test:e2e:build

- name: Ensure getting current HEAD version of the test framework
- name: Adjust/Downgrade local podman desktop version Windows
if: matrix.os == 'windows-2022'
working-directory: ./crc-extension
run: |
$version="1.0.0"
jq --arg version "$version" '.version = $version' package.json | Out-File -FilePath package.json_tmp
Move-Item -Path package.json_tmp -Destination package.json -Force
- name: Ensure getting current HEAD version of the test framework (ubuntu)
if: matrix.os == 'ubuntu-24.04'
working-directory: ./crc-extension
run: |
# workaround for https://github.com/containers/podman-desktop-extension-bootc/issues/712
version=$(npm view @podman-desktop/tests-playwright@next version)
echo "Version of @podman-desktop/tests-playwright to be used: $version"
jq --arg version "$version" '.devDependencies."@podman-desktop/tests-playwright" = $version' package.json > package.json_tmp && mv package.json_tmp package.json
shell: bash

- name: Synchronize CRC extension dependencies
working-directory: ./crc-extension
run: yarn install --check-files

- name: Execute yarn in OpenShift Local Extension
working-directory: ./crc-extension
run: yarn
run: yarn --frozen-lockfile

- name: Revert unprivileged user namespace restrictions in Ubuntu 24.04
if: matrix.os == 'ubuntu-24.04'
run: |
# allow unprivileged user namespace
sudo sysctl -w kernel.apparmor_restrict_unprivileged_userns=0
- name: Build OpenShift Local extension from container file and SSO dependency (Ubuntu, podman)
if: matrix.os == 'ubuntu-24.04'
working-directory: ./crc-extension
run: |
# build crc extension
podman build -t openshift_local_image . -f ./oci/Containerfile.multistage
CONTAINER_ID_CRC=$(podman create localhost/openshift_local_image --entrypoint "")
podman export $CONTAINER_ID_CRC > /tmp/openshift_local_extension.tar
# build sso extension
podman pull ghcr.io/redhat-developer/podman-desktop-redhat-account-ext:latest
CONTAINER_ID_SSO=$(podman create ghcr.io/redhat-developer/podman-desktop-redhat-account-ext --entrypoint "")
podman export $CONTAINER_ID_SSO > /tmp/sso_extension.tar
# move extension files to expected locations
mkdir -p tests/playwright/output/crc-tests-pd/plugins
tar -xf /tmp/openshift_local_extension.tar -C tests/playwright/output/crc-tests-pd/plugins/
mv tests/playwright/output/crc-tests-pd/plugins/extension/ tests/playwright/output/crc-tests-pd/plugins/crcextension
tar -xf /tmp/sso_extension.tar -C tests/playwright/output/crc-tests-pd/plugins/
mv tests/playwright/output/crc-tests-pd/plugins/extension/ tests/playwright/output/crc-tests-pd/plugins/ssoextension
- name: Build OpenShift Local extension locally (Windows, docker) #from container file is not available yet
if: matrix.os == 'windows-2022'
working-directory: ./crc-extension
shell: pwsh
run: |
# generate 'openshift-local.cdix':
yarn build
# put the contents into its expected folder:
New-Item -ItemType Directory -Path tests\playwright\output\crc-tests-pd\plugins -Force
Expand-Archive -Path "$(pwd)\openshift-local.cdix" -DestinationPath ".\tests\playwright\output\crc-tests-pd\plugins\crcextension"
- name: Build SSO extension (crc dependency) locally (Windows, docker) #from container file is not available yet
if: matrix.os == 'windows-2022'
working-directory: ./sso-extension
shell: pwsh
run: |
# generate 'redhat-authentication.cdix':
pnpm build
# put the contents into its expected folder (parent folder created in previous step):
Expand-Archive -Path "$(pwd)\redhat-authentication.cdix" -DestinationPath "..\crc-extension\tests\playwright\output\crc-tests-pd\plugins\ssoextension"
- name: Run All E2E tests
working-directory: ./crc-extension
env:
PODMAN_DESKTOP_ARGS: ${{ github.workspace }}/podman-desktop
run: yarn test:e2e

- uses: actions/upload-artifact@v4
if: always()
with:
name: e2e-tests
name: e2e-tests-${{ matrix.os }}
path: ./**/tests/**/output/
76 changes: 68 additions & 8 deletions .github/workflows/pr-check.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -120,11 +120,16 @@ jobs:
run: yarn test

e2e-tests:
name: e2e tests
runs-on: ubuntu-24.04 #20.04?
name: e2e tests for ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [windows-2022, ubuntu-24.04] #, macos-14
runs-on: ${{ matrix.os }}
env:
SKIP_INSTALLATION: true
steps:
# Checkout crc extension
- uses: actions/checkout@v4
with:
path: crc-extension
Expand All @@ -136,6 +141,14 @@ jobs:
ref: main
path: podman-desktop

# Checkout sso extension
- uses: actions/checkout@v4
if: matrix.os == 'windows-2022'
with:
repository: redhat-developer/podman-desktop-redhat-account-ext
ref: main
path: sso-extension

- uses: actions/setup-node@v4
with:
node-version: 20
Expand All @@ -146,46 +159,93 @@ jobs:
run_install: false
package_json_file: ./podman-desktop/package.json

- name: Execute pnpm
- name: Install Podman Desktop dependencies
working-directory: ./podman-desktop
run: pnpm install

- name: Install SSO extension dependencies
if: matrix.os == 'windows-2022'
working-directory: ./sso-extension
run: pnpm install

- name: Build Podman Desktop for E2E tests
working-directory: ./podman-desktop
run: pnpm test:e2e:build

- name: Adjust/Downgrade local podman desktop version Windows
if: matrix.os == 'windows-2022'
working-directory: ./crc-extension
run: |
$version="1.0.0"
jq --arg version "$version" '.version = $version' package.json | Out-File -FilePath package.json_tmp
Move-Item -Path package.json_tmp -Destination package.json -Force
- name: Ensure getting current HEAD version of the test framework
- name: Ensure getting current HEAD version of the test framework (ubuntu)
if: matrix.os == 'ubuntu-24.04'
working-directory: ./crc-extension
run: |
# workaround for https://github.com/containers/podman-desktop-extension-bootc/issues/712
version=$(npm view @podman-desktop/tests-playwright@next version)
echo "Version of @podman-desktop/tests-playwright to be used: $version"
jq --arg version "$version" '.devDependencies."@podman-desktop/tests-playwright" = $version' package.json > package.json_tmp && mv package.json_tmp package.json
shell: bash

- name: Synchronize CRC extension dependencies
working-directory: ./crc-extension
run: yarn install --check-files

- name: Execute yarn in OpenShift Local Extension
working-directory: ./crc-extension
run: yarn
run: yarn --frozen-lockfile

- name: Revert unprivileged user namespace restrictions in Ubuntu 24.04
if: matrix.os == 'ubuntu-24.04'
run: |
# allow unprivileged user namespace
sudo sysctl -w kernel.apparmor_restrict_unprivileged_userns=0
- name: Build OpenShift Local extension from container file
- name: Build OpenShift Local extension from container file and SSO dependency (Ubuntu, podman)
if: matrix.os == 'ubuntu-24.04'
working-directory: ./crc-extension
run: |
# build crc extension
podman build -t openshift_local_image . -f ./oci/Containerfile.multistage
CONTAINER_ID_CRC=$(podman create localhost/openshift_local_image --entrypoint "")
podman export $CONTAINER_ID_CRC > /tmp/openshift_local_extension.tar
mkdir -p tests/playwright/output/crc-tests-pd/plugins
# build sso extension
podman pull ghcr.io/redhat-developer/podman-desktop-redhat-account-ext:latest
CONTAINER_ID_SSO=$(podman create ghcr.io/redhat-developer/podman-desktop-redhat-account-ext --entrypoint "")
podman export $CONTAINER_ID_SSO > /tmp/sso_extension.tar
# move extension files to expected locations
mkdir -p tests/playwright/output/crc-tests-pd/plugins
tar -xf /tmp/openshift_local_extension.tar -C tests/playwright/output/crc-tests-pd/plugins/
mv tests/playwright/output/crc-tests-pd/plugins/extension/ tests/playwright/output/crc-tests-pd/plugins/crcextension
tar -xf /tmp/sso_extension.tar -C tests/playwright/output/crc-tests-pd/plugins/
mv tests/playwright/output/crc-tests-pd/plugins/extension/ tests/playwright/output/crc-tests-pd/plugins/ssoextension
- name: Build OpenShift Local extension locally (Windows, docker) #from container file is not available yet
if: matrix.os == 'windows-2022'
working-directory: ./crc-extension
shell: pwsh
run: |
# generate 'openshift-local.cdix':
yarn build
# put the contents into its expected folder:
New-Item -ItemType Directory -Path tests\playwright\output\crc-tests-pd\plugins -Force
Expand-Archive -Path "$(pwd)\openshift-local.cdix" -DestinationPath ".\tests\playwright\output\crc-tests-pd\plugins\crcextension"
- name: Build SSO extension (crc dependency) locally (Windows, docker) #from container file is not available yet
if: matrix.os == 'windows-2022'
working-directory: ./sso-extension
shell: pwsh
run: |
# generate 'redhat-authentication.cdix':
pnpm build
# put the contents into its expected folder (parent folder created in previous step):
Expand-Archive -Path "$(pwd)\redhat-authentication.cdix" -DestinationPath "..\crc-extension\tests\playwright\output\crc-tests-pd\plugins\ssoextension"
- name: Run All E2E tests
working-directory: ./crc-extension
env:
Expand All @@ -195,5 +255,5 @@ jobs:
- uses: actions/upload-artifact@v4
if: always()
with:
name: e2e-tests
name: e2e-tests-${{ matrix.os }}
path: ./**/tests/**/output/
2 changes: 1 addition & 1 deletion tests/src/openshift-local-extension.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ test.describe.serial('Red Hat OpenShift Local extension verification', () => {
test('Extension\'s details show correct status, no error', async ({ page,navigationBar }) => {
const extensions = await navigationBar.openExtensions();
const extensionCard = await extensions.getInstalledExtension(extensionLabelNameCrc, extensionLabelCrc);
await extensionCard.openExtensionDetails('Red Hat Authentication');
await extensionCard.openExtensionDetails('Red Hat OpenShift Local');
const details = new OpenShiftLocalExtensionPage(page);
await playExpect(details.heading).toBeVisible();
await playExpect(details.status).toHaveText(activeExtensionStatus);
Expand Down

0 comments on commit 10c3944

Please sign in to comment.