c2c-oerpscenario team mailing list archive
-
c2c-oerpscenario team
-
Mailing list archive
-
Message #29845
[Bug 819872] Re: server actions of type "trigger" cause crashes
** Description changed:
Hi!
I create two objects, A and B. A has a many2one field to B called B_id.
A and B have an associated workflow each. I want a transition on B's
workflow to be triggered by a modification on the workflow of A.
Here is the server action I created for this purpose:
- <record id="ir_actions_server_confirmB" model="ir.actions.server">
- <field name="trigger_obj_id" ref="mymodule.field_mymodule_A_B_id"/>
- <field name="wkf_model_id" ref="mymodule.model_mymodule_B"/>
- <field name="state">trigger</field>
- <field name="type">ir.actions.server</field>
- <field name="model_id" ref="mymodule.model_mymodule_A"/>
- <field name="trigger_name">mymodule.B</field>
- <field name="condition">True</field>
- <field name="name">Confirm B</field>
- </record>
+ <record id="ir_actions_server_confirmB" model="ir.actions.server">
+ <field name="trigger_obj_id" ref="mymodule.field_mymodule_A_B_id"/>
+ <field name="wkf_model_id" ref="mymodule.model_mymodule_B"/>
+ <field name="state">trigger</field>
+ <field name="type">ir.actions.server</field>
+ <field name="model_id" ref="mymodule.model_mymodule_A"/>
+ <field name="trigger_name">mymodule.B</field>
+ <field name="condition">True</field>
+ <field name="name">Confirm B</field>
+ </record>
+
+
+ Remark: the line <field name="trigger_name">mymodule.B</field> already seems strange, but I have no choice (and it was generated like that by the module recorder); see infra for details.
+
Then I add this in the definition of one of the activities of A's workflow (call it "A_Act"):
-
- <field name="action_id" model="ir.actions.server"
- ref="ir_actions_server_confirmB"/>
+ <field name="action_id" model="ir.actions.server"
+ ref="ir_actions_server_confirmB"/>
Then I run the server. I create a record of type "A". Its "B_id" field references a B record already created; for the sake of the example, let us assume that this record has the id "2" and its field "name" has the value "B_Name".
In summary :
- A instance: {"B_id":2}
- B instance: {"id":9 , "name":"B_Name"}
+ A instance: {"B_id":2}
+ B instance: {"id":9 , "name":"B_Name"}
I trigger the transitions on A's workflow until the moment I reach the
activity "A_Act".
At this moment I get the following error:
TypeError: int() argument must be a string or a number, not 'tuple'
> /home/fde/repository/openobject-server_trunk/openerp/addons/base/ir/ir_actions.py(666)run()
-> wf_service.trg_validate(uid, model, int(id), action.trigger_name, cr)
(Pdb) model
u'mymodule.B'
(Pdb) id
(2, u'B_Name')
- (Pdb)
-
+ (Pdb)
I managed to get no error when I modified "int(id)" to "int(id[0])".
- However it still does not work because I think there is something quite
- stupid in the definition of the server action. That is the following
- function (line 436):
+ However it still does not work because there is something wrong in the
+ definition of the server action. That is the following function (line
+ 436):
def _select_signals(self, cr, uid, context=None):
- cr.execute("SELECT distinct w.osv, t.signal FROM wkf w, wkf_activity a, wkf_transition t \
- WHERE w.id = a.wkf_id AND t.act_from = a.id OR t.act_to = a.id AND t.signal!='' \
- AND t.signal NOT IN (null, NULL)")
- result = cr.fetchall() or []
- res = []
- for rs in result:
- if rs[0] is not None and rs[1] is not None:
- line = rs[0], "%s - (%s)" % (rs[1], rs[0])
- res.append(line)
- return res
+ cr.execute("SELECT distinct w.osv, t.signal FROM wkf w, wkf_activity a, wkf_transition t \
+ WHERE w.id = a.wkf_id AND t.act_from = a.id OR t.act_to = a.id AND t.signal!='' \
+ AND t.signal NOT IN (null, NULL)")
+ result = cr.fetchall() or []
+ res = []
+ for rs in result:
+ if rs[0] is not None and rs[1] is not None:
+ line = rs[0], "%s - (%s)" % (rs[1], rs[0])
+ res.append(line)
+ return res
-
- The field "trigger_name" is defined as follows:
+ And the field "trigger_name" is defined as follows:
'trigger_name': fields.selection(_select_signals, ...........
- Of course, the value of the selection will be something like [('osv object','signal')] but it should be the opposite!!! The signal is not
- "mymodule.B" but well something like "signal_confirm_B".
+ Of course, the value of the selection will be something like [('osv object','signal')] but it should be the opposite!!! The signal is not
+ "mymodule.B" but well something like "signal_confirm_B".
And indeed, I confirm it works if I write "SELECT distinct
- t.signal,w.osv..." instead.
+ t.signal,w.osv..." instead. Of course, I also changed my server action:
+
+ <field name="trigger_name">signal_name</field>
+
+ instead of
+ <field name="trigger_name">mymodule.B</field>
trunk rev 3524
--
You received this bug notification because you are a member of C2C
OERPScenario, which is subscribed to the OpenERP Project Group.
https://bugs.launchpad.net/bugs/819872
Title:
server actions of type "trigger" cause crashes
Status in OpenERP Server:
New
Bug description:
Hi!
I create two objects, A and B. A has a many2one field to B called
B_id.
A and B have an associated workflow each. I want a transition on B's
workflow to be triggered by a modification on the workflow of A.
Here is the server action I created for this purpose:
<record id="ir_actions_server_confirmB" model="ir.actions.server">
<field name="trigger_obj_id" ref="mymodule.field_mymodule_A_B_id"/>
<field name="wkf_model_id" ref="mymodule.model_mymodule_B"/>
<field name="state">trigger</field>
<field name="type">ir.actions.server</field>
<field name="model_id" ref="mymodule.model_mymodule_A"/>
<field name="trigger_name">mymodule.B</field>
<field name="condition">True</field>
<field name="name">Confirm B</field>
</record>
Remark: the line <field name="trigger_name">mymodule.B</field> already seems strange, but I have no choice (and it was generated like that by the module recorder); see infra for details.
Then I add this in the definition of one of the activities of A's workflow (call it "A_Act"):
<field name="action_id" model="ir.actions.server"
ref="ir_actions_server_confirmB"/>
Then I run the server. I create a record of type "A". Its "B_id" field references a B record already created; for the sake of the example, let us assume that this record has the id "2" and its field "name" has the value "B_Name".
In summary :
A instance: {"B_id":2}
B instance: {"id":9 , "name":"B_Name"}
I trigger the transitions on A's workflow until the moment I reach the
activity "A_Act".
At this moment I get the following error:
TypeError: int() argument must be a string or a number, not 'tuple'
> /home/fde/repository/openobject-server_trunk/openerp/addons/base/ir/ir_actions.py(666)run()
-> wf_service.trg_validate(uid, model, int(id), action.trigger_name, cr)
(Pdb) model
u'mymodule.B'
(Pdb) id
(2, u'B_Name')
(Pdb)
I managed to get no error when I modified "int(id)" to "int(id[0])".
However it still does not work because there is something wrong in the
definition of the server action. That is the following function (line
436):
def _select_signals(self, cr, uid, context=None):
cr.execute("SELECT distinct w.osv, t.signal FROM wkf w, wkf_activity a, wkf_transition t \
WHERE w.id = a.wkf_id AND t.act_from = a.id OR t.act_to = a.id AND t.signal!='' \
AND t.signal NOT IN (null, NULL)")
result = cr.fetchall() or []
res = []
for rs in result:
if rs[0] is not None and rs[1] is not None:
line = rs[0], "%s - (%s)" % (rs[1], rs[0])
res.append(line)
return res
And the field "trigger_name" is defined as follows:
'trigger_name': fields.selection(_select_signals, ...........
Of course, the value of the selection will be something like [('osv object','signal')] but it should be the opposite!!! The signal is not
"mymodule.B" but well something like "signal_confirm_B".
And indeed, I confirm it works if I write "SELECT distinct
t.signal,w.osv..." instead. Of course, I also changed my server
action:
<field name="trigger_name">signal_name</field>
instead of
<field name="trigger_name">mymodule.B</field>
trunk rev 3524
To manage notifications about this bug go to:
https://bugs.launchpad.net/openobject-server/+bug/819872/+subscriptions
References