You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

87 lines
3.9 KiB

# -*- coding: utf-8 -*-
# Copyright 2016 Carlos Dauden <carlos.dauden@tecnativa.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from openerp.tests.common import TransactionCase
from openerp import fields
from dateutil.relativedelta import relativedelta
from datetime import datetime
class TestPartnerFinancialRisk(TransactionCase):
def setUp(self):
super(TestPartnerFinancialRisk, self).setUp()
self.env.user.groups_id |= self.env.ref('base.group_sale_manager')
self.partner = self.env['res.partner'].create({
'name': 'Partner test',
'customer': True,
})
self.journal = self.env['account.journal'].create({
'type': 'sale',
'name': 'Test Sales',
'code': 'TSALE',
})
self.prod_account = self.env.ref('account.a_sale')
self.inv_account = self.env.ref('account.a_recv')
date_inv = datetime.now() - relativedelta(days=7)
date_due = datetime.now() - relativedelta(days=3)
self.invoice = self.env['account.invoice'].create({
'journal_id': self.journal.id,
'company_id': self.env.user.company_id.id,
'currency_id': self.env.user.company_id.currency_id.id,
'date_invoice': date_inv.strftime("%Y-%m-%d"),
'date_due': date_due.strftime("%Y-%m-%d"),
'partner_id': self.partner.id,
'account_id': self.inv_account.id,
'invoice_line': [(0, 0, {
'account_id': self.prod_account.id,
'name': 'Test line',
'price_unit': 50,
'quantity': 10,
})]
})
def test_invoices(self):
self.partner.risk_invoice_draft_include = True
self.assertAlmostEqual(self.partner.risk_invoice_draft, 500.0)
self.assertAlmostEqual(self.partner.risk_total, 500.0)
self.invoice.signal_workflow('invoice_open')
self.assertAlmostEqual(self.partner.risk_invoice_draft, 0.0)
self.partner.risk_invoice_unpaid_include = True
self.assertAlmostEqual(self.partner.risk_invoice_unpaid, 500.0)
self.assertAlmostEqual(self.partner.risk_total, 500.0)
self.partner.credit_limit = 100.0
self.assertTrue(self.partner.risk_exception)
self.partner.credit_limit = 1000.0
self.assertFalse(self.partner.risk_exception)
self.partner.risk_invoice_unpaid_limit = 499.0
self.assertTrue(self.partner.risk_exception)
invoice2 = self.invoice.copy()
wiz_dic = invoice2.invoice_open()
wiz = self.env[wiz_dic['res_model']].browse(wiz_dic['res_id'])
self.assertEqual(wiz.exception_msg, "Financial risk exceeded.\n")
self.partner.risk_invoice_unpaid_limit = 0.0
self.assertFalse(self.partner.risk_exception)
self.partner.risk_invoice_open_limit = 300.0
invoice2.date_due = fields.Date.today()
wiz_dic = invoice2.invoice_open()
wiz = self.env[wiz_dic['res_model']].browse(wiz_dic['res_id'])
self.assertEqual(wiz.exception_msg,
"This invoice exceeds the open invoices risk.\n")
self.partner.risk_invoice_open_limit = 0.0
self.partner.risk_invoice_draft_include = False
self.partner.risk_invoice_open_include = True
self.partner.credit_limit = 900.0
wiz_dic = invoice2.invoice_open()
wiz = self.env[wiz_dic['res_model']].browse(wiz_dic['res_id'])
self.assertEqual(wiz.exception_msg,
"This invoice exceeds the financial risk.\n")
self.assertAlmostEqual(self.partner.risk_invoice_open, 0.0)
wiz.button_continue()
self.assertAlmostEqual(self.partner.risk_invoice_open, 500.0)
self.assertTrue(self.partner.risk_allow_edit)
self.partner.process_unpaid_invoices()
self.assertEqual(self.env['ir.config_parameter'].get_param(
'partner_financial_risk.last_check'),
fields.Date.today())