我创建了一个工作流程,它的工作非常完美。 工作流活动调用的函数是
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
。
对于任何其他声明,我们不能对同一记录允许两次。
为什么会这样?&如何覆盖这个?
答案 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