From 688f475837c9b2ee5241f559961bf3f2cc5e1b36 Mon Sep 17 00:00:00 2001 From: Jim Bosch Date: Thu, 2 Mar 2023 10:29:01 -0500 Subject: [PATCH] Use PipelineGraph instead of PipelineDatasetTypes in step tester. --- python/lsst/pipe/base/pipeline_graph/_abcs.py | 2 - .../pipe/base/tests/pipelineStepTester.py | 43 ++++++++----------- 2 files changed, 18 insertions(+), 27 deletions(-) diff --git a/python/lsst/pipe/base/pipeline_graph/_abcs.py b/python/lsst/pipe/base/pipeline_graph/_abcs.py index df0d856e0..71fe4763d 100644 --- a/python/lsst/pipe/base/pipeline_graph/_abcs.py +++ b/python/lsst/pipe/base/pipeline_graph/_abcs.py @@ -170,8 +170,6 @@ class Edge(ABC): not when it is run. connection_name : `str` Internal name for the connection as seen by the task. - connection : `BaseConnection` - Post-configuration object to draw dataset type information from. """ def __init__( diff --git a/python/lsst/pipe/base/tests/pipelineStepTester.py b/python/lsst/pipe/base/tests/pipelineStepTester.py index 697ccac7f..00f4523ec 100644 --- a/python/lsst/pipe/base/tests/pipelineStepTester.py +++ b/python/lsst/pipe/base/tests/pipelineStepTester.py @@ -28,7 +28,7 @@ import unittest from lsst.daf.butler import Butler, DatasetType -from lsst.pipe.base import Pipeline, PipelineDatasetTypes +from lsst.pipe.base import Pipeline @dataclasses.dataclass @@ -88,32 +88,25 @@ def run(self, butler: Butler, test_case: unittest.TestCase) -> None: pure_inputs: dict[str, str] = dict() for suffix in self.step_suffixes: - pipeline = Pipeline.from_uri(self.filename + suffix) - dataset_types = PipelineDatasetTypes.fromPipeline( - pipeline, - registry=butler.registry, - include_configs=False, - include_packages=False, + step_graph = Pipeline.from_uri(self.filename + suffix).to_graph().resolved(butler.registry) + + pure_inputs.update( + { + node.name: suffix + for node in step_graph.iter_overall_inputs() + if node.name not in all_outputs + } + ) + all_outputs.update( + { + name: node.dataset_type + for name, node in step_graph.dataset_types.items() + if step_graph.producer_of(name) is not None + } ) - pure_inputs.update({k: suffix for k in dataset_types.prerequisites.names}) - parent_inputs = {t.nameAndComponent()[0] for t in dataset_types.inputs} - pure_inputs.update({k: suffix for k in parent_inputs - all_outputs.keys()}) - all_outputs.update(dataset_types.outputs.asMapping()) - all_outputs.update(dataset_types.intermediates.asMapping()) - - for name in dataset_types.inputs.names & all_outputs.keys(): - test_case.assertTrue( - all_outputs[name].is_compatible_with(dataset_types.inputs[name]), - msg=( - f"dataset type {name} is defined as {dataset_types.inputs[name]} as an " - f"input, but {all_outputs[name]} as an output, and these are not compatible." - ), - ) - - for dataset_type in dataset_types.outputs | dataset_types.intermediates: - if not dataset_type.isComponent(): - butler.registry.registerDatasetType(dataset_type) + for node in step_graph.dataset_types.values(): + butler.registry.registerDatasetType(node.dataset_type) if not pure_inputs.keys() <= self.expected_inputs: missing = [f"{k} ({pure_inputs[k]})" for k in pure_inputs.keys() - self.expected_inputs]