TypeError: write() takes at least 5 arguments (2 given) - inherited module from v8 to v10 community

TypeError: write() takes at least 5 arguments (2 given) - inherited module from v8 to v10 community

我正在将一些模块从 v8 迁移到 v10 社区

这次我在尝试创建发票时遇到此错误:

Traceback (most recent call last):
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 638, in _handle_exception
return super(JsonRequest, self)._handle_exception(exception)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 675, in dispatch
result = self._call_function(**self.params)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 331, in _call_function
return checked_call(self.db, *args, **kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/service/model.py", line 119, in wrapper
return f(dbname, *args, **kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 324, in checked_call
result = self.endpoint(*a, **kw)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 933, in __call__
return self.method(*args, **kw)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/http.py", line 504, in response_wrap
response = f(*args, **kw)
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/web/controllers/main.py", line 862, in call_kw
return self._call_kw(model, method, args, kwargs)
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/web/controllers/main.py", line 854, in _call_kw
return call_kw(request.env[model], method, args, kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/api.py", line 679, in call_kw
return call_kw_model(method, model, args, kwargs)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/api.py", line 664, in call_kw_model
result = method(recs, *args, **kwargs)
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/account/models/account_invoice.py", line 342, in create
invoice = super(AccountInvoice, self.with_context(mail_create_nolog=True)).create(vals)
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/mail/models/mail_thread.py", line 227, in create
thread = super(MailThread, self).create(values)
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/models.py", line 3798, in create
record = self.browse(self._create(old_vals))
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/models.py", line 3958, in _create
self.recompute()
File "/home/kristian/.virtualenvs/odoov10/lib/python2.7/site-packages/odoo-10.0rc1c_20161005-py2.7.egg/odoo/models.py", line 5277, in recompute
recs.browse(ids)._write(dict(vals))
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/account/models/account_invoice.py", line 356, in _write
(reconciled & pre_reconciled).filtered(lambda invoice: invoice.state == 'open').action_invoice_paid()
File "/home/kristian/odoov10/odoo-10.0rc1c-20161005/odoo/addons/account/models/account_invoice.py", line 573, in action_invoice_paid
return to_pay_invoices.write({'state': 'paid'})
TypeError: write() takes at least 5 arguments (2 given)

它没有说明实际错误来自哪里,它必须来自我正在迁移的模块,这是我的模块中有 'state' : 'paid' 的方法:

@api.multi
def action_invoice_create(self, cr, uid, ids, wizard_brw, inv_brw,
                          context=None):
    """
    If the invoice has control number, this function is responsible for
    passing the bill to damaged paper
    @param wizard_brw: nothing for now
    @param inv_brw: damaged paper
    """
    invoice_line_obj = self.env('account.invoice.line')
    invoice_obj = self.env('account.invoice')
    acc_mv_obj = self.env('account.move')
    acc_mv_l_obj = self.env('account.move.line')
    tax_obj = self.env('account.invoice.tax')
    invoice = {}
    if inv_brw.nro_ctrl:
        invoice.update({
            'name': 'PAPELANULADO_NRO_CTRL_%s' % (
                inv_brw.nro_ctrl and inv_brw.nro_ctrl or ''),
            'state': 'paid',
            'tax_line': [],
        })
    else:
        raise osv.except_osv(
            _('Validation error!'),
            _("You can run this process just if the invoice have Control"
              " Number, please verify the invoice and try again."))
    invoice_obj.write(cr, uid, [inv_brw.id], invoice, context=context)
    for line in inv_brw.invoice_line:
        invoice_line_obj.write(
            cr, uid, [line.id],
            {'quantity': 0.0, 'invoice_line_tax_id': [],
             'price_unit': 0.0}, context=context)

    tax_ids = self.env('account.tax').search(cr, uid, [],
                                                  context=context)
    tax = tax_obj.search(cr, uid,
                         [('invoice_id', '=', inv_brw and inv_brw.id)],
                         context=context)
    if tax:
        tax_obj.write(cr, uid, tax[0], {'invoice_id': []}, context=context)
    tax_obj.create(cr, uid, {
        'name': 'SDCF',
        'tax_id': tax_ids and tax_ids[0],
        'amount': 0.00,
        'tax_amount': 0.00,
        'base': 0.00,
        'account_id': inv_brw.company_id.acc_id.id,
        'invoice_id': inv_brw and inv_brw.id}, {})
    move_id = inv_brw.move_id and inv_brw.move_id.id

    if move_id:
        acc_mv_obj.button_cancel(cr, uid, [inv_brw.move_id.id],
                                 context=context)
        acc_mv_obj.write(cr, uid, [inv_brw.move_id.id],
                         {'ref': 'Damanged Paper'}, context=context)
        acc_mv_l_obj.unlink(cr, uid,
                            [i.id for i in inv_brw.move_id.line_id])
    return inv_brw.id

对此有什么想法吗?

因为这是对记录进行操作的代码,所以我添加了 @api.multi 装饰器,但我不确定这是否是问题所在。

编辑

这是 account 模块上的方法:

@api.multi
def action_invoice_paid(self):
    # lots of duplicate calls to action_invoice_paid, so we remove those already paid
    to_pay_invoices = self.filtered(lambda inv: inv.state != 'paid')
    if to_pay_invoices.filtered(lambda inv: inv.state != 'open'):
        raise UserError(_('Invoice must be validated in order to set it to register payemnt.'))
    if to_pay_invoices.filtered(lambda inv: not inv.reconciled):
        raise UserError(_('You cannot pay an invoice which is partially paid. You need to reconcile payment entries first.'))
    return to_pay_invoices.write({'state': 'paid'})

但我不确定这是一个错误,还是我的模块中继承了 account.invoice class 的方法导致的,我认为是后者。

你在这里混淆了旧的 API 和新的 API:

@api.multi
def action_invoice_create(
    self, cr, uid, ids, wizard_brw, inv_brw, context=None):

cruididscontextself.env 处理,因此您无需再声明它们。如果需要,Odoo 会自动将方法包装为旧的或新的 API 样式。

新的API样式应该是:

@api.multi
def action_invoice_create(self, wizard_brw, inv_brw):

还有一个关于 Odoo 10 的提示:现在(终于)invoice_line_ids ;-)