Skip to content
This repository has been archived by the owner on Oct 28, 2024. It is now read-only.

Commit

Permalink
Use aiomysql as sqlalchemy database driver
Browse files Browse the repository at this point in the history
  • Loading branch information
garryod committed Apr 18, 2024
1 parent 66e4970 commit 108775c
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 16 deletions.
2 changes: 1 addition & 1 deletion .devcontainer/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ services:
- ..:/workspace:cached,z
command: sleep infinity
environment:
DATABASE_URL: mysql+pymysql://root:rootpassword@ispyb/ispyb_build
DATABASE_URL: mysql+aiomysql://root:rootpassword@ispyb/ispyb_build
OTEL_COLLECTOR_URL: http://jaeger:4317

ispyb:
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ dependencies = [
"starlette",
"strawberry-graphql[asgi]",
"sqlalchemy",
"pymysql",
"aiomysql",
"opentelemetry-api",
"opentelemetry-sdk",
"opentelemetry-semantic-conventions",
Expand Down
4 changes: 2 additions & 2 deletions src/graph_energy_scan/__main__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,14 @@
from strawberry.printer import print_schema

from graph_energy_scan.database import create_session
from graph_energy_scan.graphql import EnergyScan, Session
from graph_energy_scan.graphql import EnergyScan, Query, Session
from graph_energy_scan.telemetry import setup_telemetry

from . import __version__

__all__ = ["main"]

SCHEMA = Schema(types=[Session, EnergyScan], enable_federation_2=True)
SCHEMA = Schema(Query, types=[Session, EnergyScan], enable_federation_2=True)


@click.group(invoke_without_command=True)
Expand Down
22 changes: 11 additions & 11 deletions src/graph_energy_scan/database.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,21 @@
from contextlib import asynccontextmanager
from typing import AsyncGenerator, Optional, cast

from sqlalchemy import create_engine
from sqlalchemy.orm import Session
from sqlalchemy.ext.asyncio import AsyncSession, async_sessionmaker, create_async_engine

SESSION: Optional[Session] = None
SESSION_SET = Event()
SESSION_MAKER: Optional[async_sessionmaker] = None
SESSION_CREATED = Event()


def create_session(url: str):
global SESSION
engine = create_engine(url)
SESSION = Session(engine)
SESSION_SET.set()
global SESSION_MAKER
engine = create_async_engine(url)
SESSION_MAKER = async_sessionmaker(engine)
SESSION_CREATED.set()


@asynccontextmanager
async def current_session() -> AsyncGenerator[Session, None]:
await SESSION_SET.wait()
yield cast(Session, SESSION)
async def current_session() -> AsyncGenerator[AsyncSession, None]:
await SESSION_CREATED.wait()
async with cast(async_sessionmaker, SESSION_MAKER)() as session:
yield session
4 changes: 3 additions & 1 deletion src/graph_energy_scan/graphql.py
Original file line number Diff line number Diff line change
Expand Up @@ -81,4 +81,6 @@ async def energy_scans(self) -> list[EnergyScan]:
stmt = select(models.EnergyScan).where(
models.EnergyScan.sessionId == self.id
)
return [EnergyScan.from_model(model) for model in session.scalars(stmt)]
return [
EnergyScan.from_model(model) for model in await session.scalars(stmt)
]

0 comments on commit 108775c

Please sign in to comment.