Skip to content

Commit

Permalink
Merge remote-tracking branch 'equinor/main' into examine-persistence
Browse files Browse the repository at this point in the history
  • Loading branch information
rubenthoms committed Jun 17, 2024
2 parents 12e4dac + a988d65 commit 7dd7e1e
Show file tree
Hide file tree
Showing 586 changed files with 36,252 additions and 8,811 deletions.
295 changes: 149 additions & 146 deletions .github/workflows/webviz.yml
Original file line number Diff line number Diff line change
@@ -1,151 +1,154 @@
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: 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 --env WEBVIZ_VDS_HOST_ADDRESS=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
WEBVIZ_VDS_HOST_ADDRESS: 0
run: |
pytest ./tests/unit
go:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Setup Go
uses: actions/setup-go@v3
with:
go-version: "1.21.x"
- name: Install dependencies
working-directory: ./backend_go/surface_query
run: |
go get .
- name: Test with Go
working-directory: ./backend_go/surface_query
run: |
go test ./...
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_py/primary/Dockerfile -t backend:latest .
CONTAINER_ID=$(docker run --detach -p 5000:5000 --env UVICORN_PORT=5000 --env WEBVIZ_CLIENT_SECRET=0 --env WEBVIZ_SMDA_SUBSCRIPTION_KEY=0 --env WEBVIZ_SMDA_RESOURCE_SCOPE=0 --env WEBVIZ_VDS_HOST_ADDRESS=0 --env WEBVIZ_ENTERPRISE_SUBSCRIPTION_KEY=0 --env WEBVIZ_SSDL_RESOURCE_SCOPE=0 backend:latest)
sleep 10 # 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_py/primary
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_py/primary
run: |
set -x
black --check primary/ tests/
pylint primary/ tests/
bandit --recursive primary/
mypy primary/ tests/
- name: 🤖 Run tests
working-directory: ./backend_py/primary
env:
WEBVIZ_CLIENT_SECRET: 0
WEBVIZ_SMDA_SUBSCRIPTION_KEY: 0
WEBVIZ_SMDA_RESOURCE_SCOPE: 0
WEBVIZ_VDS_HOST_ADDRESS: 0
WEBVIZ_ENTERPRISE_SUBSCRIPTION_KEY: 0
WEBVIZ_SSDL_RESOURCE_SCOPE: 0
run: |
pytest ./tests/unit
go:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Setup Go
uses: actions/setup-go@v3
with:
go-version: "1.21.x"
- name: Install dependencies
working-directory: ./backend_go/surface_query
run: |
go get .
- name: Test with Go
working-directory: ./backend_go/surface_query
run: |
go test ./...
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_py/primary/Dockerfile .
6 changes: 5 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -108,9 +108,10 @@ dist
.tern-port

# .vscode
.vscode/
**/.vscode/*
!.vscode/tasks.json
!.vscode/launch.json
!backend_py/primary/.vscode/launch.json

# playwright results
playwright-report/
Expand All @@ -122,3 +123,6 @@ playwright-report/

# Ignore Jupyter Notebook checkpoints (hidden directories)
.ipynb_checkpoints/

# Python virtual environments
.venv*
38 changes: 19 additions & 19 deletions .vscode/launch.json
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
{
"configurations": [
{
"name": "Python: Remote Attach",
"type": "debugpy",
"request": "attach",
"connect": { "host": "localhost", "port": 5678 },
"pathMappings": [
"configurations": [
{
"localRoot": "${workspaceFolder}/backend",
"remoteRoot": "/home/appuser/backend"
"name": "Python: Remote Attach",
"type": "python",
"request": "attach",
"connect": { "host": "localhost", "port": 5678 },
"pathMappings": [
{
"localRoot": "${workspaceFolder}/backend_py/primary",
"remoteRoot": "/home/appuser/backend_py/primary"
}
]
},
{
"name": "TS: Launch Chrome and Attach",
"request": "launch",
"type": "chrome",
"webRoot": "${workspaceFolder}/frontend",
"url": "http://localhost:8080"
}
]
},
{
"name": "TS: Launch Chrome and Attach",
"request": "launch",
"type": "chrome",
"webRoot": "${workspaceFolder}/frontend",
"url": "http://localhost:8080"
}
]
]
}
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,8 @@ as stated above).

We have two applications in Radix built from this repository:
* [Main application](https://webviz.app.radix.equinor.com/) built from the `main` branch.
* [Review application](https://frontend-webviz-review.radix.equinor.com/) built from the `review` branch
* [Review application](https://frontend-webviz-review.radix.equinor.com/) built from the `review` branch.
* [Dev application](https://frontend-webviz-dev.radix.equinor.com/) built from the `dev` branch.

The applications are automatically built and redeployed when pushing commits to the respective branch.

Expand Down
15 changes: 0 additions & 15 deletions backend.Dockerfile

This file was deleted.

Loading

0 comments on commit 7dd7e1e

Please sign in to comment.