Skip to content

Commit

Permalink
Merge pull request #13 from thehyve/fix-payer-plan
Browse files Browse the repository at this point in the history
Fix payer_plan_period_id columns
  • Loading branch information
Spayralbe authored Jan 15, 2025
2 parents bafeb23 + e1f2c0c commit 865d9ae
Show file tree
Hide file tree
Showing 12 changed files with 41 additions and 19 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
## v0.3.0

Bugfixes
- Incorrect references for payer_plan_period_id fields in CDM 5.4 ([#12](https://github.com/thehyve/omop-cdm/issues/12))
- The stem table field `start_datetime` is now nullable in CDM 5.3 and 5.4 ([#14](https://github.com/thehyve/omop-cdm/issues/14))

## v0.2.0
Expand Down
10 changes: 4 additions & 6 deletions src/omop_cdm/dynamic/cdm54/health_economics.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ class BasePayerPlanPeriodCdm54:
__tablename__ = "payer_plan_period"
__table_args__ = {"schema": CDM_SCHEMA}

payer_plan_period_id: Mapped[int] = mapped_column(ForeignKey(FK_PERSON_ID), primary_key=True, sort_order=100)
payer_plan_period_id: Mapped[int] = mapped_column(Integer, primary_key=True, sort_order=100)
person_id: Mapped[int] = mapped_column(ForeignKey(FK_PERSON_ID), index=True, sort_order=200)
payer_plan_period_start_date: Mapped[datetime.date] = mapped_column(Date, sort_order=300)
payer_plan_period_end_date: Mapped[datetime.date] = mapped_column(Date, sort_order=400)
Expand All @@ -37,10 +37,6 @@ class BasePayerPlanPeriodCdm54:
def payer_concept(cls) -> Mapped["Concept"]:
return relationship("Concept", foreign_keys="PayerPlanPeriod.payer_concept_id")

@declared_attr
def payer_plan_period(cls) -> Mapped["Person"]:
return relationship("Person", foreign_keys="PayerPlanPeriod.payer_plan_period_id")

@declared_attr
def payer_source_concept(cls) -> Mapped["Concept"]:
return relationship("Concept", foreign_keys="PayerPlanPeriod.payer_source_concept_id")
Expand Down Expand Up @@ -94,7 +90,9 @@ class BaseCostCdm54:
paid_by_primary: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric, sort_order=1400)
paid_ingredient_cost: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric, sort_order=1500)
paid_dispensing_fee: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric, sort_order=1600)
payer_plan_period_id: Mapped[Optional[int]] = mapped_column(Integer, sort_order=1700)
payer_plan_period_id: Mapped[Optional[int]] = mapped_column(
ForeignKey(f"{CDM_SCHEMA}.payer_plan_period.payer_plan_period_id"), sort_order=1700
)
amount_allowed: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric, sort_order=1800)
revenue_code_concept_id: Mapped[Optional[int]] = mapped_column(ForeignKey(FK_CONCEPT_ID), sort_order=1900)
revenue_code_source_value: Mapped[Optional[str]] = mapped_column(String(50), sort_order=2000)
Expand Down
7 changes: 4 additions & 3 deletions src/omop_cdm/regular/cdm54/tables.py
Original file line number Diff line number Diff line change
Expand Up @@ -850,7 +850,7 @@ class PayerPlanPeriod(Base):
__tablename__ = "payer_plan_period"
__table_args__ = {"schema": CDM_SCHEMA}

payer_plan_period_id: Mapped[int] = mapped_column(ForeignKey(FK_PERSON_ID), primary_key=True)
payer_plan_period_id: Mapped[int] = mapped_column(Integer, primary_key=True)
person_id: Mapped[int] = mapped_column(ForeignKey(FK_PERSON_ID), index=True)
payer_plan_period_start_date: Mapped[datetime.date] = mapped_column(Date)
payer_plan_period_end_date: Mapped[datetime.date] = mapped_column(Date)
Expand All @@ -869,7 +869,6 @@ class PayerPlanPeriod(Base):
stop_reason_source_concept_id: Mapped[Optional[int]] = mapped_column(ForeignKey(FK_CONCEPT_ID))

payer_concept: Mapped["Concept"] = relationship("Concept", foreign_keys="PayerPlanPeriod.payer_concept_id")
payer_plan_period: Mapped["Person"] = relationship("Person", foreign_keys="PayerPlanPeriod.payer_plan_period_id")
payer_source_concept: Mapped["Concept"] = relationship(
"Concept", foreign_keys="PayerPlanPeriod.payer_source_concept_id"
)
Expand Down Expand Up @@ -910,7 +909,9 @@ class Cost(Base):
paid_by_primary: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric)
paid_ingredient_cost: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric)
paid_dispensing_fee: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric)
payer_plan_period_id: Mapped[Optional[int]] = mapped_column(Integer)
payer_plan_period_id: Mapped[Optional[int]] = mapped_column(
ForeignKey(f"{CDM_SCHEMA}.payer_plan_period.payer_plan_period_id")
)
amount_allowed: Mapped[Optional[decimal.Decimal]] = mapped_column(Numeric)
revenue_code_concept_id: Mapped[Optional[int]] = mapped_column(ForeignKey(FK_CONCEPT_ID))
revenue_code_source_value: Mapped[Optional[str]] = mapped_column(String(50))
Expand Down
18 changes: 16 additions & 2 deletions tests/conftest.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
from contextlib import contextmanager
from typing import Set
from typing import Callable, Set

import pytest
from sqlalchemy import Connection, Engine, MetaData, create_engine
from sqlalchemy import Connection, Engine, MetaData, create_engine, select
from sqlalchemy.orm import Session
from sqlalchemy.sql.ddl import CreateSchema, DropSchema
from testcontainers.postgres import PostgresContainer

Expand Down Expand Up @@ -38,3 +39,16 @@ def temp_schemas(engine: Engine, schemas: Set[str]):
def create_all_tables(engine: Engine, metadata: MetaData) -> None:
with engine.begin() as conn:
metadata.create_all(bind=conn)


def validate_relationships(engine: Engine, table: Callable) -> None:
"""
Query any table to make SQLAlchemy validate table relationships.
While SQLAlchemy's Metadata.create_all method will create the tables
in the database, it can still be that ORM FK relationships are
configured incorrectly. This will only become apparent upon first
using an ORM query. Hence, this simple session interaction.
"""
with Session(engine) as session:
session.execute(select(table))
3 changes: 2 additions & 1 deletion tests/omop_cdm/dynamic/cdm531/test_cdm531.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from sqlalchemy import Engine, inspect

from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.dynamic.cdm_definitions import cdm531
from tests.omop_cdm.table_sets import CDM531_NON_VOCAB, CUSTOM, VOCAB

Expand All @@ -21,3 +21,4 @@ def test_create_tables_cdm531(cdm531_engine: Engine):
cdm_tables = inspect(cdm531_engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(vocab_tables) == VOCAB
assert set(cdm_tables) == CDM531_NON_VOCAB | CUSTOM
validate_relationships(cdm531_engine, cdm531.Person)
3 changes: 2 additions & 1 deletion tests/omop_cdm/dynamic/cdm54/test_cdm54.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from sqlalchemy import Engine, inspect

from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.dynamic.cdm_definitions import cdm54
from tests.omop_cdm.table_sets import CDM54_NON_VOCAB, CUSTOM, VOCAB

Expand All @@ -21,3 +21,4 @@ def test_create_tables_cdm54(cdm54_engine: Engine):
cdm_tables = inspect(cdm54_engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(vocab_tables) == VOCAB
assert set(cdm_tables) == CDM54_NON_VOCAB | CUSTOM
validate_relationships(cdm54_engine, cdm54.Person)
3 changes: 2 additions & 1 deletion tests/omop_cdm/dynamic/cdm54_custom/test_cdm54_custom.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from sqlalchemy import BIGINT, Engine, inspect

from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.dynamic.cdm_definitions import cdm54_custom
from tests.omop_cdm.table_sets import CDM54_NON_VOCAB, CUSTOM

Expand All @@ -27,6 +27,7 @@ def _create_custom_cdm_tables(cdm54_custom_engine: Engine):
def test_custom_table_is_created(cdm54_custom_engine: Engine):
cdm_tables = inspect(cdm54_custom_engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(cdm_tables) == CDM54_NON_VOCAB | CUSTOM | {"cloudspine"}
validate_relationships(cdm54_custom_engine, cdm54_custom.Person)


@pytest.mark.usefixtures("_create_custom_cdm_tables")
Expand Down
3 changes: 2 additions & 1 deletion tests/omop_cdm/dynamic/cdm54_plus_legacy/test_legacy.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from sqlalchemy import Engine, inspect

from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.dynamic.cdm_definitions import cdm54_plus_legacy
from tests.omop_cdm.table_sets import CDM54_NON_VOCAB, CUSTOM, LEGACY, VOCAB

Expand All @@ -23,3 +23,4 @@ def test_create_tables_cdm54_plus_legacy(cdm54_legacy_engine: Engine):
SCHEMA_MAP[CDM_SCHEMA]
)
assert set(cdm_tables) == VOCAB | CDM54_NON_VOCAB | LEGACY | CUSTOM
validate_relationships(cdm54_legacy_engine, cdm54_plus_legacy.Person)
3 changes: 2 additions & 1 deletion tests/omop_cdm/dynamic/cdm600/test_cdm600.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from sqlalchemy import Engine, inspect

from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.dynamic.cdm_definitions import cdm600
from tests.omop_cdm.table_sets import CDM600_NON_VOCAB, CUSTOM, VOCAB

Expand All @@ -21,3 +21,4 @@ def test_create_tables_cdm600(cdm600_engine: Engine):
cdm_tables = inspect(cdm600_engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(vocab_tables) == VOCAB
assert set(cdm_tables) == CDM600_NON_VOCAB | CUSTOM
validate_relationships(cdm600_engine, cdm600.Person)
3 changes: 2 additions & 1 deletion tests/omop_cdm/regular/cdm531/test_cdm531.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

import src.omop_cdm.regular.cdm531 as cdm531
from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.table_sets import CDM531_NON_VOCAB, VOCAB

SCHEMA_MAP = {VOCAB_SCHEMA: "vocab531", CDM_SCHEMA: "cdm531"}
Expand All @@ -22,3 +22,4 @@ def test_create_tables_cdm531_regular(cdm531_regular_engine: Engine):
cdm_tables = inspect(engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(vocab_tables) == VOCAB
assert set(cdm_tables) == CDM531_NON_VOCAB
validate_relationships(cdm531_regular_engine, cdm531.Person)
3 changes: 2 additions & 1 deletion tests/omop_cdm/regular/cdm54/test_cdm54.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

import src.omop_cdm.regular.cdm54 as cdm54
from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.table_sets import CDM54_NON_VOCAB, VOCAB

SCHEMA_MAP = {VOCAB_SCHEMA: "vocab54", CDM_SCHEMA: "cdm54"}
Expand All @@ -22,3 +22,4 @@ def test_create_tables_cdm54_regular(cdm54_regular_engine: Engine):
cdm_tables = inspect(engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(vocab_tables) == VOCAB
assert set(cdm_tables) == CDM54_NON_VOCAB
validate_relationships(cdm54_regular_engine, cdm54.Person)
3 changes: 2 additions & 1 deletion tests/omop_cdm/regular/cdm600/test_cdm600.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

import src.omop_cdm.regular.cdm600 as cdm600
from src.omop_cdm.constants import CDM_SCHEMA, VOCAB_SCHEMA
from tests.conftest import create_all_tables, temp_schemas
from tests.conftest import create_all_tables, temp_schemas, validate_relationships
from tests.omop_cdm.table_sets import CDM600_NON_VOCAB, VOCAB

SCHEMA_MAP = {VOCAB_SCHEMA: "vocab600", CDM_SCHEMA: "cdm600"}
Expand All @@ -22,3 +22,4 @@ def test_create_tables_cdm600_regular(cdm600_regular_engine: Engine):
cdm_tables = inspect(engine).get_table_names(SCHEMA_MAP[CDM_SCHEMA])
assert set(vocab_tables) == VOCAB
assert set(cdm_tables) == CDM600_NON_VOCAB
validate_relationships(cdm600_regular_engine, cdm600.Person)

0 comments on commit 865d9ae

Please sign in to comment.