为什么工作流程会将函数调用两次&如何覆盖它?

时间:2012-07-19 08:45:57

标签: openerp

我创建了一个工作流程,它的工作非常完美。 工作流活动调用的函数是

  def employee_confirm(self, cr, uid, ids, context=None):  
    print "Entering >>>employee_confirm"
    return self.write(cr, uid, ids, {'state':'confirm'})

我的问题是print语句执行两次。 这意味着该功能正在执行两次。

这个没关系

self.write(cr, uid, ids, {'state':'confirm'})

因为它是write

对于任何其他声明,我们不能对同一记录允许两次。

为什么会这样?&如何覆盖这个?

1 个答案:

答案 0 :(得分:0)

了解和调试工作流代码是构建新OpenERP模块时最难的任务之一。我发现tracing the code in Eclipse是看到发生了什么的唯一方法,但是花了很长时间。

这是我编写的用于总结工作流转换的SQL查询。我打印出工作流程图,然后将这些数据复制到图表上。据我所知,您只能从GTK客户端not the web client打印图表。使用所需的工作流程打开屏幕,然后从“插件”菜单中选择“执行插件”,然后双击“打印工作流程”。

    select  wkf.name, 
            f.name || '(' || f.id || ')' as src, 
            f.kind,
            f.action as from_action,
            f.split_mode, 
            f.flow_start,
            t.name || '(' || t.id || ')' as dest, 
            t.kind as dest_kind,
            t.action as dest_action,
            t.join_mode, 
            t.flow_stop, 
            tr.*
    from wkf_transition tr
    join wkf_activity f
    on tr.act_from = f.id
    join wkf_activity t
    on tr.act_to = t.id
    join wkf
    on f.wkf_id = wkf.id
    order by wkf.name, f.name, t.name