spiff-arena/tests/SpiffWorkflow/bpmn/MultiInstanceParallelTest.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

52 lines
1.8 KiB
Python

# -*- coding: utf-8 -*-
import sys
import os
import unittest
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..', '..', '..'))
from SpiffWorkflow.bpmn.workflow import BpmnWorkflow
from tests.SpiffWorkflow.bpmn.BpmnWorkflowTestCase import BpmnWorkflowTestCase
__author__ = 'matth'
class MultiInstanceTest(BpmnWorkflowTestCase):
"""The example bpmn diagram has a single task set to be a parallel
multi-instance with a loop cardinality of 5.
It should repeat 5 times before termination, and it should
have a navigation list with 7 items in it - one for start, one for end,
and five items for the repeating section. """
def setUp(self):
spec, subprocesses = self.load_workflow_spec('MultiInstanceParallelTask.bpmn', 'MultiInstance')
self.workflow = BpmnWorkflow(spec, subprocesses)
def load_workflow1_spec(self):
return
def testRunThroughHappy(self):
self.actualTest()
def testSaveRestore(self):
self.actualTest(True)
def actualTest(self, save_restore=False):
self.workflow.do_engine_steps()
self.assertEqual(1, len(self.workflow.get_ready_user_tasks()))
task = self.workflow.get_ready_user_tasks()[0]
task.data['collection'] = [1,2,3,4,5]
self.workflow.complete_task_from_id(task.id)
self.workflow.do_engine_steps()
for task in self.workflow.get_ready_user_tasks():
self.assertFalse(self.workflow.is_completed())
self.workflow.complete_task_from_id(task.id)
if save_restore:
self.save_restore()
self.workflow.do_engine_steps()
self.assertTrue(self.workflow.is_completed())
def suite():
return unittest.TestLoader().loadTestsFromTestCase(MultiInstanceTest)
if __name__ == '__main__':
unittest.TextTestRunner(verbosity=2).run(suite())