fix: run migrations before unit tests in CI
Some unit tests (test_api_deps, test_server_key) are integration tests that need DB tables. Move alembic upgrade head before unit tests.
This commit is contained in:
parent
06b5a3dc12
commit
70eb9f6b12
3 changed files with 71 additions and 6 deletions
|
|
@ -62,13 +62,14 @@ jobs:
|
|||
- name: Install Playwright browsers
|
||||
run: uv run playwright install --with-deps chromium
|
||||
|
||||
- name: Run migrations
|
||||
run: uv run alembic upgrade head
|
||||
|
||||
- name: Run unit tests
|
||||
run: uv run pytest tests/ --ignore=tests/e2e -v --tb=short
|
||||
|
||||
- name: Run E2E tests
|
||||
run: |
|
||||
uv run alembic upgrade head
|
||||
uv run pytest tests/e2e/ -v --tb=short
|
||||
run: uv run pytest tests/e2e/ -v --tb=short
|
||||
|
||||
docker:
|
||||
needs: test
|
||||
|
|
|
|||
|
|
@ -63,13 +63,14 @@ jobs:
|
|||
- name: Install Playwright browsers
|
||||
run: uv run playwright install --with-deps chromium
|
||||
|
||||
- name: Run migrations
|
||||
run: uv run alembic upgrade head
|
||||
|
||||
- name: Run unit tests
|
||||
run: uv run pytest tests/ --ignore=tests/e2e -v --tb=short
|
||||
|
||||
- name: Run E2E tests
|
||||
run: |
|
||||
uv run alembic upgrade head
|
||||
uv run pytest tests/e2e/ -v --tb=short
|
||||
run: uv run pytest tests/e2e/ -v --tb=short
|
||||
|
||||
release:
|
||||
needs: test
|
||||
|
|
|
|||
63
tests/test_server_key.py
Normal file
63
tests/test_server_key.py
Normal file
|
|
@ -0,0 +1,63 @@
|
|||
"""Tests for server public key retrieval from Configuration table."""
|
||||
|
||||
import pytest
|
||||
|
||||
from wiregui.db import async_session
|
||||
from wiregui.models.configuration import Configuration
|
||||
from wiregui.utils.server_key import get_server_public_key
|
||||
from sqlmodel import select
|
||||
|
||||
|
||||
@pytest.fixture(autouse=True)
|
||||
async def _snapshot_config():
|
||||
"""Snapshot and restore server_public_key around each test."""
|
||||
async with async_session() as session:
|
||||
c = (await session.execute(select(Configuration).limit(1))).scalar_one_or_none()
|
||||
orig = c.server_public_key if c else None
|
||||
cid = c.id if c else None
|
||||
|
||||
yield
|
||||
|
||||
if cid:
|
||||
async with async_session() as session:
|
||||
c = await session.get(Configuration, cid)
|
||||
if c:
|
||||
c.server_public_key = orig
|
||||
session.add(c)
|
||||
await session.commit()
|
||||
|
||||
|
||||
async def test_get_server_public_key_returns_key():
|
||||
"""Returns the public key when configured."""
|
||||
async with async_session() as session:
|
||||
c = (await session.execute(select(Configuration).limit(1))).scalar_one_or_none()
|
||||
c.server_public_key = "TestServerPubKey123456789012345678901234w="
|
||||
session.add(c)
|
||||
await session.commit()
|
||||
|
||||
result = await get_server_public_key()
|
||||
assert result == "TestServerPubKey123456789012345678901234w="
|
||||
|
||||
|
||||
async def test_get_server_public_key_raises_when_missing():
|
||||
"""Raises RuntimeError when server_public_key is None."""
|
||||
async with async_session() as session:
|
||||
c = (await session.execute(select(Configuration).limit(1))).scalar_one_or_none()
|
||||
c.server_public_key = None
|
||||
session.add(c)
|
||||
await session.commit()
|
||||
|
||||
with pytest.raises(RuntimeError, match="not configured"):
|
||||
await get_server_public_key()
|
||||
|
||||
|
||||
async def test_get_server_public_key_raises_when_empty_string():
|
||||
"""Raises RuntimeError when server_public_key is empty string."""
|
||||
async with async_session() as session:
|
||||
c = (await session.execute(select(Configuration).limit(1))).scalar_one_or_none()
|
||||
c.server_public_key = ""
|
||||
session.add(c)
|
||||
await session.commit()
|
||||
|
||||
with pytest.raises(RuntimeError, match="not configured"):
|
||||
await get_server_public_key()
|
||||
Loading…
Add table
Add a link
Reference in a new issue