cubells
8 years ago
committed by
Pedro M. Baeza
12 changed files with 169 additions and 211 deletions
-
38contract_payment_mode/README.rst
-
2contract_payment_mode/__init__.py
-
36contract_payment_mode/__openerp__.py
-
5contract_payment_mode/hooks.py
-
27contract_payment_mode/i18n/contract_payment_mode.pot
-
28contract_payment_mode/models/contract.py
-
49contract_payment_mode/test/contract_payment_mode.yml
-
4contract_payment_mode/tests/__init__.py
-
83contract_payment_mode/tests/test_contract_payment.py
-
40contract_payment_mode/tests/test_contract_payment_init.py
-
67contract_payment_mode/views/contract_view.xml
-
1oca_dependencies.txt
@ -1,5 +1,5 @@ |
|||||
# -*- coding: utf-8 -*- |
# -*- coding: utf-8 -*- |
||||
# © 2016 Antiun Ingenieria S.L. - Antonio Espinosa |
|
||||
|
# Copyright 2016 Antiun Ingenieria S.L. - Antonio Espinosa |
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
||||
|
|
||||
from . import models |
from . import models |
||||
|
@ -1,40 +1,26 @@ |
|||||
# -*- coding: utf-8 -*- |
# -*- coding: utf-8 -*- |
||||
|
|
||||
############################################################################### |
|
||||
# |
|
||||
# OpenERP, Open Source Management Solution |
|
||||
# Copyright (C) 2015 Domatix (<www.domatix.com>). |
|
||||
# |
|
||||
# This program is free software: you can redistribute it and/or modify |
|
||||
# it under the terms of the GNU Affero General Public License as |
|
||||
# published by the Free Software Foundation, either version 3 of the |
|
||||
# License, or (at your option) any later version. |
|
||||
# |
|
||||
# This program is distributed in the hope that it will be useful, |
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
||||
# GNU Affero General Public License for more details. |
|
||||
# |
|
||||
# You should have received a copy of the GNU Affero General Public License |
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
||||
# |
|
||||
############################################################################### |
|
||||
|
# Copyright 2015 Domatix (<www.domatix.com>) |
||||
|
# Copyright 2016 Antiun Ingenieria S.L. - Antonio Espinosa |
||||
|
# Copyright 2017 Tecnativa - Vicent Cubells |
||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
||||
|
|
||||
{ |
{ |
||||
'name': 'Contract Payment Mode', |
'name': 'Contract Payment Mode', |
||||
'summary': 'Payment mode in contracts and their invoices', |
'summary': 'Payment mode in contracts and their invoices', |
||||
'version': '8.0.1.0.0', |
|
||||
'author': 'Domatix, Odoo Community Association (OCA)', |
|
||||
|
'version': '9.0.1.0.0', |
||||
|
'author': 'Domatix, ' |
||||
|
'Tecnativa, ' |
||||
|
'Odoo Community Association (OCA)', |
||||
'website': 'http://www.domatix.com', |
'website': 'http://www.domatix.com', |
||||
'depends': [ |
'depends': [ |
||||
'account_analytic_analysis', |
|
||||
'account_payment_partner'], |
|
||||
|
'contract', |
||||
|
'account_payment_partner' |
||||
|
], |
||||
'category': 'Sales Management', |
'category': 'Sales Management', |
||||
'license': 'AGPL-3', |
'license': 'AGPL-3', |
||||
'data': [ |
'data': [ |
||||
'views/contract_view.xml', |
'views/contract_view.xml', |
||||
], |
], |
||||
'test': ['test/contract_payment_mode.yml'], |
|
||||
'post_init_hook': 'post_init_hook', |
'post_init_hook': 'post_init_hook', |
||||
'installable': True, |
'installable': True, |
||||
'auto_install': True, |
'auto_install': True, |
||||
|
@ -1,27 +0,0 @@ |
|||||
# Translation of Odoo Server. |
|
||||
# This file contains the translation of the following modules: |
|
||||
# * contract_payment_mode |
|
||||
# |
|
||||
msgid "" |
|
||||
msgstr "" |
|
||||
"Project-Id-Version: Odoo Server 8.0\n" |
|
||||
"Report-Msgid-Bugs-To: \n" |
|
||||
"POT-Creation-Date: 2015-10-16 08:32+0000\n" |
|
||||
"PO-Revision-Date: 2015-10-16 08:32+0000\n" |
|
||||
"Last-Translator: <>\n" |
|
||||
"Language-Team: \n" |
|
||||
"MIME-Version: 1.0\n" |
|
||||
"Content-Type: text/plain; charset=UTF-8\n" |
|
||||
"Content-Transfer-Encoding: \n" |
|
||||
"Plural-Forms: \n" |
|
||||
|
|
||||
#. module: contract_payment_mode |
|
||||
#: model:ir.model,name:contract_payment_mode.model_account_analytic_account |
|
||||
msgid "Analytic Account" |
|
||||
msgstr "" |
|
||||
|
|
||||
#. module: contract_payment_mode |
|
||||
#: field:account.analytic.account,payment_mode_id:0 |
|
||||
msgid "Payment Mode" |
|
||||
msgstr "" |
|
||||
|
|
@ -1,33 +1,27 @@ |
|||||
# -*- coding: utf-8 -*- |
# -*- coding: utf-8 -*- |
||||
from openerp import models, fields, api |
|
||||
|
from openerp import api, fields, models |
||||
|
|
||||
|
|
||||
class AccountAnalyticAccount(models.Model): |
class AccountAnalyticAccount(models.Model): |
||||
_inherit = 'account.analytic.account' |
_inherit = 'account.analytic.account' |
||||
|
|
||||
payment_mode_id = fields.Many2one( |
payment_mode_id = fields.Many2one( |
||||
'payment.mode', |
|
||||
|
comodel_name='account.payment.mode', |
||||
string='Payment Mode', |
string='Payment Mode', |
||||
domain="[('sale_ok', '=', True)]") |
|
||||
|
domain=[('payment_type', '=', 'inbound')], |
||||
|
) |
||||
|
|
||||
@api.multi |
|
||||
def on_change_partner_id(self, partner_id, name): |
|
||||
res = super(AccountAnalyticAccount, self).on_change_partner_id( |
|
||||
partner_id, |
|
||||
name) |
|
||||
partner = self.env['res.partner'].browse(partner_id) |
|
||||
if partner and partner.customer_payment_mode: |
|
||||
res['value']['payment_mode_id'] = partner.customer_payment_mode.id |
|
||||
return res |
|
||||
|
@api.onchange('partner_id') |
||||
|
def on_change_partner_id(self): |
||||
|
if self.partner_id.customer_payment_mode_id: |
||||
|
self.payment_mode_id = self.partner_id.customer_payment_mode_id.id |
||||
|
|
||||
@api.model |
@api.model |
||||
def _prepare_invoice_data(self, contract): |
def _prepare_invoice_data(self, contract): |
||||
invoice_vals = super(AccountAnalyticAccount, self).\ |
|
||||
_prepare_invoice_data(contract) |
|
||||
|
invoice_vals = super(AccountAnalyticAccount, self)._prepare_invoice() |
||||
if contract.payment_mode_id: |
if contract.payment_mode_id: |
||||
invoice_vals['payment_mode_id'] = contract.payment_mode_id.id |
invoice_vals['payment_mode_id'] = contract.payment_mode_id.id |
||||
invoice_vals['partner_bank_id'] = ( |
invoice_vals['partner_bank_id'] = ( |
||||
contract.partner_id.bank_ids[:1].id or |
|
||||
contract.payment_mode_id.bank_id.id) |
|
||||
|
|
||||
|
contract.partner_id.bank_ids[:1].id |
||||
|
) |
||||
return invoice_vals |
return invoice_vals |
@ -1,49 +0,0 @@ |
|||||
- |
|
||||
In order to test payment mode in contract, I create a contract with custom payment mode. |
|
||||
Then, I generate Invoices from contract and test this payment mode. |
|
||||
First create custom payment mode. |
|
||||
- |
|
||||
!record {model: payment.mode, id: custom_payment_mode}: |
|
||||
name: Custom Payment Mode |
|
||||
journal: account.bank_journal |
|
||||
bank_id: account_payment.partner_bank_1 |
|
||||
company_id: base.main_company |
|
||||
type: account_banking_payment_export.manual_bank_tranfer |
|
||||
- |
|
||||
I create a contract with custom payment mode |
|
||||
- |
|
||||
!record {model: account.analytic.account, id: contract_custom_payment}: |
|
||||
name: Maintenance of Servers |
|
||||
company_id: base.main_company |
|
||||
partner_id: base.main_partner |
|
||||
payment_mode_id: custom_payment_mode |
|
||||
type: contract |
|
||||
recurring_invoices : 1 |
|
||||
recurring_interval : 1 |
|
||||
recurring_invoice_line_ids: |
|
||||
- quantity: 2.0 |
|
||||
price_unit: 100.0 |
|
||||
name: Database Administration 25 |
|
||||
product_id: product.product_product_consultant |
|
||||
uom_id: product.product_uom_hour |
|
||||
- |
|
||||
I test the payment mode in contract |
|
||||
- |
|
||||
!python {model: account.analytic.account}: | |
|
||||
aid = ref('contract_payment_mode.contract_custom_payment') |
|
||||
contract = self.browse(cr, uid, aid,context=context) |
|
||||
assert contract.payment_mode_id.id == ref('contract_payment_mode.custom_payment_mode'), "Payment Mode is not correct in contract" |
|
||||
- |
|
||||
I generate all invoices from contracts having recurring invoicing |
|
||||
- |
|
||||
!python {model: account.analytic.account}: | |
|
||||
self.recurring_create_invoice(cr, uid, []) |
|
||||
- |
|
||||
I test the generated invoice for custom payment contract |
|
||||
- |
|
||||
!python {model: account.invoice}: | |
|
||||
aid = ref('contract_payment_mode.contract_custom_payment') |
|
||||
ids = self.search(cr, uid, [('invoice_line.account_analytic_id','=',aid)], context=context) |
|
||||
assert len(ids)>=1, 'No invoice created for the custom paymetn mode contract' |
|
||||
for invoice in self.browse(cr, uid, ids,context=context): |
|
||||
assert invoice.payment_mode_id.id == ref('contract_payment_mode.custom_payment_mode'), "Payment Mode is not correct in invoice" |
|
@ -1,5 +1,5 @@ |
|||||
# -*- coding: utf-8 -*- |
# -*- coding: utf-8 -*- |
||||
# © 2016 Antiun Ingenieria S.L. - Antonio Espinosa |
|
||||
|
# Copyright 2016 Antiun Ingenieria S.L. - Antonio Espinosa |
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
||||
|
|
||||
from . import test_contract_payment_init |
|
||||
|
from . import test_contract_payment |
@ -0,0 +1,83 @@ |
|||||
|
# -*- coding: utf-8 -*- |
||||
|
# Copyright 2015 Antiun Ingenieria S.L. - Antonio Espinosa |
||||
|
# Copyright 2017 Tecnativa - Vicent Cubells |
||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
||||
|
|
||||
|
from openerp.tests import common |
||||
|
from ..hooks import post_init_hook |
||||
|
|
||||
|
|
||||
|
class TestContractPaymentInit(common.SavepointCase): |
||||
|
@classmethod |
||||
|
def setUpClass(cls): |
||||
|
super(TestContractPaymentInit, cls).setUpClass() |
||||
|
|
||||
|
cls.payment_method = cls.env.ref( |
||||
|
'account.account_payment_method_manual_in') |
||||
|
cls.payment_mode = cls.env.ref( |
||||
|
'account_payment_mode.payment_mode_inbound_ct1') |
||||
|
cls.partner = cls.env['res.partner'].create({ |
||||
|
'name': 'Test contract partner', |
||||
|
'customer_payment_mode_id': cls.payment_mode, |
||||
|
}) |
||||
|
cls.product = cls.env['product.product'].create({ |
||||
|
'name': 'Custom Service', |
||||
|
'type': 'service', |
||||
|
'uom_id': cls.env.ref('product.product_uom_hour').id, |
||||
|
'uom_po_id': cls.env.ref('product.product_uom_hour').id, |
||||
|
'sale_ok': True, |
||||
|
}) |
||||
|
cls.contract = cls.env['account.analytic.account'].create({ |
||||
|
'name': 'Maintenance of Servers', |
||||
|
}) |
||||
|
|
||||
|
def _contract_payment_mode_id(self, contract_id): |
||||
|
contract = self.env['account.analytic.account'].search([ |
||||
|
('id', '=', contract_id), |
||||
|
]) |
||||
|
return contract.payment_mode_id.id |
||||
|
|
||||
|
def test_post_init_hook(self): |
||||
|
contract = self.env['account.analytic.account'].create({ |
||||
|
'name': 'Test contract', |
||||
|
'partner_id': self.partner.id, |
||||
|
'payment_mode_id': self.payment_mode.id, |
||||
|
}) |
||||
|
self.assertEqual(self._contract_payment_mode_id(contract.id), |
||||
|
self.payment_mode.id) |
||||
|
|
||||
|
contract.payment_mode_id = False |
||||
|
self.assertEqual(self._contract_payment_mode_id(contract.id), False) |
||||
|
|
||||
|
post_init_hook(self.cr, self.env) |
||||
|
self.assertEqual(self._contract_payment_mode_id(contract.id), |
||||
|
self.payment_mode.id) |
||||
|
|
||||
|
def test_contract_and_invoices(self): |
||||
|
self.contract.write({'partner_id': self.partner.id}) |
||||
|
self.contract.on_change_partner_id() |
||||
|
self.assertEqual(self.contract.payment_mode_id, |
||||
|
self.contract.partner_id.customer_payment_mode_id) |
||||
|
self.contract.write({ |
||||
|
'recurring_invoices': True, |
||||
|
'recurring_interval': 1, |
||||
|
'recurring_invoice_line_ids': [(0, 0, { |
||||
|
'quantity': 2.0, |
||||
|
'price_unit': 200.0, |
||||
|
'name': 'Database Administration 25', |
||||
|
'product_id': self.product.id, |
||||
|
'uom_id': self.product.uom_id.id, |
||||
|
})] |
||||
|
}) |
||||
|
res = self.contract._prepare_invoice_data(self.contract) |
||||
|
self.assertEqual(res.get('partner_id'), self.contract.partner_id.id) |
||||
|
self.assertEqual(res.get('payment_mode_id'), |
||||
|
self.contract.payment_mode_id.id) |
||||
|
self.contract.recurring_create_invoice() |
||||
|
new_invoice = self.env['account.invoice'].search([ |
||||
|
('contract_id', '=', self.contract.id) |
||||
|
]) |
||||
|
self.assertEqual(len(new_invoice.ids), 1) |
||||
|
self.contract.recurring_create_invoice() |
||||
|
self.assertEqual(self.contract.payment_mode_id, |
||||
|
new_invoice.payment_mode_id) |
@ -1,40 +0,0 @@ |
|||||
# -*- coding: utf-8 -*- |
|
||||
# © 2015 Antiun Ingenieria S.L. - Antonio Espinosa |
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). |
|
||||
|
|
||||
from openerp.tests.common import TransactionCase |
|
||||
from ..hooks import post_init_hook |
|
||||
|
|
||||
|
|
||||
class TestContractPaymentInit(TransactionCase): |
|
||||
# Use case : Prepare some data for current test case |
|
||||
def setUp(self): |
|
||||
super(TestContractPaymentInit, self).setUp() |
|
||||
self.payment_mode = self.env.ref('account_payment.payment_mode_1') |
|
||||
self.partner = self.env['res.partner'].create({ |
|
||||
'name': 'Test contract partner', |
|
||||
'customer_payment_mode': self.payment_mode.id, |
|
||||
}) |
|
||||
|
|
||||
def _contract_payment_mode_id(self, contract_id): |
|
||||
contract = self.env['account.analytic.account'].search([ |
|
||||
('id', '=', contract_id), |
|
||||
]) |
|
||||
return contract.payment_mode_id.id |
|
||||
|
|
||||
def test_post_init_hook(self): |
|
||||
contract = self.env['account.analytic.account'].create({ |
|
||||
'name': 'Test contract', |
|
||||
'type': 'contract', |
|
||||
'partner_id': self.partner.id, |
|
||||
'payment_mode_id': self.payment_mode.id, |
|
||||
}) |
|
||||
self.assertEqual(self._contract_payment_mode_id(contract.id), |
|
||||
self.payment_mode.id) |
|
||||
|
|
||||
contract.payment_mode_id = False |
|
||||
self.assertEqual(self._contract_payment_mode_id(contract.id), False) |
|
||||
|
|
||||
post_init_hook(self.cr, self.env) |
|
||||
self.assertEqual(self._contract_payment_mode_id(contract.id), |
|
||||
self.payment_mode.id) |
|
@ -1,42 +1,39 @@ |
|||||
<?xml version="1.0"?> |
<?xml version="1.0"?> |
||||
<openerp> |
|
||||
<data> |
|
||||
|
<odoo> |
||||
|
|
||||
<record id="account_analytic_account_payment_form" model="ir.ui.view"> |
|
||||
<field name="name">account.analytic.account.payment.form</field> |
|
||||
<field name="model">account.analytic.account</field> |
|
||||
<field name="inherit_id" ref="analytic.view_account_analytic_account_form" /> |
|
||||
<field name="arch" type="xml"> |
|
||||
<xpath expr="//field[@name='template_id']" position="before"> |
|
||||
<field name="payment_mode_id" /> |
|
||||
</xpath> |
|
||||
</field> |
|
||||
</record> |
|
||||
|
<record id="account_analytic_account_payment_form" model="ir.ui.view"> |
||||
|
<field name="name">account.analytic.account.payment.form</field> |
||||
|
<field name="model">account.analytic.account</field> |
||||
|
<field name="inherit_id" ref="analytic.view_account_analytic_account_form" /> |
||||
|
<field name="arch" type="xml"> |
||||
|
<xpath expr="//field[@name='partner_id']" position="after"> |
||||
|
<field name="payment_mode_id" /> |
||||
|
</xpath> |
||||
|
</field> |
||||
|
</record> |
||||
|
|
||||
<!-- Inherited Analytic Account list for contracts --> |
|
||||
<record id="view_account_analytic_account_payment_tree" model="ir.ui.view"> |
|
||||
<field name="name">account.analytic.account.payment.list</field> |
|
||||
<field name="model">account.analytic.account</field> |
|
||||
<field name="inherit_id" ref="account.view_account_analytic_account_list" /> |
|
||||
<field name="arch" type="xml"> |
|
||||
<field name="partner_id" position="after"> |
|
||||
<field name="payment_mode_id" /> |
|
||||
</field> |
|
||||
|
<!-- Inherited Analytic Account list for contracts --> |
||||
|
<record id="view_account_analytic_account_payment_tree" model="ir.ui.view"> |
||||
|
<field name="name">account.analytic.account.payment.list</field> |
||||
|
<field name="model">account.analytic.account</field> |
||||
|
<field name="inherit_id" ref="analytic.view_account_analytic_account_list" /> |
||||
|
<field name="arch" type="xml"> |
||||
|
<field name="partner_id" position="after"> |
||||
|
<field name="payment_mode_id" /> |
||||
</field> |
</field> |
||||
</record> |
|
||||
|
</field> |
||||
|
</record> |
||||
|
|
||||
<!-- Analytic Account search view for contract --> |
|
||||
<record id="view_account_analytic_account_payment_search" model="ir.ui.view"> |
|
||||
<field name="name">account.analytic.account.payment.search</field> |
|
||||
<field name="model">account.analytic.account</field> |
|
||||
<field name="inherit_id" |
|
||||
ref="account_analytic_analysis.view_account_analytic_account_overdue_search" /> |
|
||||
<field name="arch" type="xml"> |
|
||||
<field name="name" position="after"> |
|
||||
<field name="payment_mode_id" /> |
|
||||
</field> |
|
||||
|
<!-- Analytic Account search view for contract --> |
||||
|
<record id="view_account_analytic_account_search" model="ir.ui.view"> |
||||
|
<field name="name">account.analytic.account.search</field> |
||||
|
<field name="model">account.analytic.account</field> |
||||
|
<field name="inherit_id" ref="analytic.view_account_analytic_account_search" /> |
||||
|
<field name="arch" type="xml"> |
||||
|
<field name="name" position="after"> |
||||
|
<field name="payment_mode_id" /> |
||||
</field> |
</field> |
||||
</record> |
|
||||
|
</field> |
||||
|
</record> |
||||
|
|
||||
</data> |
|
||||
</openerp> |
|
||||
|
</odoo> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue