Skip to content

Commit

Permalink
Further adjustments to testing setup
Browse files Browse the repository at this point in the history
  • Loading branch information
rubenthoms committed Oct 18, 2023
1 parent cc0f874 commit f990e0f
Show file tree
Hide file tree
Showing 17 changed files with 783 additions and 188 deletions.
239 changes: 128 additions & 111 deletions .github/workflows/webviz.yml
Original file line number Diff line number Diff line change
@@ -1,116 +1,133 @@
name: webviz

on:
push:
pull_request:
branches:
- main
release:
types:
- published
push:
pull_request:
branches:
- main
release:
types:
- published

jobs:
frontend:
runs-on: ubuntu-latest

steps:
- name: 📖 Checkout commit locally
uses: actions/checkout@v3

- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
cache-dependency-path: frontend/package-lock.json

- name: ℹ️ Node and npm versions
run: |
node -v
npm -v
- name: 📦 Install build dependencies
working-directory: ./frontend
run: |
npm ci --include=dev
- name: ℹ️ Installed npm packages (depth = 0)
working-directory: ./frontend
run: npm list --depth=0

- name: 🏗️ Build JavaScript bundle
working-directory: ./frontend
run: npm run build

- name: 🕵️ Check code style, linting & dependencies
working-directory: ./frontend
run: |
npm run validate
- name: 🤖 Run tests
working-directory: ./frontend
run: |
npm run test
- name: 🕵️ Check auto-generated frontend code is in sync with backend
run: |
docker build -f backend.Dockerfile -t backend:latest .
CONTAINER_ID=$(docker run --detach -p 5000:5000 --env UVICORN_PORT=5000 --env UVICORN_ENTRYPOINT=src.backend.primary.main:app --env WEBVIZ_CLIENT_SECRET=0 --env WEBVIZ_SMDA_SUBSCRIPTION_KEY=0 --env WEBVIZ_SMDA_RESOURCE_SCOPE=0 backend:latest)
sleep 5 # Ensure the backend server is up and running exposing /openapi.json
npm run generate-api --prefix ./frontend
docker stop $CONTAINER_ID
git diff --exit-code ./frontend/src/api || exit 1
backend:
runs-on: ubuntu-latest

steps:
- name: 📖 Checkout commit locally
uses: actions/checkout@v3

- name: 🐍 Set up Python
uses: actions/setup-python@v4
with:
python-version: "3.11"
cache: pip

- name: 📦 Install poetry and dependencies
working-directory: ./backend
run: |
pip install --upgrade pip
pip install poetry
poetry config virtualenvs.create false
poetry lock --check --no-update # Check lock file is consistent with pyproject.toml
poetry install --with dev
- name: 🕵️ Check code style & linting
working-directory: ./backend
run: |
black --check src/ tests/
pylint src/ tests/
bandit --recursive src/
mypy src/ tests/
- name: 🤖 Run tests
working-directory: ./backend
env:
WEBVIZ_CLIENT_SECRET: 0
WEBVIZ_SMDA_SUBSCRIPTION_KEY: 0
WEBVIZ_SMDA_RESOURCE_SCOPE: 0
run: |
pytest ./tests/unit
build_docker_images:
runs-on: ubuntu-latest

steps:
- name: 📖 Checkout commit locally
uses: actions/checkout@v3

- uses: actions/setup-node@v3
with:
node-version: 18

- name: 🐳 Verify Docker images build
run: |
docker build -f frontend-prod.Dockerfile .
docker build -f backend.Dockerfile .
frontend:
runs-on: ubuntu-latest

steps:
- name: 📖 Checkout commit locally
uses: actions/checkout@v3

- uses: actions/setup-node@v3
with:
node-version: 18
cache: npm
cache-dependency-path: frontend/package-lock.json

- name: ℹ️ Node and npm versions
run: |
node -v
npm -v
- name: 📦 Install build dependencies
working-directory: ./frontend
run: |
npm ci --include=dev
- name: ℹ️ Installed npm packages (depth = 0)
working-directory: ./frontend
run: npm list --depth=0

- name: 🏗️ Build JavaScript bundle
working-directory: ./frontend
run: npm run build

- name: 🕵️ Check code style, linting & dependencies
working-directory: ./frontend
run: |
npm run validate
- name: Install Playwright Browsers
working-directory: ./frontend
run: |
npx playwright install --with-deps
- name: 🤖 Run unit tests
working-directory: ./frontend
run: |
npm run test:unit
- name: 🤖 Run component tests
working-directory: ./frontend
run: |
npm run test:ct
- uses: actions/upload-artifact@v3
if: always()
with:
name: playwright-report
path: playwright-report/
retention-days: 30

- name: 🕵️ Check auto-generated frontend code is in sync with backend
run: |
docker build -f backend.Dockerfile -t backend:latest .
CONTAINER_ID=$(docker run --detach -p 5000:5000 --env UVICORN_PORT=5000 --env UVICORN_ENTRYPOINT=src.backend.primary.main:app --env WEBVIZ_CLIENT_SECRET=0 --env WEBVIZ_SMDA_SUBSCRIPTION_KEY=0 --env WEBVIZ_SMDA_RESOURCE_SCOPE=0 backend:latest)
sleep 5 # Ensure the backend server is up and running exposing /openapi.json
npm run generate-api --prefix ./frontend
docker stop $CONTAINER_ID
git diff --exit-code ./frontend/src/api || exit 1
backend:
runs-on: ubuntu-latest

steps:
- name: 📖 Checkout commit locally
uses: actions/checkout@v3

- name: 🐍 Set up Python
uses: actions/setup-python@v4
with:
python-version: "3.11"
cache: pip

- name: 📦 Install poetry and dependencies
working-directory: ./backend
run: |
pip install --upgrade pip
pip install poetry
poetry config virtualenvs.create false
poetry lock --check --no-update # Check lock file is consistent with pyproject.toml
poetry install --with dev
- name: 🕵️ Check code style & linting
working-directory: ./backend
run: |
black --check src/ tests/
pylint src/ tests/
bandit --recursive src/
mypy src/ tests/
- name: 🤖 Run tests
working-directory: ./backend
env:
WEBVIZ_CLIENT_SECRET: 0
WEBVIZ_SMDA_SUBSCRIPTION_KEY: 0
WEBVIZ_SMDA_RESOURCE_SCOPE: 0
run: |
pytest ./tests/unit
build_docker_images:
runs-on: ubuntu-latest

steps:
- name: 📖 Checkout commit locally
uses: actions/checkout@v3

- uses: actions/setup-node@v3
with:
node-version: 18

- name: 🐳 Verify Docker images build
run: |
docker build -f frontend-prod.Dockerfile .
docker build -f backend.Dockerfile .
15 changes: 10 additions & 5 deletions frontend/nyc.config.cjs
Original file line number Diff line number Diff line change
@@ -1,11 +1,16 @@
module.exports = {
extends: "@istanbuljs/nyc-config-typescript",
/* include all TypeScript sources from folder "src", excluding type definitions and test files */
cwd: ".",
include: ["src/**"],
extension: [".ts", ".tsx"],

include: ["./src/lib/components/**/*.tsx"],
extension: [".tsx"],
exclude: ["**/*.d.ts", "**/index.ts"],

/* instrument all files, not just the ones touched by the test cases */
all: true,


cache: false,
"check-coverage": true,

reporter: ["html", "lcov"],
};
};
Loading

0 comments on commit f990e0f

Please sign in to comment.