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.

86 lines
3.6 KiB

  1. # Copyright 2016 Tecnativa - Carlos Dauden
  2. # Copyright 2017 Tecnativa - Pedro M. Baeza
  3. # Copyright 2018 Road-Support - Roel Adriaans
  4. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
  5. from odoo.tests import common
  6. class TestContractBase(common.SavepointCase):
  7. @classmethod
  8. def setUpClass(cls):
  9. super(TestContractBase, cls).setUpClass()
  10. cls.partner = cls.env.ref('base.res_partner_2')
  11. cls.product = cls.env.ref('product.product_product_2')
  12. cls.product.taxes_id += cls.env['account.tax'].search(
  13. [('type_tax_use', '=', 'sale')], limit=1)
  14. cls.product.description_sale = 'Test description sale'
  15. cls.template_vals = {
  16. 'recurring_rule_type': 'yearly',
  17. 'recurring_interval': 12345,
  18. 'name': 'Test Contract Template',
  19. }
  20. cls.template = cls.env['account.analytic.contract'].create(
  21. cls.template_vals,
  22. )
  23. cls.contract = cls.env['account.analytic.account'].create({
  24. 'name': 'Test Contract',
  25. 'partner_id': cls.partner.id,
  26. 'pricelist_id': cls.partner.property_product_pricelist.id,
  27. 'recurring_invoices': True,
  28. 'date_start': '2016-02-15',
  29. 'recurring_next_date': '2016-02-29',
  30. })
  31. cls.line_vals = {
  32. 'analytic_account_id': cls.contract.id,
  33. 'product_id': cls.product.id,
  34. 'name': 'Services from #START# to #END#',
  35. 'quantity': 1,
  36. 'uom_id': cls.product.uom_id.id,
  37. 'price_unit': 100,
  38. 'discount': 50,
  39. }
  40. cls.acct_line = cls.env['account.analytic.invoice.line'].create(
  41. cls.line_vals,
  42. )
  43. class TestContract(TestContractBase):
  44. def test_contract_default_name(self):
  45. """ Create invoice, based on default values.
  46. Should have a valid name"""
  47. self.contract.cron_recurring_create_invoice()
  48. invoice_id = self.env['account.invoice'].search(
  49. [('contract_id', '=', self.contract.id)])
  50. self.assertEqual(invoice_id.invoice_line_ids.name,
  51. 'Services from 02/29/2016 to 03/28/2016')
  52. def test_contract_computed_name(self):
  53. """ Create invoice, based on computed values.
  54. Should have these computed values in invoice line."""
  55. self.acct_line.unlink()
  56. self.line_vals['name'] = "Services from #START(dd/MM/yyyy)# " \
  57. "to #END(d MMMM yy)#"
  58. self.acct_line = self.env['account.analytic.invoice.line'].create(
  59. self.line_vals,
  60. )
  61. self.contract.cron_recurring_create_invoice()
  62. invoice_id = self.env['account.invoice'].search(
  63. [('contract_id', '=', self.contract.id)])
  64. self.assertEqual(invoice_id.invoice_line_ids.name,
  65. 'Services from 29/02/2016 to 28 March 16')
  66. def test_contract_computed_broken_name(self):
  67. """ Broken date format. Should not give an error, but empty
  68. test in the invoice line."""
  69. self.acct_line.unlink()
  70. self.line_vals['name'] = "Services from #START(Invalid)# " \
  71. "to #END(EEEE dd MMMM yyy)#"
  72. self.acct_line = self.env['account.analytic.invoice.line'].create(
  73. self.line_vals,
  74. )
  75. self.contract.cron_recurring_create_invoice()
  76. invoice_id = self.env['account.invoice'].search(
  77. [('contract_id', '=', self.contract.id)])
  78. self.assertEqual(invoice_id.invoice_line_ids.name,
  79. 'Services from to Monday 28 March 2016')