From 2fce235f2fae4b334d57ea61cd3abfd9b711c4eb Mon Sep 17 00:00:00 2001 From: Laurent LAPORTE <43534797+laurent-laporte-pro@users.noreply.github.com> Date: Fri, 23 Feb 2024 19:03:39 +0100 Subject: [PATCH] fix(variants): correct the generation of variant when a snapshot is removed (#1947) --- antarest/study/model.py | 3 ++- antarest/study/storage/variantstudy/model/dbmodel.py | 4 ++++ antarest/study/storage/variantstudy/snapshot_generator.py | 2 +- tests/study/storage/variantstudy/model/test_dbmodel.py | 2 +- 4 files changed, 8 insertions(+), 3 deletions(-) diff --git a/antarest/study/model.py b/antarest/study/model.py index fe10b4f211..fe993a1512 100644 --- a/antarest/study/model.py +++ b/antarest/study/model.py @@ -188,8 +188,9 @@ class Study(Base): # type: ignore __mapper_args__ = {"polymorphic_identity": "study", "polymorphic_on": type} def __str__(self) -> str: + cls = self.__class__.__name__ return ( - f"[Study]" + f"[{cls}]" f" id={self.id}," f" type={self.type}," f" name={self.name}," diff --git a/antarest/study/storage/variantstudy/model/dbmodel.py b/antarest/study/storage/variantstudy/model/dbmodel.py index bbe264f89f..15b1bb896d 100644 --- a/antarest/study/storage/variantstudy/model/dbmodel.py +++ b/antarest/study/storage/variantstudy/model/dbmodel.py @@ -112,3 +112,7 @@ def is_snapshot_up_to_date(self) -> bool: and (self.snapshot.created_at >= self.updated_at) and (self.snapshot_dir / "study.antares").is_file() ) + + def has_snapshot(self) -> bool: + """Check if the snapshot exists.""" + return (self.snapshot is not None) and (self.snapshot_dir / "study.antares").is_file() diff --git a/antarest/study/storage/variantstudy/snapshot_generator.py b/antarest/study/storage/variantstudy/snapshot_generator.py index 50972ae99a..138089a35e 100644 --- a/antarest/study/storage/variantstudy/snapshot_generator.py +++ b/antarest/study/storage/variantstudy/snapshot_generator.py @@ -246,7 +246,7 @@ def search_ref_study( # To reuse the snapshot of the current variant, the last executed command # must be one of the commands of the current variant. curr_variant = descendants[-1] - if curr_variant.snapshot: + if curr_variant.has_snapshot(): last_exec_cmd = curr_variant.snapshot.last_executed_command command_ids = [c.id for c in curr_variant.commands] # If the variant has no command, we can reuse the snapshot if it is recent diff --git a/tests/study/storage/variantstudy/model/test_dbmodel.py b/tests/study/storage/variantstudy/model/test_dbmodel.py index 0715dec535..1e18e4fef1 100644 --- a/tests/study/storage/variantstudy/model/test_dbmodel.py +++ b/tests/study/storage/variantstudy/model/test_dbmodel.py @@ -188,7 +188,7 @@ def test_init__without_snapshot(self, db_session: Session, raw_study_id: str, us obj: VariantStudy = db_session.query(VariantStudy).filter(VariantStudy.id == variant_study_id).one() # check Study representation - assert str(obj).startswith(f"[Study] id={variant_study_id}") + assert str(obj).startswith(f"[VariantStudy] id={variant_study_id}") # check Study fields assert obj.id == variant_study_id