Feat: register table modifications

This commit is contained in:
2025-01-18 07:31:30 +01:00
parent 8882317a47
commit 478a8c2403
3 changed files with 138 additions and 36 deletions

View File

@@ -6,7 +6,7 @@ import pytest
from plesna.models.flux import FluxMetaData
from plesna.storage.metadata_repository.fs_metadata_repository import FSMetaDataRepository
from plesna.storage.metadata_repository.metadata_repository import ExecutionLog
from plesna.storage.metadata_repository.metadata_repository import ExecutionLog, ModificationLog
@pytest.fixture
@@ -30,8 +30,8 @@ def test_add_flux(location, metadata_repository):
flux_id = "my_flux"
metadata_repository.add_flux(flux_id)
metadata_filepath = location / metadata_repository.FILEMODEL["execution"].format(
flux_id=flux_id
metadata_filepath = location / metadata_repository.OBJECTS["flux"]["filemodel"].format(
id=flux_id
)
assert metadata_filepath.exists()
@@ -40,6 +40,13 @@ def test_add_flux(location, metadata_repository):
assert content == "datetime,output\n"
def test_add_and_list_fluxes(metadata_repository):
flux_ids = ["my_flux", "flux2", "blahblah"]
for f in flux_ids:
metadata_repository.add_flux(f)
assert metadata_repository.fluxes() == flux_ids
def test_register_flux_execution(location, metadata_repository):
flux_id = "my_flux"
metadata_repository.add_flux(flux_id)
@@ -52,8 +59,8 @@ def test_register_flux_execution(location, metadata_repository):
},
)
metadata_filepath = location / metadata_repository.FILEMODEL["execution"].format(
flux_id=flux_id
metadata_filepath = location / metadata_repository.OBJECTS["flux"]["filemodel"].format(
id=flux_id
)
with open(metadata_filepath, "r") as csvfile:
content = csvfile.read()
@@ -116,8 +123,68 @@ def test_register_and_get_last_log(metadata_repository):
)
def test_register_and_list_fluxes(metadata_repository):
flux_ids = ["my_flux", "flux2", "blahblah"]
for f in flux_ids:
metadata_repository.add_flux(f)
assert metadata_repository.fluxes() == flux_ids
def test_add_and_list_tables(metadata_repository):
table_ids = ["my_table", "table2", "blahblah"]
for f in table_ids:
metadata_repository.add_table(f)
assert metadata_repository.tables() == table_ids
def test_register_table_modification(location, metadata_repository):
table_id = "my_table"
flux_id = "my_flux"
metadata_repository.add_table(table_id)
metadata_repository.register_table_modification(
table_id, datetime(2023, 3, 15, 14, 30), flux_id
)
metadata_filepath = location / metadata_repository.OBJECTS["table"]["filemodel"].format(
id=table_id
)
with open(metadata_filepath, "r") as csvfile:
content = csvfile.read()
assert content == "datetime,flux_id\n2023-03-15T14:30:00,my_flux\n"
# def test_register_and_get_logs(metadata_repository):
# table_id = "my_table"
# flux_id = "my_flux"
# metadata_repository.add_table(table_id)
#
# metadata_repository.register_table_modification(
# table_id, datetime(2023, 3, 15, 14, 30), flux_id
# )
# metadata_repository.register_table_modification(
# table_id, datetime(2024, 3, 15, 14, 30), flux_id
# )
#
# logs = metadata_repository.table_logs(table_id)
# assert logs == [
# ModificationLog(datetime=datetime(2023, 3, 15, 14, 30), flux_is=flux_id),
# ModificationLog(datetime=datetime(2024, 3, 15, 14, 30), flux_is=flux_id),
# ]
# def test_register_and_get_last_log(metadata_repository):
# table_id = "my_table"
# metadata_repository.add_table(table_id)
#
# metadata_repository.register_table_modification(
# table_id,
# datetime(2023, 3, 15, 14, 30),
# output={"truc": "machin"},
# )
# metadata_repository.register_table_modification(
# table_id,
# datetime(2024, 3, 15, 14, 30),
# output={
# "truc": "chose",
# },
# )
#
# logs = metadata_repository.table(table_id)
# assert logs == modificationLog(
# datetime=datetime(2024, 3, 15, 14, 30),
# output=TableMetaData(data={"truc": "chose"}),
# )