osworkflow dynamic split 动态会签的实现

目前 osworkflow的版本是2.8,很久没有更新了,而且这个版本的动态会签无法实现,虽然她提供了 split和join这样的标签,但是split中result的个数是固定的,这往往在我们现实的系统中用的很少,比如 我要给你一个组提供会签功能,而这个组的人数事先是不知道的,所以必须提供动态会签,也就是动态的split。

附件里面是我通过改写osworkflow使其能够动态会签的例子

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE workflow PUBLIC "-//OpenSymphony Group//DTD OSWorkflow 2.8//EN" "workflow_2_8.dtd" >
<workflow>
  <initial-actions>
    <action id="1" name="Start Workflow">
      <results>
        <unconditional-result old-status="Finished" status="Queued" step="1"/>
      </results>
    </action>
  </initial-actions>
  <steps>
    <step id="1" name="First Part">
      <actions>
        <action id="2" name="Finish First Part">
          <results>
            <unconditional-result old-status="Finished" status="Queued" split="1" owner="test1,test2,test3"/>
          </results>
        </action>
      </actions>
    </step>
    <step id="2" name="Second Part">
      <actions>
        <action id="3" name="Back to First Part">
          <results>
            <unconditional-result old-status="Rejected" status="Queued" join="2"/>
          </results>
        </action>
        <action id="4" name="Finish">
          <results>
            <unconditional-result old-status="Finished" status="Queued" join="1"/>
          </results>
        </action>
      </actions>
    </step>

    <step id="4" name="End" />
  </steps>

  <splits>
    <split id="1" dynamic="TRUE" obtain-groups-callback="com.siemens.dingchao.test.DynamicSplitGroup"

>
      <unconditional-result old-status="Finished" status="Queued" step="2"/>
    </split>
  </splits>

  <joins>
    <join id="1">
      <conditions type="AND">
        <condition type="beanshell">
          <arg name="script">"Finished".equals(jn.getStep(2,"test1").getStatus())</arg>
        </condition>
        <condition type="beanshell">
          <arg name="script">"Finished".equals(jn.getStep(2,"test2").getStatus())</arg>
        </condition>
         <condition type="beanshell">
          <arg name="script">"Finished".equals(jn.getStep(2,"test3").getStatus())</arg>
        </condition>
      </conditions>
      <unconditional-result old-status="Finished" status="Underway" step="4"/>
    </join>
    <join id="2">
      <conditions type="OR">
        <condition type="beanshell">
          <arg name="script">"Rejected".equals(jn.getStep(2,"test1").getStatus())</arg>
        </condition>
        <condition type="beanshell">
          <arg name="script">"Rejected".equals(jn.getStep(2,"test2").getStatus())</arg>
        </condition>
        <condition type="beanshell">
          <arg name="script">"Rejected".equals(jn.getStep(2,"test3").getStatus())</arg>
        </condition>
      </conditions>
      <unconditional-result old-status="Finished" status="Underway" step="1"/>
    </join>
  </joins>
</workflow>

 

上面的红颜色部分是我为split标签添加的 属性,dynamic 属性 : 可以为 TRUE,true,FALSE,false,指定是否是动态的,如果是动态的 则必须指定obtain-group-callback 属性,该callback必须实现com.opensymphony.workflow.util.DynamicSplitGroupCallback接口(该接口为新添加)

 

 

 

test case :

 

/*
 * Copyright (c) 2002-2003 by OpenSymphony
 * All rights reserved.
 */
package com.siemens.dingchao.test;

import junit.framework.TestCase;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.opensymphony.workflow.Workflow;
import com.opensymphony.workflow.basic.BasicWorkflow;


/**
 * @author hani Date: Feb 17, 2005 Time: 4:24:20 PM
 */
public class JoinTestCase extends TestCase {
    //~ Instance fields ////////////////////////////////////////////////////////

    private Workflow workflow;

    //~ Methods ////////////////////////////////////////////////////////////////

    public void testWithReject() throws Exception {
    	//说明:
        checkRoute(new int[] {2, 3, 2, 4 ,4 ,4});

    	//checkRoute(new int[] {4,4});
    }

    protected void setUp() throws Exception {
       /* workflow = new BasicWorkflow("testuser");*/
        ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
        workflow = (Workflow)context.getBean("workflow");
    
    }

    private void checkRoute(int[] actions) throws Exception {
        long workflowId = workflow.initialize("join", 1, null);

        for (int i = 0; i < actions.length; i++) {
            workflow.doAction(workflowId, actions[i], null);
        }
    }
}
 

 

test case 的红颜色部分标明了 步骤的 route 均是 xml里面的action id ,你可以把这个数字和xml对照起来看。

 

 

调试结果     以下图例都是 表 os_currentstep:

 

流程实例初始化


osworkflow dynamic split 动态会签的实现_第1张图片

 

运行action  2 此时动态split为3个任务,因为 owner为 test1,test2,test3


osworkflow dynamic split 动态会签的实现_第2张图片
 运行action : 3  reject(驳回) 回到step1
osworkflow dynamic split 动态会签的实现_第3张图片

运行action 2 ,相当于再次提交任务,此时任务再次分裂成为3个任务,owner分别为test1 ,test2,test3


osworkflow dynamic split 动态会签的实现_第4张图片

test1 执行action 4 : test1 用户提交任务


osworkflow dynamic split 动态会签的实现_第5张图片

test2执行action 4 : test2 用户提交任务


osworkflow dynamic split 动态会签的实现_第6张图片

test3 执行action 4 : test3 用户提交任务


osworkflow dynamic split 动态会签的实现_第7张图片

此时3个用户都提交了任务,任务移动到下一步 , 即 结束节点,至此 这个工作流实例完成

 

在看看 os_historystep 表的数据 :

 


osworkflow dynamic split 动态会签的实现_第8张图片

我们可以发现历史信息业完整的记录了这个操作轨迹。

 

希望能给你们带来帮助

你可能感兴趣的:(workflow)