Skip to content

Commit f1518e8

Browse files
committed
[FIX] sale_project : create on order when type updated to service
Steps : Install Sales, Project and Inventory. Create a Storable Product. Create a SO with this product, but do not confirm it. Change this product : > Type : Service > Sales > Service Tracking : Create a task in SO's project Confirm the SO. Issue : Neither a delivery or a task is created. Cause : Confirming the SO calls SO._timesheet_service_generation(), which filtered its SOLs based on is_service to 'create on order'. As this field is not updated when changing the type of the product, the SOL with the service is filtered out. Fix : Update SOL_.is_service when changing SOL.product_id.type. opw-2786655 closes odoo#87112 X-original-commit: 33bfe96 Signed-off-by: Laurent Stukkens (ltu) <ltu@odoo.com>
1 parent 57a92e6 commit f1518e8

File tree

2 files changed

+23
-2
lines changed

2 files changed

+23
-2
lines changed

addons/sale_project/models/sale_order.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -127,12 +127,12 @@ class SaleOrderLine(models.Model):
127127
index=True, copy=False, help="Task generated by the sales order item")
128128
is_service = fields.Boolean("Is a Service", compute='_compute_is_service', store=True, compute_sudo=True, help="Sales Order item should generate a task and/or a project, depending on the product settings.")
129129

130-
@api.depends('product_id')
130+
@api.depends('product_id.type')
131131
def _compute_is_service(self):
132132
for so_line in self:
133133
so_line.is_service = so_line.product_id.type == 'service'
134134

135-
@api.depends('product_id')
135+
@api.depends('product_id.type')
136136
def _compute_product_updatable(self):
137137
for line in self:
138138
if line.product_id.type == 'service' and line.state == 'sale':

addons/sale_project/tests/test_sale_project.py

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -163,3 +163,24 @@ def test_sale_order_with_project_task(self):
163163
self.assertEqual(task.sale_line_id, sale_line_1_order_2)
164164
self.assertIn(task.sale_line_id, self.project_global._get_sale_order_items())
165165
self.assertEqual(self.project_global._get_sale_orders(), sale_order | sale_order_2)
166+
167+
def test_sol_product_type_update(self):
168+
partner = self.env['res.partner'].create({'name': "Mur en brique"})
169+
sale_order = self.env['sale.order'].with_context(tracking_disable=True).create({
170+
'partner_id': partner.id,
171+
'partner_invoice_id': partner.id,
172+
'partner_shipping_id': partner.id,
173+
})
174+
self.product_order_service3.type = 'consu'
175+
sale_order_line = self.env['sale.order.line'].create({
176+
'order_id': sale_order.id,
177+
'name': self.product_order_service3.name,
178+
'product_id': self.product_order_service3.id,
179+
'product_uom_qty': 5,
180+
'product_uom': self.product_order_service3.uom_id.id,
181+
'price_unit': self.product_order_service3.list_price
182+
})
183+
self.assertFalse(sale_order_line.is_service, "As the product is consumable, the SOL should not be a service")
184+
185+
self.product_order_service3.type = 'service'
186+
self.assertTrue(sale_order_line.is_service, "As the product is a service, the SOL should be a service")

0 commit comments

Comments
 (0)