forked from enviPath/enviPy
I added playwright for frontend testing and got a couple simple test cases working. I have updated pyproject.toml but it can also be installed with `pip install pytest-playwright` followed by `playwright install` With the django server running you can do `playwright codegen http://localhost:8000/` which will generate test code based on the actions you take on the webpage it opens. Be sure to change the target to pytest in the code pop up. I will add more test cases but @jebus and @t03i feel free to add more. Especially once we are done with the full front-end redesign. I have put the tests under `tests/frontend/` but I am not sure how to add them to the CI. They give steps for CI integration but maybe we want to somehow include them in our exisiting CI yaml? https://playwright.dev/python/docs/ci-intro Reviewed-on: enviPath/enviPy#218 Reviewed-by: Tobias O <tobias.olenyi@envipath.com> Co-authored-by: Liam Brydon <lbry121@aucklanduni.ac.nz> Co-committed-by: Liam Brydon <lbry121@aucklanduni.ac.nz>
125 lines
3.2 KiB
YAML
125 lines
3.2 KiB
YAML
name: CI
|
|
|
|
on:
|
|
pull_request:
|
|
branches:
|
|
- develop
|
|
workflow_dispatch:
|
|
|
|
jobs:
|
|
test:
|
|
if: ${{ !contains(gitea.event.pull_request.title, 'WIP') }}
|
|
runs-on: ubuntu-latest
|
|
|
|
services:
|
|
postgres:
|
|
image: postgres:16
|
|
env:
|
|
POSTGRES_USER: ${{ vars.POSTGRES_USER }}
|
|
POSTGRES_PASSWORD: ${{ secrets.POSTGRES_PASSWORD }}
|
|
POSTGRES_DB: ${{ vars.POSTGRES_DB }}
|
|
ports:
|
|
- ${{ vars.POSTGRES_PORT}}:5432
|
|
options: >-
|
|
--health-cmd="pg_isready -U postgres"
|
|
--health-interval=10s
|
|
--health-timeout=5s
|
|
--health-retries=5
|
|
|
|
#redis:
|
|
# image: redis:7
|
|
# ports:
|
|
# - 6379:6379
|
|
# options: >-
|
|
# --health-cmd "redis-cli ping"
|
|
# --health-interval=10s
|
|
# --health-timeout=5s
|
|
# --health-retries=5
|
|
|
|
env:
|
|
RUNNER_TOOL_CACHE: /toolcache
|
|
EP_DATA_DIR: /opt/enviPy/
|
|
ALLOWED_HOSTS: 127.0.0.1,localhost
|
|
DEBUG: True
|
|
LOG_LEVEL: DEBUG
|
|
MODEL_BUILDING_ENABLED: True
|
|
APPLICABILITY_DOMAIN_ENABLED: True
|
|
ENVIFORMER_PRESENT: True
|
|
ENVIFORMER_DEVICE: cpu
|
|
FLAG_CELERY_PRESENT: False
|
|
PLUGINS_ENABLED: True
|
|
SERVER_URL: http://localhost:8000
|
|
ADMIN_APPROVAL_REQUIRED: True
|
|
REGISTRATION_MANDATORY: True
|
|
LOG_DIR: ''
|
|
# DB
|
|
POSTGRES_SERVICE_NAME: postgres
|
|
POSTGRES_DB: ${{ vars.POSTGRES_DB }}
|
|
POSTGRES_USER: ${{ vars.POSTGRES_USER }}
|
|
POSTGRES_PASSWORD: ${{ secrets.POSTGRES_PASSWORD }}
|
|
POSTGRES_PORT: 5432
|
|
# SENTRY
|
|
SENTRY_ENABLED: False
|
|
# MS ENTRA
|
|
MS_ENTRA_ENABLED: False
|
|
|
|
steps:
|
|
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Install system tools via apt
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get install -y postgresql-client redis-tools openjdk-11-jre-headless
|
|
|
|
- name: Setup ssh
|
|
run: |
|
|
echo "${{ secrets.ENVIPY_CI_PRIVATE_KEY }}" > ~/.ssh/id_ed25519
|
|
chmod 600 ~/.ssh/id_ed25519
|
|
ssh-keyscan git.envipath.com >> ~/.ssh/known_hosts
|
|
eval $(ssh-agent -s)
|
|
ssh-add ~/.ssh/id_ed25519
|
|
|
|
- name: Install pnpm
|
|
uses: pnpm/action-setup@v4
|
|
with:
|
|
version: 10
|
|
|
|
- name: Use Node.js
|
|
uses: actions/setup-node@v4
|
|
with:
|
|
node-version: 20
|
|
cache: "pnpm"
|
|
|
|
- name: Install uv
|
|
uses: astral-sh/setup-uv@v6
|
|
with:
|
|
enable-cache: true
|
|
|
|
- name: Setup venv
|
|
run: |
|
|
uv sync --locked --all-extras --dev
|
|
source .venv/bin/activate
|
|
playwright install --with-deps
|
|
|
|
- name: Wait for services
|
|
run: |
|
|
until pg_isready -h postgres -U postgres; do sleep 2; done
|
|
# until redis-cli -h redis ping; do sleep 2; done
|
|
|
|
- name: Run Django Migrations
|
|
run: |
|
|
source .venv/bin/activate
|
|
python manage.py migrate --noinput
|
|
|
|
- name: Run frontend tests
|
|
run: |
|
|
source .venv/bin/activate
|
|
python manage.py test --tag frontend
|
|
|
|
- name: Run Django tests
|
|
run: |
|
|
source .venv/bin/activate
|
|
python manage.py test tests --exclude-tag slow --exclude-tag frontend
|