Skip to content

Commit

Permalink
End-to-end testing - playwright CI (#361)
Browse files Browse the repository at this point in the history
* initial commit for CI tests

* tests: update github action to run playwright CI tests

* tests: update qgis-app fixtures

* tests: add playwright tests fixtures

* tests: add playwright CI tests

* tests: tests on planet tab and 3D models

* fix: fix failing test due media path

* shell.nix updated to use latest unstable

* Add plugin manage playwright test

* Chane the order of plugin manage test

* Remove locale time in plugin manage test

* Fix plugin manage e2e CI test

* Remove codecov upload

* Wait for the server in the playwright workflow

* Playwright fix: force click on login button

* Set DEBUG to True by default in env template

---------

Co-authored-by: Lova ANDRIARIMALALA <[email protected]>
  • Loading branch information
osundwajeff and Xpirix authored Jan 8, 2025
1 parent 60cbe0e commit ce9fdb6
Show file tree
Hide file tree
Showing 38 changed files with 2,466 additions and 4 deletions.
40 changes: 39 additions & 1 deletion .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,9 @@ jobs:
working-directory: dockerize
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v3
with:
node-version: 20

- name: Generate the .env file
run: cp .env.template .env
Expand All @@ -58,11 +61,46 @@ jobs:
- name: Wait for the containers to start
run: sleep 15

- name: Run test
- name: Run Django tests
run: |
docker compose exec -T devweb bash -c '
set -e # Exit immediately if any command fails
python manage.py makemigrations --merge --noinput &&
python manage.py makemigrations feedjack &&
python manage.py makemigrations &&
python manage.py migrate &&
python manage.py test
'
- name: Start Django server
run: |
docker-compose exec -T devweb bash -c "python manage.py loaddata fixtures/*.json"
docker-compose exec -T devweb bash -c "nohup python manage.py runserver 0.0.0.0:8080 &"
# Wait for the server to start
until curl -s http://localhost:62202; do
echo "Waiting for Django server to be up..."
sleep 5
done
- name: Test django endpoint
run: |
curl -v http://0.0.0.0:62202
if [ $? -ne 0 ]; then
echo "Curl command failed"
exit 1
fi
- name: Install playwright dependencies
working-directory: playwright/ci-test
run: |
npm install
npm ci
npx playwright install --with-deps
- name: Run Playwright tests
working-directory: playwright/ci-test
run: npx playwright test
- uses: actions/upload-artifact@v3
if: always()
with:
name: playwright-report
path: playwright/ci-test/playwright-report/
retention-days: 30
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -54,5 +54,8 @@ qgis-app/api/tests/*/

# whoosh_index
qgis-app/whoosh_index/

# playwright fixture
!playwright/ci-test/tests/fixtures/qgis-logo.zip
docker-compose.override.yml
.env
2 changes: 1 addition & 1 deletion dockerize/.env.template
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ DATABASE_HOST=db

# Django settings
DJANGO_SETTINGS_MODULE=settings_docker
DEBUG=False
DEBUG=True

# Docker volumes
QGISPLUGINS_STATIC_VOLUME=static-data
Expand Down
1 change: 1 addition & 0 deletions playwright/ci-test/.envrc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
use nix
8 changes: 8 additions & 0 deletions playwright/ci-test/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
node_modules/
/test-results/
/playwright-report/
/playwright/.cache/
states
package-lock.json
playwright-results
*auth.json
98 changes: 98 additions & 0 deletions playwright/ci-test/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
# Validation Tests

These tests are designed to run from GitHub action or CI.

They are intended to verify basic functionality is working during the building of the application(Just before deployment to staging or production).

## Essential reading:

* [https://playwright.dev/](https://playwright.dev/)
* [https://playwright.dev/docs/ci-intro](https://playwright.dev/docs/ci-intro)
* [https://direnv.net/docs/installation.html](https://direnv.net/docs/installation.html)

## Setting up your environment

Before you can run, you need to set up your environment.

Running these tests requires playwright set up on your local machine, as well as NodeJS.

### NixOS

If you are a NixOS user, you can set up direnv and then cd into this directory in your shell.

When you do so the first time, you will be prompted to allow direnv which you can do using this command:

```bash
direnv allow
```

>  This may take a while the first time as NixOS builds you a sandbox environment.
### Non-NixOS

For a non-NixOS user(Debian/Ubuntu) set up your environment by the following commands:

```bash
npm install
```

To install playwright browsers with OS-level dependencies use:

```bash
npx playwright install --with-deps chromium
```

**NOTE:** This only works with Debian/Ubuntu as they receive official support from playwright. It will also request your master password to install the dependencies.

## Recording a test

There is a bash helper script that will let you quickly create a new test:

```
Usage: ./record-test.sh TESTNAME
e.g. ./record-test.sh mytest
will write a new test to tests/mytest.spec.ts
Do not use spaces in your test name.
Test files MUST END in .spec.ts
After recording your test, close the test browser.
You can then run your test by doing:
./run-tests.sh
```

>  The first time you record a test, it will store your session credentials in a file ending in ``auth.json``. This file should **NEVER** be committed to git / shared publicly. There is a gitignore rule to ensure this.
## Running a test

By default, this will run in `headless` mode just as it is in CI.

```bash
./run-tests.sh
```

**NOTE:** To run it in `UI` mode, add the `--ui` tag to the script.

```bash
$PLAYWRIGHT \
test \
--ui \
--project chromium
```

## Adding a CI test

To add tests for CI, use the recorded tests then modify it for CI.

The tests can be modified to include time-outs, and waiting for events/actions etc. For more look go through [playwright's documentation](https://playwright.dev/docs/writing-tests).

An example of a line-recorded test would look like:

```typescript
await page.getByRole('img', { name: 'image' }).click();
```

For the CI the line could be modified and turned into an assertion using `expect` to test if the specific element is visible.

```typescript
await expect(page.getByRole('img', { name: 'image' })).toBeVisible();
```
4 changes: 4 additions & 0 deletions playwright/ci-test/base-url.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
#!/usr/bin/env bash

echo "Setting BASE_URL for test site"
BASE_URL=http://0.0.0.0:62202
35 changes: 35 additions & 0 deletions playwright/ci-test/create-auth.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
#!/usr/bin/env bash

source base-url.sh

source playwright-path.sh

echo "This script will write a new test to tests/deleteme.spec.ts"
echo "then delete it, leaving only the auth config."
echo ""
echo "When the playwright browser opens, log in to the site then exit."
echo "After recording your test, close the test browser."
echo "Recording auth token to auth.json"

# File exists and write permission granted to user
# show prompt
echo "Continue? y/n"
read ANSWER
case $ANSWER in
[yY] ) echo "Writing auth.json" ;;
[nN] ) echo "Cancelled."; exit ;;
esac

$PLAYWRIGHT \
codegen \
--target playwright-test \
--save-storage=auth.json \
-o tests/deleteme.spec.ts \
$BASE_URL

# We are only interested in auth.json
rm tests/deleteme.spec.ts

echo "Auth file creation completed."
echo "You can then run your tests by doing e.g.:"
echo "playwright test --project chromium"
23 changes: 23 additions & 0 deletions playwright/ci-test/nodesource-install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#!/usr/bin/env bash

echo "NodeJS will be installed if not present"
echo "sudo password will be required"

USES_APT=$(which apt | grep -w "apt" | wc -l)
USES_RPM=$(which rpm | grep -w "rpm" | wc -l)

if [ $USES_APT -eq 1 ]; then
curl -SLO https://deb.nodesource.com/nsolid_setup_deb.sh
sudo chmod 500 nsolid_setup_deb.sh
sudo ./nsolid_setup_deb.sh 20
sudo apt-get install nodejs -y

elif [ $USES_RPM -eq 1 ]; then
curl -SLO https://rpm.nodesource.com/nsolid_setup_rpm.sh
sudo chmod 500 nsolid_setup_rpm.sh
sudo ./nsolid_setup_rpm.sh 20
sudo yum install nodejs -y --setopt=nodesource-nodejs.module_hotfixes=1
fi

echo "Done"
echo ""
20 changes: 20 additions & 0 deletions playwright/ci-test/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
{
"name": "ci-test",
"version": "1.0.0",
"description": "",
"main": "index.js",
"directories": {
"test": "tests"
},
"scripts": {},
"keywords": [],
"author": "",
"license": "ISC",
"devDependencies": {
"@playwright/test": "^1.39.0",
"@types/node": "^20.8.9"
},
"dependencies": {
"playwright": "^1.39.0"
}
}
83 changes: 83 additions & 0 deletions playwright/ci-test/playwright-path.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
#!/usr/bin/env bash

echo "This script will discover the path to your playwright install"
echo "If you are not in a NixOS environment and it is not installed,"
echo "playwright will be installed."
echo ""
echo "At the end of calling this script , you should have a PLAYWRIGHT"
echo ""

# Are we on nixos or a distro with Nix installed for packages
# Y
# Are we in direnv?
# Y: should all be set up
# N: run nix-shell
#N
# Are we in a deb based distro?
# Are we in an rpm based distro?
# Are we on macOS?
# Are we in windows?

HAS_PLAYWRIGHT=$(which playwright 2> /dev/null | grep -v "which: no" | wc -l)
PLAYWRIGHT="playwright"
if [ $HAS_PLAYWRIGHT -eq 0 ]; then
PLAYWRIGHT="npx playwright"

# check if OS is a deb based distro and uses apt
USES_APT=$(which apt 2> /dev/null | grep -w "apt" | wc -l)
# check if OS is an rpm-based distro
USES_RPM=$(which rpm | grep -w "rpm" | wc -l)

if [ $USES_APT -eq 1 ]; then
# check if nodejs is installed
HAS_NODEJS=$(which node | grep -w "node" | wc -l)

# if nodejs is present then
if [ $HAS_NODEJS -eq 0 ]; then
source nodesource-install.sh
fi

# check if npm is present
HAS_NPM=$(which npm | grep -w "npm" | wc -l)

if [ $HAS_NPM -eq 1 ]; then
NPM="npm"
PLAYWRIGHT_INSTALL=$($NPM ls --depth 1 playwright | grep -w "@playwright/test" | wc -l)

if [ $PLAYWRIGHT_INSTALL -eq 0 ]; then
$NPM install -D @playwright/test@latest
$NPM ci
$PLAYWRIGHT install --with-deps chromium
fi

fi

elif [ $USES_RPM -eq 1 ]; then

# check if nodejs is installed
HAS_NODEJS=$(which node | grep -w "node" | wc -l)

# if nodejs is present then
if [ $HAS_NODEJS -eq 0 ]; then
source nodesource-install.sh
fi

# check if npm is present
HAS_NPM=$(which npm | grep -w "npm" | wc -l)

if [ $HAS_NPM -eq 1 ]; then
NPM="npm"
PLAYWRIGHT_INSTALL=$($NPM ls --depth 1 playwright | grep -w "@playwright/test" | wc -l)

if [ $PLAYWRIGHT_INSTALL -eq 0 ]; then
$NPM install -D @playwright/test@latest
$NPM ci
$PLAYWRIGHT install
fi

fi
fi
fi

echo "Done."
echo ""
Loading

0 comments on commit ce9fdb6

Please sign in to comment.