From f73d6b83cc44fe46b0793a286964942e42247701 Mon Sep 17 00:00:00 2001 From: Sebastian Diaz Date: Fri, 26 Jul 2024 12:54:12 +0200 Subject: [PATCH] address comments by CO and SA --- cg/services/post_processing/abstract_classes.py | 7 ++++--- .../pacbio/metrics_parser/metrics_parser.py | 11 +++++++++-- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/cg/services/post_processing/abstract_classes.py b/cg/services/post_processing/abstract_classes.py index 1d08f4dfab..c31d868ece 100644 --- a/cg/services/post_processing/abstract_classes.py +++ b/cg/services/post_processing/abstract_classes.py @@ -36,9 +36,10 @@ def get_files_to_store(self, run_data: RunData) -> list[Path]: class PostProcessingMetricsParser(ABC): - @staticmethod - @abstractmethod - def parse_metrics(metrics_files: list[Path]) -> RunMetrics: + def __init__(self, file_manager: RunFileManager): + self.file_manager: RunFileManager = file_manager + + def parse_metrics(self, run_data: RunData) -> RunMetrics: pass diff --git a/cg/services/post_processing/pacbio/metrics_parser/metrics_parser.py b/cg/services/post_processing/pacbio/metrics_parser/metrics_parser.py index 937108feb0..c74c1db5c6 100644 --- a/cg/services/post_processing/pacbio/metrics_parser/metrics_parser.py +++ b/cg/services/post_processing/pacbio/metrics_parser/metrics_parser.py @@ -13,14 +13,21 @@ from cg.services.post_processing.pacbio.metrics_parser.utils import ( get_parsed_metrics_from_file_name, ) +from cg.services.post_processing.pacbio.run_data_generator.run_data import PacBioRunData +from cg.services.post_processing.pacbio.run_file_manager.run_file_manager import ( + PacBioRunFileManager, +) class PacBioMetricsParser(PostProcessingMetricsParser): """Class for parsing PacBio sequencing metrics.""" - @staticmethod - def parse_metrics(metrics_files: list[Path]) -> PacBioMetrics: + def __init__(self, file_manager: PacBioRunFileManager): + super().__init__(file_manager=file_manager) + + def parse_metrics(self, run_data: PacBioRunData) -> PacBioMetrics: """Return all the relevant PacBio metrics parsed in a single Pydantic object.""" + metrics_files: list[Path] = self.file_manager.get_files_to_parse(run_data) hifi_metrics: HiFiMetrics = get_parsed_metrics_from_file_name( metrics_files=metrics_files, file_name=PacBioDirsAndFiles.BASECALLING_REPORT )