152 lines
10 KiB
Python
152 lines
10 KiB
Python
|
|
|
|
import datetime
|
|
|
|
from openerp import tools
|
|
from openerp.tests.common import TransactionCase
|
|
|
|
class TestAccountFollowup(TransactionCase):
|
|
def setUp(self):
|
|
""" setUp ***"""
|
|
super(TestAccountFollowup, self).setUp()
|
|
cr, uid = self.cr, self.uid
|
|
|
|
self.user = self.registry('res.users')
|
|
self.user_id = self.user.browse(cr, uid, uid)
|
|
self.partner = self.registry('res.partner')
|
|
self.invoice = self.registry('account.invoice')
|
|
self.invoice_line = self.registry('account.invoice.line')
|
|
self.wizard = self.registry('account_followup.print')
|
|
self.followup_id = self.registry('account_followup.followup')
|
|
|
|
self.partner_id = self.partner.create(cr, uid, {'name':'Test Company',
|
|
'email':'test@localhost',
|
|
'is_company': True,
|
|
},
|
|
context=None)
|
|
self.followup_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account_followup", "demo_followup1")[1]
|
|
self.account_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account", "a_recv")[1]
|
|
self.journal_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account", "bank_journal")[1]
|
|
self.pay_account_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account", "cash")[1]
|
|
self.period_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account", "period_10")[1]
|
|
|
|
self.first_followup_line_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account_followup", "demo_followup_line1")[1]
|
|
self.last_followup_line_id = self.registry("ir.model.data").get_object_reference(cr, uid, "account_followup", "demo_followup_line3")[1]
|
|
self.product_id = self.registry("ir.model.data").get_object_reference(cr, uid, "product", "product_product_6")[1]
|
|
self.invoice_id = self.invoice.create(cr, uid, {'partner_id': self.partner_id,
|
|
'account_id': self.account_id,
|
|
'journal_id': self.journal_id,
|
|
'invoice_line': [(0, 0, {
|
|
'name': "LCD Screen",
|
|
'product_id': self.product_id,
|
|
'quantity': 5,
|
|
'price_unit':200
|
|
})]})
|
|
self.registry('account.invoice').signal_workflow(cr, uid, [self.invoice_id], 'invoice_open')
|
|
|
|
self.voucher = self.registry("account.voucher")
|
|
|
|
|
|
def test_00_send_followup_after_3_days(self):
|
|
""" Send follow up after 3 days and check nothing is done (as first follow-up level is only after 15 days)"""
|
|
cr, uid = self.cr, self.uid
|
|
current_date = datetime.datetime.utcnow()
|
|
delta = datetime.timedelta(days=3)
|
|
result = current_date + delta
|
|
self.wizard_id = self.wizard.create(cr, uid, {'date':result.strftime(tools.DEFAULT_SERVER_DATE_FORMAT),
|
|
'followup_id': self.followup_id
|
|
}, context={"followup_id": self.followup_id})
|
|
self.wizard.do_process(cr, uid, [self.wizard_id], context={"followup_id": self.followup_id})
|
|
self.assertFalse(self.partner.browse(cr, uid, self.partner_id).latest_followup_level_id)
|
|
|
|
def run_wizard_three_times(self):
|
|
cr, uid = self.cr, self.uid
|
|
current_date = datetime.datetime.utcnow()
|
|
delta = datetime.timedelta(days=40)
|
|
result = current_date + delta
|
|
self.wizard_id = self.wizard.create(cr, uid, {'date':result.strftime(tools.DEFAULT_SERVER_DATE_FORMAT),
|
|
'followup_id': self.followup_id
|
|
}, context={"followup_id": self.followup_id})
|
|
self.wizard.do_process(cr, uid, [self.wizard_id], context={"followup_id": self.followup_id, 'tz':'UTC'})
|
|
self.wizard_id = self.wizard.create(cr, uid, {'date':result.strftime(tools.DEFAULT_SERVER_DATE_FORMAT),
|
|
'followup_id': self.followup_id
|
|
}, context={"followup_id": self.followup_id})
|
|
self.wizard.do_process(cr, uid, [self.wizard_id], context={"followup_id": self.followup_id, 'tz':'UTC'})
|
|
self.wizard_id = self.wizard.create(cr, uid, {'date':result.strftime(tools.DEFAULT_SERVER_DATE_FORMAT),
|
|
'followup_id': self.followup_id,
|
|
}, context={"followup_id": self.followup_id})
|
|
self.wizard.do_process(cr, uid, [self.wizard_id], context={"followup_id": self.followup_id, 'tz':'UTC'})
|
|
|
|
def test_01_send_followup_later_for_upgrade(self):
|
|
""" Send one follow-up after 15 days to check it upgrades to level 1"""
|
|
cr, uid = self.cr, self.uid
|
|
current_date = datetime.datetime.utcnow()
|
|
delta = datetime.timedelta(days=15)
|
|
result = current_date + delta
|
|
self.wizard_id = self.wizard.create(cr, uid, {
|
|
'date':result.strftime(tools.DEFAULT_SERVER_DATE_FORMAT),
|
|
'followup_id': self.followup_id
|
|
}, context={"followup_id": self.followup_id})
|
|
self.wizard.do_process(cr, uid, [self.wizard_id], context={"followup_id": self.followup_id, 'tz':'UTC'})
|
|
self.assertEqual(self.partner.browse(cr, uid, self.partner_id).latest_followup_level_id.id, self.first_followup_line_id,
|
|
"Not updated to the correct follow-up level")
|
|
|
|
def test_02_check_manual_action(self):
|
|
""" Check that when running the wizard three times that the manual action is set"""
|
|
cr, uid = self.cr, self.uid
|
|
self.run_wizard_three_times()
|
|
self.assertEqual(self.partner.browse(cr, uid, self.partner_id).payment_next_action,
|
|
"Call the customer on the phone! ", "Manual action not set")
|
|
self.assertEqual(self.partner.browse(cr, uid, self.partner_id).payment_next_action_date,
|
|
datetime.datetime.utcnow().strftime(tools.DEFAULT_SERVER_DATE_FORMAT))
|
|
|
|
def test_03_filter_on_credit(self):
|
|
""" Check the partners can be filtered on having credits """
|
|
cr, uid = self.cr, self.uid
|
|
ids = self.partner.search(cr, uid, [('payment_amount_due', '>', 0.0)])
|
|
self.assertIn(self.partner_id, ids)
|
|
|
|
def test_04_action_done(self):
|
|
""" Run the wizard 3 times, mark it as done, check the action fields are empty"""
|
|
cr, uid = self.cr, self.uid
|
|
partner_rec = self.partner.browse(cr, uid, self.partner_id)
|
|
self.run_wizard_three_times()
|
|
self.partner.action_done(cr, uid, self.partner_id)
|
|
self.assertFalse(partner_rec.payment_next_action, "Manual action not emptied")
|
|
self.assertFalse(partner_rec.payment_responsible_id)
|
|
self.assertFalse(partner_rec.payment_next_action_date)
|
|
|
|
def test_05_litigation(self):
|
|
""" Set the account move line as litigation, run the wizard 3 times and check nothing happened.
|
|
Turn litigation off. Run the wizard 3 times and check it is in the right follow-up level.
|
|
"""
|
|
cr, uid = self.cr, self.uid
|
|
aml_id = self.partner.browse(cr, uid, self.partner_id).unreconciled_aml_ids[0].id
|
|
self.registry('account.move.line').write(cr, uid, aml_id, {'blocked': True})
|
|
self.run_wizard_three_times()
|
|
self.assertFalse(self.partner.browse(cr, uid, self.partner_id).latest_followup_level_id, "Litigation does not work")
|
|
self.registry('account.move.line').write(cr, uid, aml_id, {'blocked': False})
|
|
self.run_wizard_three_times()
|
|
self.assertEqual(self.partner.browse(cr, uid, self.partner_id).latest_followup_level_id.id,
|
|
self.last_followup_line_id, "Lines are not equal")
|
|
|
|
def test_06_pay_the_invoice(self):
|
|
"""Run wizard until manual action, pay the invoice and check that partner has no follow-up level anymore and after running the wizard the action is empty"""
|
|
cr, uid = self.cr, self.uid
|
|
self.test_02_check_manual_action()
|
|
current_date = datetime.datetime.utcnow()
|
|
delta = datetime.timedelta(days=1)
|
|
result = current_date + delta
|
|
self.invoice.pay_and_reconcile(cr, uid, [self.invoice_id], 1000.0, self.pay_account_id,
|
|
self.period_id, self.journal_id, self.pay_account_id,
|
|
self.period_id, self.journal_id,
|
|
name = "Payment for test customer invoice follow-up")
|
|
self.assertFalse(self.partner.browse(cr, uid, self.partner_id).latest_followup_level_id, "Level not empty")
|
|
self.wizard_id = self.wizard.create(cr, uid, {'date':result.strftime(tools.DEFAULT_SERVER_DATE_FORMAT),
|
|
'followup_id': self.followup_id
|
|
}, context={"followup_id": self.followup_id})
|
|
self.wizard.do_process(cr, uid, [self.wizard_id], context={"followup_id": self.followup_id})
|
|
self.assertEqual(0, self.partner.browse(cr, uid, self.partner_id).payment_amount_due, "Amount Due != 0")
|
|
self.assertFalse(self.partner.browse(cr, uid, self.partner_id).payment_next_action_date, "Next action date not cleared")
|
|
|