forked from equinor/webviz
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into fix-ensemble-selector-bug
- Loading branch information
Showing
52 changed files
with
6,706 additions
and
8,465 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 . |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
76 changes: 76 additions & 0 deletions
76
backend/src/backend/primary/routers/polygons/converters.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
from typing import List | ||
import xtgeo | ||
|
||
from src.services.smda_access.types import StratigraphicSurface | ||
from src.services.sumo_access.polygons_types import PolygonsMeta as SumoPolygonsMeta | ||
|
||
from . import schemas | ||
|
||
|
||
def to_api_polygons_data(xtgeo_poly: xtgeo.Polygons) -> List[schemas.PolygonData]: | ||
""" | ||
Create API PolygonsData from xtgeo polygons | ||
""" | ||
polydata: List[schemas.PolygonData] = [] | ||
for poly_id, polygon in xtgeo_poly.dataframe.groupby("POLY_ID"): | ||
polydata.append( | ||
schemas.PolygonData( | ||
x_arr=list(polygon.X_UTME), | ||
y_arr=list(polygon.Y_UTMN), | ||
z_arr=list(polygon.Z_TVDSS), | ||
poly_id=poly_id, | ||
) | ||
) | ||
return polydata | ||
|
||
|
||
def to_api_polygons_directory( | ||
sumo_polygons_dir: List[SumoPolygonsMeta], stratigraphical_names: List[StratigraphicSurface] | ||
) -> List[schemas.PolygonsMeta]: | ||
""" | ||
Convert Sumo polygons directory to API surface directory | ||
""" | ||
|
||
polygons_metas = _sort_by_stratigraphical_order(sumo_polygons_dir, stratigraphical_names) | ||
return polygons_metas | ||
|
||
|
||
def _sort_by_stratigraphical_order( | ||
sumo_polygons_metas: List[SumoPolygonsMeta], stratigraphic_surfaces: List[StratigraphicSurface] | ||
) -> List[schemas.PolygonsMeta]: | ||
"""Sort the Sumo polygons meta list by the order they appear in the stratigraphic column. | ||
Non-stratigraphical polygons are appended at the end of the list.""" | ||
|
||
polygons_metas_with_official_strat_name = [] | ||
polygons_metas_with_custom_names = [] | ||
|
||
for strat_surface in stratigraphic_surfaces: | ||
for sumo_polygons_meta in sumo_polygons_metas: | ||
if sumo_polygons_meta.name == strat_surface.name: | ||
polygons_meta = schemas.PolygonsMeta( | ||
name=sumo_polygons_meta.name, | ||
name_is_stratigraphic_offical=True, | ||
relative_stratigraphic_level=strat_surface.relative_strat_unit_level, | ||
parent_stratigraphic_identifier=strat_surface.strat_unit_parent, | ||
stratigraphic_identifier=strat_surface.strat_unit_identifier, | ||
attribute_name=sumo_polygons_meta.tagname, | ||
attribute_type=schemas.PolygonsAttributeType(sumo_polygons_meta.content.value), | ||
) | ||
polygons_metas_with_official_strat_name.append(polygons_meta) | ||
|
||
# Append non-official strat names | ||
for sumo_polygons_meta in sumo_polygons_metas: | ||
if sumo_polygons_meta.name not in [s.name for s in polygons_metas_with_official_strat_name]: | ||
polygons_meta = schemas.PolygonsMeta( | ||
name=sumo_polygons_meta.name, | ||
name_is_stratigraphic_offical=False, | ||
relative_stratigraphic_level=None, | ||
parent_stratigraphic_identifier=None, | ||
stratigraphic_identifier=None, | ||
attribute_name=sumo_polygons_meta.tagname, | ||
attribute_type=schemas.PolygonsAttributeType(sumo_polygons_meta.content.value), | ||
) | ||
|
||
polygons_metas_with_custom_names.append(polygons_meta) | ||
|
||
return polygons_metas_with_official_strat_name + polygons_metas_with_custom_names |
Oops, something went wrong.