Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DEV - Update dev workflows and CI #801

Closed
wants to merge 18 commits into from
Closed
Show file tree
Hide file tree
Changes from 12 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 19 additions & 28 deletions .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
name: Tests

env:
DEFAULT_PYTHON_VERSION: "3.10"
FORCE_COLOR: "1" # Make tools pretty.
trallard marked this conversation as resolved.
Show resolved Hide resolved

on:
Expand All @@ -10,7 +9,6 @@ on:
branches:
- main


# ensuring only one instance is running at a given time
concurrency:
group: ${{ github.ref }}
trallard marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -22,13 +20,6 @@ jobs:
strategy:
trallard marked this conversation as resolved.
Show resolved Hide resolved
matrix:
os: ["ubuntu", "macos", "windows"]
trallard marked this conversation as resolved.
Show resolved Hide resolved
include:
- os: ubuntu
environment-file: conda-store-server/environment-dev.yaml
- os: macos
environment-file: conda-store-server/environment-macos-dev.yaml
- os: windows
environment-file: conda-store-server/environment-windows-dev.yaml
runs-on: ${{ matrix.os }}-latest
trallard marked this conversation as resolved.
Show resolved Hide resolved
defaults:
run:
Expand All @@ -41,7 +32,7 @@ jobs:
- name: "Set up env ${{ matrix.os }} 🐍"
trallard marked this conversation as resolved.
Show resolved Hide resolved
uses: conda-incubator/setup-miniconda@v2
trallard marked this conversation as resolved.
Show resolved Hide resolved
with:
environment-file: ${{ matrix.environment-file }}
environment-file: conda-store-server/environment-dev.yaml
miniforge-version: latest

# This fixes a "DLL not found" issue importing ctypes from the hatch env
Expand All @@ -51,20 +42,20 @@ jobs:
timeout_minutes: 9999
max_attempts: 6
command:
conda install --channel=conda-forge --quiet --yes python=${{ matrix.python }}
conda install --channel=conda-forge --quiet --yes python="3.10"
if: matrix.os == 'windows'

- name: "Linting Checks 🧹"
run: |
hatch env run -e lint lint

- name: "Build package 📦"
- name: "Install conda-store-server for tests 📦"
run: |
hatch build
python -m pip install .

- name: "Unit tests ✅"
run: |
pytest -m "not extended_prefix and not user_journey" tests
python -m pytest -m "not extended_prefix and not user_journey" tests

# https://github.com/actions/runner-images/issues/1052
- name: "Windows extended prefix unit tests ✅"
Expand Down Expand Up @@ -98,10 +89,10 @@ jobs:

- name: "Install build dependencies 📦"
run: |
pip install hatch
sudo apt update
sudo apt install wait-for-it -y

- name: "Deploy docker-compose"
- name: "Deploy docker-compose 🏗"
run: |
docker-compose up -d
docker ps
Expand All @@ -110,26 +101,29 @@ jobs:
wait-for-it localhost:9000 # minio
wait-for-it localhost:8080 # conda-store-server

- name: "Install conda-store-server for tests 📦"
run: |
python -m pip install .

- name: "Run Playwright tests 🎭"
run: |
playwright install
pytest --video on ../tests/test_playwright.py
playwright install --with-deps chromium
python -m pytest --video on ../tests/test_playwright.py

- name: "Upload test results 📤"
uses: actions/upload-artifact@v4
if: ${{ always() }}
with:
name: playwright-tests
path: conda-store-server/test-results
path: conda-store-server/test-results/

- name: "Run integration tests ✅"
run: |
export PYTHONPATH=$PYTHONPATH:$PWD
pytest ../tests/test_api.py ../tests/test_metrics.py
python -m pytest ../tests/test_api.py ../tests/test_metrics.py

- name: "Run user journey tests ✅"
run: |
pytest -m "user_journey"
python -m pytest -m "user_journey"

- name: "Get Docker logs 🔍"
if: ${{ failure() }}
Expand Down Expand Up @@ -157,16 +151,13 @@ jobs:
- name: "Install Dependencies 📦"
run: |
pip install hatch
sudo apt update
sudo apt install wait-for-it -y

- name: "Linting Checks 🧹"
run: |
hatch env run -e dev lint

- name: "Build package 📦"
run: |
hatch build

- name: "Deploy docker-compose"
run: |
docker-compose up -d
Expand All @@ -178,7 +169,7 @@ jobs:

- name: "Install conda-store for tests 📦"
run: |
pip install .
python -m pip install .

- name: "Run basic tests - not authenticated"
run: |
Expand All @@ -203,7 +194,7 @@ jobs:
docker-compose logs

build-docker-image:
name: "Build docker images"
name: "Build Docker images 🐳"
runs-on: ubuntu-latest
strategy:
matrix:
Expand Down
58 changes: 13 additions & 45 deletions conda-store-server/environment-dev.yaml
Original file line number Diff line number Diff line change
@@ -1,63 +1,31 @@
# only development dependencies should be added to this file, if you add a new dev dependency
# you must ensure to add it to the [tool.hatch.envs.dev] section of the pyproject.toml file too
# required conda-store-server or conda-store (core) dependencies MUST ONLY be added/updated in the [dependencies]
# section of the corresponding pyproject.toml file
# the only exceptions to this rule are conda and constructor which are only conda installable
name: conda-store-server-dev
channels:
- conda-forge
- microsoft
- nodefaults
dependencies:
- python ==3.10
trallard marked this conversation as resolved.
Show resolved Hide resolved
# conda builds
- conda ==23.5.2
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why this particular pin?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems this was introduced in #522 -> going through the commits this seems was temporary while mamba-org/mamba#2715

Will remove it and see how it goes

- conda-docker >= 0.1.2
- python-docker
- conda-pack
- conda-lock >=1.0.5
- conda-package-handling
- conda-package-streaming
# web server
- celery
- flower
- redis-py
- sqlalchemy<=1.4.47
- psycopg2
- pymysql
- requests
- uvicorn
- fastapi
- pydantic < 2.0
- pyyaml
- traitlets
- yarl
- pyjwt
- filelock
- itsdangerous
- jinja2
- python-multipart
- alembic
# artifact storage
- minio
# installer
- constructor
# CLI
- typer

# dev dependencies
- aiohttp>=3.8.1
- hatch
- pytest
- pytest-celery
- pytest-mock
- black ==22.3.0
- flake8
- ruff
- sphinx
- myst-parser
- sphinx-panels
- sphinx-copybutton
- pydata-sphinx-theme
- playwright
- docker-py<7 # for docker-compose
- docker-compose
# build dependencies
- hatch
- build
# installer
- constructor # runtime dep but must be conda installed
- pip

- pip:
- pytest-playwright
- pre-commit
- twine>=5.0.0
- pkginfo>=1.10 # needed to support metadata 2.3
trallard marked this conversation as resolved.
Show resolved Hide resolved
63 changes: 0 additions & 63 deletions conda-store-server/environment-macos-dev.yaml

This file was deleted.

63 changes: 0 additions & 63 deletions conda-store-server/environment-windows-dev.yaml

This file was deleted.

28 changes: 0 additions & 28 deletions conda-store-server/environment.yaml
trallard marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -6,33 +6,5 @@ dependencies:
- python ==3.10
# conda environment builds
- conda ==23.5.2
- python-docker
- conda-docker >= 0.1.2
- conda-pack
- conda-lock >=1.0.5
- conda-package-handling
- conda-package-streaming
# web server
- celery
- flower
- redis-py
- sqlalchemy<=1.4.47
- alembic
- psycopg2
- pymysql
- requests
- pyyaml
- uvicorn
- fastapi
- pydantic < 2.0
- traitlets
- yarl
- pyjwt
- filelock
- itsdangerous
- jinja2
- python-multipart
# artifact storage
- minio
# installer
- constructor
Loading
Loading