我有一个在V9中可以使用的版本9模式。我试图将其安装在V10中并出现错误。创建安全组时发生错误。我还尝试了从维护工具迁移到V10的方法。
> Replace openerp imports to odoo.
>
> Rename __openerp__.py to __manifest__.py
>
> Replace select = True by index = TrueReplace string selectors in XML by name (if possible) or other attribute selector or even another
> equivalent path/reference. For example, change <group string="x"
> position="after"> by <group name="x" position="after">Remove <data>
> and </data> in xml files if noupdate="0"
>
> Replace the <openerp>/</openerp> tags in xml files by <odoo>/</odoo>.
>
> Don't use @api.one with @api.onchange or it will crash.
>
> ...
下面是错误
File "/home/jason/git/odoo10/odoo/addons/base/ir/ir_model.py", line 1028, in xmlid_lookup
raise ValueError('External ID not found in the system: %s' % xmlid)
ParseError: "<type 'exceptions.ValueError'>: "External ID not found in the system: base.group_sale_salesman_all_leads" while evaluating
"[(4,ref('base.group_user')), (4,ref('account.group_account_invoice')), (4,ref('stock.group_stock_user')), (4,ref('base.group_sale_salesman_all_leads'))]"" while parsing /home/jason/git/customaddons/layby_order/security/layby_security.xml:5, near
<record id="group_layby_user" model="res.groups">
<field name="name">Layby User</field>
<field name="category_id" ref="base.module_category_sales_management"/>
<field name="comment">This is applicable for Layby User.</field>
<field name="implied_ids" eval="[(4,ref('base.group_user')), (4,ref('account.group_account_invoice')), (4,ref('stock.group_stock_user')), (4,ref('base.group_sale_salesman_all_leads'))]"/>
</record>
layby_security.xml
<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<record id="group_layby_user" model="res.groups">
<field name="name">Layby User</field>
<field name="category_id" ref="base.module_category_sales_management"/>
<field name="comment">This is applicable for Layby User.</field>
<field name="implied_ids" eval="[(4,ref('base.group_user')),
(4,ref('account.group_account_invoice')),
(4,ref('stock.group_stock_user')),
(4,ref('base.group_sale_salesman_all_leads'))]"/>
</record>
</data>
</openerp>
ir.model.access.csv
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_layby_order,layby.order,model_layby_order,group_layby_user,1,1,1,0
access_layby_order_line,layby.order.line,model_layby_order_line,group_layby_user,1,1,1,1
如果我停止服务器并重新启动它,然后尝试安装,我得到的第一个错误是
File "/home/jason/git/customaddons/layby_order/layby.py", line 147
date_order = fields.Date.context_today(self)
SyntaxError: invalid syntax
在那之后,如果我安装了,我会得到解析错误外部ID找不到。我在想我得到它的原因是因为安装在第147
date_order = fields.Date.context_today(self)
行上停止,但是我不知道为什么。更新
仍在147行停止
date_order = fields.Date.context_today(self))
更改为
sales_team.group_sale_salesman_all_leads
后原始错误消失了,但现在得到了
raise Exception(_('Module loading %s failed: file %s could not be processed:\n %s') % (module, fname, warning_msg))
Exception: Module loading layby_order failed: file layby_order/security/ir.model.access.csv could not be processed:
No matching record found for external id 'model_layby_order' in field 'Object'
Missing required value for the field 'Object' (model_id)
No matching record found for external id 'model_layby_order_line' in field 'Object'
Missing required value for the field 'Object' (model_id)
最佳答案
OCA的将模块从v9迁移到v10的指南就足够了,只是没有提到曾经用base
作为前缀的几个安全组已被移动/模块化到它们各自的模块,例如base.group_hr_user
您所见的base.group_sale_salesman_all_leads
。
要解决您的第一个问题,请将base.group_sale_salesman_all_leads
中的参考sales_team.group_sale_salesman_all_leads
更改为layby_security.xml
:
<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<record id="group_layby_user" model="res.groups">
<field name="name">Layby User</field>
<field name="category_id" ref="base.module_category_sales_management"/>
<field name="comment">This is applicable for Layby User</field>
<field name="implied_ids" eval="[(4,ref('base.group_user')),
(4,ref('account.group_account_invoice')),
(4,ref('stock.group_stock_user')),
(4,ref('sales_team.group_sale_salesman_all_leads'))]"/>
</record>
</data>
</openerp>
对于第二个问题,如果
date_order
是要添加到班级的字段,请执行以下操作:date_order = fields.Date(default=fields.Date.context_today)
否则,如果您实际上是在声明变量而不是新字段,则语法看起来不错,并且Odoo 10仍在使用
fields.Date.context_today()
。您可以look it up on github。
编辑:(问题更新后)
该错误可能是因为您在
res.groups
记录中缺少模型声明。您可以尝试在layby_security.xml中添加
<field name="model_id" ref="model_layby_order"/>
吗?<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<record id="group_layby_user" model="res.groups">
<field name="name">Layby User</field>
<field name="model_id" ref="model_layby_order"/>
<field name="category_id" ref="base.module_category_sales_management"/>
<field name="comment">This is applicable for Layby User</field>
<field name="implied_ids" eval="[(4,ref('base.group_user')),
(4,ref('account.group_account_invoice')),
(4,ref('stock.group_stock_user')),
(4,ref('sales_team.group_sale_salesman_all_leads'))]"/>
</record>
</data>
</openerp>