spiff-arena/tests/SpiffWorkflow/specs/SubWorkflowTest.py
Jon Herron 0892db6fa7 Squashed 'SpiffWorkflow/' content from commit 63db3e4
git-subtree-dir: SpiffWorkflow
git-subtree-split: 63db3e45947ec66b8d0efc2c74064004f8ff482c
2022-10-12 10:19:53 -04:00

128 lines
4.5 KiB
Python

# -*- coding: utf-8 -*-
import sys
import unittest
import os
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..', '..', '..'))
from SpiffWorkflow.specs import WorkflowSpec
from SpiffWorkflow.specs.SubWorkflow import SubWorkflow
from SpiffWorkflow.serializer.prettyxml import XmlSerializer
from SpiffWorkflow.task import TaskState
from SpiffWorkflow.workflow import Workflow
class TaskSpecTest(unittest.TestCase):
CORRELATE = SubWorkflow
def testConstructor(self):
pass # FIXME
def testSerialize(self):
pass # FIXME
def testTest(self):
pass # FIXME
def load_workflow_spec(self, folder, f):
file = os.path.join(
os.path.dirname(__file__), '..', 'data', 'spiff', folder, f)
serializer = XmlSerializer()
with open(file) as fp:
xml = fp.read()
self.wf_spec = WorkflowSpec.deserialize(
serializer, xml, filename=file)
self.workflow = Workflow(self.wf_spec)
def do_next_unique_task(self, name):
# This method asserts that there is only one ready task! The specified
# one - and then completes it
ready_tasks = self.workflow.get_tasks(TaskState.READY)
self.assertEqual(1, len(ready_tasks))
task = ready_tasks[0]
self.assertEqual(name, task.task_spec.name)
task.complete()
def do_next_named_step(self, name, other_ready_tasks):
# This method completes a single task from the specified set of ready
# tasks
ready_tasks = self.workflow.get_tasks(TaskState.READY)
all_tasks = sorted([name] + other_ready_tasks)
self.assertEqual(
all_tasks, sorted([t.task_spec.name for t in ready_tasks]))
task = list([t for t in ready_tasks if t.task_spec.name == name])[0]
task.complete()
def test_block_to_subworkflow(self):
self.load_workflow_spec('data', 'block_to_subworkflow.xml')
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_unique_task('sub_workflow_1')
# Inner:
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_unique_task('last')
self.do_next_unique_task('End')
# Back to outer:
self.do_next_unique_task('last')
self.do_next_unique_task('End')
def test_subworkflow_to_block(self):
self.load_workflow_spec('data', 'subworkflow_to_block.xml')
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_unique_task('sub_workflow_1')
# Inner:
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_unique_task('last')
self.do_next_unique_task('End')
# Back to outer:
self.do_next_unique_task('last')
self.do_next_unique_task('End')
def test_subworkflow_to_join(self):
self.load_workflow_spec('control-flow', 'subworkflow_to_join.xml')
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_named_step('second', ['sub_workflow_1'])
self.do_next_unique_task('sub_workflow_1')
# Inner:
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_unique_task('last')
self.do_next_unique_task('End')
# Back to outer:
self.do_next_unique_task('join')
self.do_next_unique_task('last')
self.do_next_unique_task('End')
def test_subworkflow_to_join_refresh_waiting(self):
self.load_workflow_spec('control-flow', 'subworkflow_to_join.xml')
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
self.do_next_named_step('second', ['sub_workflow_1'])
self.do_next_unique_task('sub_workflow_1')
# Inner:
self.do_next_unique_task('Start')
self.do_next_unique_task('first')
# Now refresh waiting tasks:
# Update the state of every WAITING task.
for thetask in self.workflow._get_waiting_tasks():
thetask.task_spec._update(thetask)
self.do_next_unique_task('last')
self.do_next_unique_task('End')
# Back to outer:
self.do_next_unique_task('join')
self.do_next_unique_task('last')
self.do_next_unique_task('End')
def suite():
return unittest.TestLoader().loadTestsFromTestCase(TaskSpecTest)
if __name__ == '__main__':
unittest.TextTestRunner(verbosity=2).run(suite())