我有一个在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>

10-02 10:54