当前位置: 首页>>代码示例>>Python>>正文


Python BpmnWorkflow.BpmnWorkflow类代码示例

本文整理汇总了Python中SpiffWorkflow.bpmn.BpmnWorkflow.BpmnWorkflow的典型用法代码示例。如果您正苦于以下问题:Python BpmnWorkflow类的具体用法?Python BpmnWorkflow怎么用?Python BpmnWorkflow使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了BpmnWorkflow类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: AbstractParallelTest

class AbstractParallelTest(BpmnWorkflowTestCase):
    def _do_test(self, order, only_one_instance=True, save_restore=False):
        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()
        for s in order:
            choice = None
            if isinstance(s, tuple):
                s, choice = s
            if s.startswith("!"):
                logging.info("Checking that we cannot do '%s'", s[1:])
                self.assertRaises(AssertionError, self.do_next_named_step, s[1:], choice=choice)
            else:
                if choice is not None:
                    logging.info("Doing step '%s' (with choice='%s')", s, choice)
                else:
                    logging.info("Doing step '%s'", s)
                # logging.debug(self.workflow.get_dump())
                self.do_next_named_step(s, choice=choice, only_one_instance=only_one_instance)
            self.workflow.do_engine_steps()
            if save_restore:
                # logging.debug("Before SaveRestore: \n%s" % self.workflow.get_dump())
                self.save_restore()

        self.workflow.do_engine_steps()
        unfinished = self.workflow.get_tasks(Task.READY | Task.WAITING)
        if unfinished:
            logging.debug("Unfinished tasks: %s", unfinished)
            logging.debug(self.workflow.get_dump())
        self.assertEquals(0, len(unfinished))
开发者ID:conlini,项目名称:SpiffWorkflow,代码行数:29,代码来源:ParallelTest.py

示例2: testRunThroughMessageInterruptSaveAndRestore

    def testRunThroughMessageInterruptSaveAndRestore(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.save_restore()
        self.do_next_exclusive_step('Select Test', choice='Message Interrupts')
        self.workflow.do_engine_steps()
        self.save_restore()

        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.workflow.accept_message('Test Message')
        self.save_restore()

        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.WAITING)))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_exclusive_step('Acknowledge Interrupt Message')
        self.save_restore()

        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:AnyBucket,项目名称:SpiffWorkflow,代码行数:25,代码来源:MessageInterruptsTest.py

示例3: testRunThroughThread1FirstThenNo

    def testRunThroughThread1FirstThenNo(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()

        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step('Thread 1 - Choose', choice='Yes', with_save_load=True)
        self.workflow.do_engine_steps()
        for i in range(1,13):
            self.do_next_named_step('Thread 1 - Task %d' % i)
            self.workflow.do_engine_steps()

        self.assertRaises(AssertionError, self.do_next_named_step, 'Done')
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.do_next_named_step('Thread 2 - Choose', choice='No', with_save_load=True)
        self.workflow.do_engine_steps()
        self.do_next_named_step('Done', with_save_load=True)
        self.workflow.do_engine_steps()
        self.do_next_named_step('Thread 2 - No Task', with_save_load=True)
        self.workflow.do_engine_steps()


        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:AnyBucket,项目名称:SpiffWorkflow,代码行数:25,代码来源:ParallelTest.py

示例4: testRunThroughMessageOrder3SaveAndRestore

    def testRunThroughMessageOrder3SaveAndRestore(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.save_restore()

        self.workflow.do_engine_steps()
        self.save_restore()

        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.workflow.accept_message('Test Message')

        self.do_next_named_step('Acknowledge SP Parallel Message')
        self.workflow.do_engine_steps()
        self.save_restore()

        self.do_next_named_step('Do Something In a Subprocess')
        self.workflow.do_engine_steps()
        self.save_restore()

        self.do_next_named_step('Ack Subprocess Done')
        self.workflow.do_engine_steps()
        self.save_restore()

        self.workflow.do_engine_steps()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:0-T-0,项目名称:SpiffWorkflow,代码行数:27,代码来源:MessageNonInterruptsSpTest.py

示例5: testRunThroughThread1First

    def testRunThroughThread1First(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()

        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step("Thread 1 - Choose", choice="Yes", with_save_load=True)
        self.workflow.do_engine_steps()
        for i in range(1, 13):
            self.do_next_named_step("Thread 1 - Task %d" % i)
            self.workflow.do_engine_steps()

        self.assertRaises(AssertionError, self.do_next_named_step, "Done")
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.do_next_named_step("Thread 2 - Choose", choice="Yes", with_save_load=True)
        self.workflow.do_engine_steps()
        for i in range(1, 13):
            self.do_next_named_step("Thread 2 - Task %d" % i, with_save_load=True)
            self.workflow.do_engine_steps()

        self.do_next_named_step("Done", with_save_load=True)
        self.workflow.do_engine_steps()

        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:conlini,项目名称:SpiffWorkflow,代码行数:26,代码来源:ParallelTest.py

示例6: testRepeatTasksReadyTogetherSaveRestore

    def testRepeatTasksReadyTogetherSaveRestore(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()
        self.save_restore()

        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step("Choice 1", choice="Yes")
        self.workflow.do_engine_steps()
        self.save_restore()
        self.do_next_named_step("Yes Task")
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertRaises(AssertionError, self.do_next_named_step, "Done")
        ready_tasks = self.workflow.get_tasks(Task.READY)
        self.assertEquals(2, len(ready_tasks))
        self.assertEquals("Repeated Task", ready_tasks[0].task_spec.description)
        ready_tasks[0].complete()
        self.workflow.do_engine_steps()
        self.save_restore()
        # The inclusive gateway allows us through here, because there is no route for the other thread
        # that doesn't use the same sequence flow
        self.do_next_named_step("Done")
        self.workflow.do_engine_steps()
        self.save_restore()
        self.do_next_named_step("Repeated Task")
        self.workflow.do_engine_steps()
        self.save_restore()

        self.do_next_named_step("Done")
        self.workflow.do_engine_steps()
        self.save_restore()

        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:conlini,项目名称:SpiffWorkflow,代码行数:35,代码来源:ParallelTest.py

示例7: testRunThroughAlternating

    def testRunThroughAlternating(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()

        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step("Do First")
        self.workflow.do_engine_steps()
        self.do_next_named_step("SP 1 - Choose", choice="Yes")
        self.workflow.do_engine_steps()
        self.do_next_named_step("SP 2 - Choose", choice="Yes")
        self.workflow.do_engine_steps()
        self.do_next_named_step("SP 3 - Choose", choice="Yes")
        self.workflow.do_engine_steps()
        self.do_next_named_step("SP 1 - Yes Task")
        self.workflow.do_engine_steps()
        self.do_next_named_step("SP 2 - Yes Task")
        self.workflow.do_engine_steps()
        self.do_next_named_step("SP 3 - Yes Task")
        self.workflow.do_engine_steps()

        self.do_next_named_step("Done")
        self.workflow.do_engine_steps()

        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:conlini,项目名称:SpiffWorkflow,代码行数:26,代码来源:ParallelTest.py

示例8: testNoRouteRepeatTaskFirst

    def testNoRouteRepeatTaskFirst(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()
        self.save_restore()

        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step("Repeated Task")
        self.workflow.do_engine_steps()
        self.save_restore()
        # The inclusive gateway allows this to pass through (since there is a route to it on the same sequence flow)
        self.do_next_named_step("Done")
        self.workflow.do_engine_steps()
        self.save_restore()
        self.do_next_named_step("Choice 1", choice="No")
        self.workflow.do_engine_steps()
        self.save_restore()
        self.do_next_named_step("No Task")
        self.workflow.do_engine_steps()
        self.save_restore()
        self.do_next_named_step("Done")
        self.workflow.do_engine_steps()
        self.save_restore()

        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:conlini,项目名称:SpiffWorkflow,代码行数:26,代码来源:ParallelTest.py

示例9: testRunThroughMessageInterrupt

    def testRunThroughMessageInterrupt(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.do_next_exclusive_step('Select Test', choice='Message Non Interrupt')
        self.workflow.do_engine_steps()

        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.workflow.accept_message('Test Message')

        self.workflow.do_engine_steps()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.WAITING)))
        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step('Acknowledge Non-Interrupt Message')

        self.workflow.do_engine_steps()
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.do_next_named_step('Do Something That Takes A Long Time')

        self.workflow.do_engine_steps()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:0-T-0,项目名称:SpiffWorkflow,代码行数:25,代码来源:MessageNonInterruptTest.py

示例10: setUp

    def setUp(self):
        self.spec = self.load_spec()
        self.workflow = BpmnWorkflow(self.spec)

        start_time = datetime.datetime.now() + datetime.timedelta(seconds=0.5)
        finish_time = datetime.datetime.now() + datetime.timedelta(seconds=1.5)

        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.workflow.get_tasks(Task.READY)[0].set_data(start_time=start_time, finish_time=finish_time)
开发者ID:0-T-0,项目名称:SpiffWorkflow,代码行数:9,代码来源:ActionManagementTest.py

示例11: testRunThroughHappy

    def testRunThroughHappy(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.do_next_named_step('Action1')
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.do_next_named_step('Action2')
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.do_next_named_step('Action3')
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:0-T-0,项目名称:SpiffWorkflow,代码行数:15,代码来源:NestedProcessesTest.py

示例12: testRunThroughHappy

    def testRunThroughHappy(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.do_next_exclusive_step('Select Test', choice='Message Non Interrupt')
        self.workflow.do_engine_steps()

        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))

        self.do_next_exclusive_step('Do Something That Takes A Long Time')

        self.workflow.do_engine_steps()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.WAITING)))

        self.workflow.do_engine_steps()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:0-T-0,项目名称:SpiffWorkflow,代码行数:16,代码来源:MessageNonInterruptTest.py

示例13: testRunThroughHappy

    def testRunThroughHappy(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.do_next_exclusive_step('Select Test', choice='Messages')
        self.workflow.do_engine_steps()
        self.assertEquals([], self.workflow.get_tasks(Task.READY))
        self.assertEquals(1, len(self.workflow.get_tasks(Task.WAITING)))
        self.workflow.accept_message('Wrong Message')
        self.assertEquals([], self.workflow.get_tasks(Task.READY))
        self.workflow.accept_message('Test Message')
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))

        self.assertEquals('Test Message', self.workflow.get_tasks(Task.READY)[0].task_spec.description)

        self.workflow.do_engine_steps()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:AnyBucket,项目名称:SpiffWorkflow,代码行数:16,代码来源:MessagesTest.py

示例14: NestedProcessesTest

class NestedProcessesTest(BpmnWorkflowTestCase):
    def setUp(self):
        self.spec = self.load_spec()

    def load_spec(self):
        return self.load_workflow_spec('Test-Workflows/*.bpmn20.xml', 'Nested Subprocesses')

    def testRunThroughHappy(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.do_next_named_step('Action1')
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.do_next_named_step('Action2')
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(1, len(self.workflow.get_tasks(Task.READY)))
        self.do_next_named_step('Action3')
        self.workflow.do_engine_steps()
        self.save_restore()
        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:0-T-0,项目名称:SpiffWorkflow,代码行数:22,代码来源:NestedProcessesTest.py

示例15: testRunThroughParallelTaskFirst

    def testRunThroughParallelTaskFirst(self):

        self.workflow = BpmnWorkflow(self.spec)
        self.workflow.do_engine_steps()

        self.assertEquals(2, len(self.workflow.get_tasks(Task.READY)))

        self.do_next_named_step('Parallel Task')
        self.workflow.do_engine_steps()
        self.assertRaises(AssertionError, self.do_next_named_step, 'Done')
        self.do_next_named_step('Choice 1', choice='No')
        self.workflow.do_engine_steps()

        self.do_next_named_step('Done')
        self.workflow.do_engine_steps()

        self.assertEquals(0, len(self.workflow.get_tasks(Task.READY | Task.WAITING)))
开发者ID:AnyBucket,项目名称:SpiffWorkflow,代码行数:17,代码来源:ParallelTest.py


注:本文中的SpiffWorkflow.bpmn.BpmnWorkflow.BpmnWorkflow类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。