Browse Source

[12.0][FIX] - contract company must be the same as the sale order

When creating a contract from a sale order the company must be the sale order
company and not the user company
pull/405/head
sbejaoui 5 years ago
committed by Stéphane Bidoul (ACSONE)
parent
commit
e1a399e14b
No known key found for this signature in database GPG Key ID: BCAB2555446B5B92
  1. 2
      contract/models/abstract_contract.py
  2. 1
      product_contract/models/sale_order.py
  3. 13
      product_contract/tests/test_sale_order.py

2
contract/models/abstract_contract.py

@ -14,7 +14,7 @@ class ContractAbstractContract(models.AbstractModel):
_description = 'Abstract Recurring Contract'
# These fields will not be synced to the contract
NO_SYNC = ['name', 'partner_id']
NO_SYNC = ['name', 'partner_id', 'company_id']
name = fields.Char(required=True)
# Needed for avoiding errors on several inherited behaviors

1
product_contract/models/sale_order.py

@ -46,6 +46,7 @@ class SaleOrder(models.Model):
template_name=contract_template.name, sale_name=self.name
),
'partner_id': self.partner_id.id,
'company_id': self.company_id.id,
'contract_template_id': contract_template.id,
'user_id': self.user_id.id,
'payment_term_id': self.payment_term_id.id,

13
product_contract/tests/test_sale_order.py

@ -110,6 +110,19 @@ class TestSaleOrder(TransactionCase):
contract_line.recurring_next_date, Date.to_date('2018-01-31')
)
def test_contract_company(self):
"""
contract company must be the sale order company and not the user one
"""
self.assertTrue(self.sale.company_id)
other_company = self.env['res.company'].create(
{'name': 'other company', 'parent_id': self.sale.company_id.id}
)
self.sale.company_id = other_company
self.sale.action_confirm()
contracts = self.sale.order_line.mapped('contract_id')
self.assertEqual(contracts.mapped('company_id'), other_company)
def test_sale_order_invoice_status(self):
"""
sale line linked to contracts must not be invoiced from sale order

Loading…
Cancel
Save