mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-25 01:09:10 +00:00
e53d860b40
8d820dce1f Track spiff step details more granularly (#17) 426da26d8f Clear the remaining __init__.py imports in SpiffWorkflow (#14) 9a1d1c484a Fix FutureWarning in SpiffWorkflow (#16) git-subtree-dir: SpiffWorkflow git-subtree-split: 8d820dce1f439bb76bc07e39629832d998d6f634
75 lines
2.7 KiB
Python
75 lines
2.7 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import unittest
|
|
import datetime
|
|
import time
|
|
from datetime import timedelta
|
|
|
|
from SpiffWorkflow.bpmn.specs.events.EndEvent import EndEvent
|
|
from SpiffWorkflow.task import TaskState
|
|
from SpiffWorkflow.bpmn.workflow import BpmnWorkflow
|
|
from SpiffWorkflow.bpmn.PythonScriptEngine import PythonScriptEngine
|
|
from tests.SpiffWorkflow.bpmn.BpmnWorkflowTestCase import BpmnWorkflowTestCase
|
|
__author__ = 'kellym'
|
|
|
|
|
|
class TimerDurationTest(BpmnWorkflowTestCase):
|
|
|
|
def setUp(self):
|
|
self.script_engine = PythonScriptEngine(default_globals={"timedelta": timedelta})
|
|
self.spec, self.subprocesses = self.load_workflow_spec('boundary_timer_on_task.bpmn', 'test_timer')
|
|
self.workflow = BpmnWorkflow(self.spec, self.subprocesses, script_engine=self.script_engine)
|
|
|
|
def testRunThroughHappy(self):
|
|
self.actual_test(save_restore=False)
|
|
|
|
def testThroughSaveRestore(self):
|
|
self.actual_test(save_restore=True)
|
|
|
|
def actual_test(self,save_restore = False):
|
|
# In the normal flow of things, the final end event should be the last task
|
|
self.workflow.do_engine_steps()
|
|
ready_tasks = self.workflow.get_tasks(TaskState.READY)
|
|
self.assertEqual(1, len(ready_tasks))
|
|
self.workflow.complete_task_from_id(ready_tasks[0].id)
|
|
self.workflow.do_engine_steps()
|
|
self.assertTrue(self.workflow.is_completed())
|
|
end_events = []
|
|
|
|
for task in self.workflow.get_tasks():
|
|
if isinstance(task.task_spec, EndEvent):
|
|
end_events.append(task)
|
|
self.assertEqual(1, len(end_events))
|
|
|
|
# In the event of a timer firing, the last task should STILL
|
|
# be the final end event.
|
|
|
|
starttime = datetime.datetime.now()
|
|
self.workflow = BpmnWorkflow(self.spec)
|
|
self.workflow.script_engine = self.script_engine
|
|
self.workflow.do_engine_steps()
|
|
if save_restore:
|
|
self.save_restore()
|
|
self.workflow.script_engine = self.script_engine
|
|
time.sleep(0.1)
|
|
self.workflow.refresh_waiting_tasks()
|
|
self.workflow.do_engine_steps()
|
|
task = self.workflow.get_ready_user_tasks()[0]
|
|
self.workflow.complete_task_from_id(task.id)
|
|
self.workflow.do_engine_steps()
|
|
|
|
self.assertTrue(self.workflow.is_completed())
|
|
end_events = []
|
|
|
|
for task in self.workflow.get_tasks():
|
|
if isinstance(task.task_spec, EndEvent):
|
|
end_events.append(task)
|
|
self.assertEqual(1, len(end_events))
|
|
|
|
|
|
|
|
def suite():
|
|
return unittest.TestLoader().loadTestsFromTestCase(TimerDurationTest)
|
|
if __name__ == '__main__':
|
|
unittest.TextTestRunner(verbosity=2).run(suite())
|