Source code for pypushflow.tests.test_workflow6

from pypushflow.Workflow import Workflow
from pypushflow.Submodel import Submodel
from pypushflow.StopActor import StopActor
from pypushflow.StartActor import StartActor
from pypushflow.PythonActor import PythonActor
from pypushflow.ThreadCounter import ThreadCounter
from pypushflow.tests.workflowTestCase import WorkflowTestCase


[docs] class Submodel6(Submodel): """ Submodel containing one python actor which has a long execution time """ def __init__(self, parent, name, thread_counter): super().__init__(parent=parent, name=name, thread_counter=thread_counter) self.pythonActorAdd = PythonActor( parent=self, script="pypushflow.tests.tasks.pythonActorAdd.py", name="Python Submodel Actor Add", errorHandler=self, thread_counter=thread_counter, ) self.getPort("In").connect(self.pythonActorAdd) self.pythonActorAdd.connect(self.getPort("Out"))
[docs] class Workflow6(Workflow): """ Workflow containing one start actor, one submodel which has a long execution and one stop actor with short timeout. """ def __init__(self, name): super().__init__(name) ctr = ThreadCounter(parent=self) self.startActor = StartActor(self, thread_counter=ctr) self.pythonActorAdd1 = PythonActor( parent=self, script="pypushflow.tests.tasks.pythonActorAdd.py", name="Python Add Actor 1", thread_counter=ctr, ) self.pythonActorAdd2 = PythonActor( parent=self, script="pypushflow.tests.tasks.pythonActorAdd.py", name="Python Add Actor 2", thread_counter=ctr, ) self.submodel6 = Submodel6(self, name="Submodel 6", thread_counter=ctr) self.stopActor = StopActor(self, thread_counter=ctr) self.startActor.connect(self.pythonActorAdd1) self.pythonActorAdd1.connect(self.submodel6.getPort("In")) self.submodel6.getPort("Out").connect(self.pythonActorAdd2) self.pythonActorAdd2.connect(self.stopActor)
[docs] class TestWorkflow6(WorkflowTestCase):
[docs] def test_workflow6(self): workflow6 = Workflow6("Test workflow 6") inData = {"value": 1} outData = workflow6.run( inData, timeout=5, scaling_workers=False, max_workers=-1 ) self.assertEqual(outData["value"], 4)