lightning/tests/tests_app/utilities/test_tree.py

172 lines
4.8 KiB
Python

import pytest
from lightning_app import LightningFlow, LightningWork
from lightning_app.testing.helpers import EmptyFlow, EmptyWork
from lightning_app.utilities.tree import breadth_first, depth_first
class LeafFlow(EmptyFlow):
pass
class LeafWork(EmptyWork):
pass
class SimpleFlowTree(EmptyFlow):
def __init__(self):
super().__init__()
self.simple_flow_left = LeafFlow()
self.simple_flow_right = LeafFlow()
class SimpleWorkTree(EmptyFlow):
def __init__(self):
super().__init__()
self.simple_work_left = LeafWork()
self.simple_work_right = LeafWork()
class MixedTree(EmptyFlow):
def __init__(self):
super().__init__()
self.mixed_left = SimpleFlowTree()
self.work_tree = SimpleWorkTree()
self.mixed_right = SimpleFlowTree()
@pytest.mark.parametrize(
"input_tree, types,expected_sequence",
[
(LeafFlow(), (LightningFlow,), ["root"]),
(LeafWork(), (LightningFlow,), []),
(
SimpleFlowTree(),
(LightningFlow,),
[
"root",
"root.simple_flow_right",
"root.simple_flow_left",
],
),
(SimpleWorkTree(), (LightningFlow,), ["root"]),
(
SimpleWorkTree(),
(LightningFlow, LightningWork),
[
"root",
"root.simple_work_right",
"root.simple_work_left",
],
),
(
MixedTree(),
(LightningFlow,),
[
"root",
"root.work_tree",
"root.mixed_right",
"root.mixed_right.simple_flow_right",
"root.mixed_right.simple_flow_left",
"root.mixed_left",
"root.mixed_left.simple_flow_right",
"root.mixed_left.simple_flow_left",
],
),
(
MixedTree(),
(LightningWork,),
[
"root.work_tree.simple_work_right",
"root.work_tree.simple_work_left",
],
),
(
MixedTree(),
(LightningFlow, LightningWork),
[
"root",
"root.work_tree",
"root.work_tree.simple_work_right",
"root.work_tree.simple_work_left",
"root.mixed_right",
"root.mixed_right.simple_flow_right",
"root.mixed_right.simple_flow_left",
"root.mixed_left",
"root.mixed_left.simple_flow_right",
"root.mixed_left.simple_flow_left",
],
),
],
)
def test_depth_first(input_tree, types, expected_sequence):
assert list(node.name for node in depth_first(input_tree, types=types)) == expected_sequence
@pytest.mark.parametrize(
"input_tree, types,expected_sequence",
[
(LeafFlow(), (LightningFlow,), ["root"]),
(LeafWork(), (LightningFlow,), []),
(
SimpleFlowTree(),
(LightningFlow,),
[
"root",
"root.simple_flow_left",
"root.simple_flow_right",
],
),
(SimpleWorkTree(), (LightningFlow,), ["root"]),
(
SimpleWorkTree(),
(LightningFlow, LightningWork),
[
"root",
"root.simple_work_left",
"root.simple_work_right",
],
),
(
MixedTree(),
(LightningFlow,),
[
"root",
"root.mixed_left",
"root.mixed_right",
"root.work_tree",
"root.mixed_left.simple_flow_left",
"root.mixed_left.simple_flow_right",
"root.mixed_right.simple_flow_left",
"root.mixed_right.simple_flow_right",
],
),
(
MixedTree(),
(LightningWork,),
[
"root.work_tree.simple_work_left",
"root.work_tree.simple_work_right",
],
),
(
MixedTree(),
(LightningFlow, LightningWork),
[
"root",
"root.mixed_left",
"root.mixed_right",
"root.work_tree",
"root.mixed_left.simple_flow_left",
"root.mixed_left.simple_flow_right",
"root.mixed_right.simple_flow_left",
"root.mixed_right.simple_flow_right",
"root.work_tree.simple_work_left",
"root.work_tree.simple_work_right",
],
),
],
)
def test_breadth_first(input_tree, types, expected_sequence):
assert list(node.name for node in breadth_first(input_tree, types=types)) == expected_sequence