IMP sale_line_change with tests and Dropshipping check

If a changed line relates to a purchase order that is not cancelled, raises an exception with the name(s) of the purchase orders.
This commit is contained in:
Unknown
2018-09-21 10:44:37 -07:00
committed by Leighton Pennicott
parent 32864d7854
commit 8f0d07ca4b
4 changed files with 111 additions and 0 deletions

View File

@@ -13,6 +13,7 @@
'depends': [ 'depends': [
'sale_sourced_by_line', 'sale_sourced_by_line',
'sale_stock', 'sale_stock',
'stock_dropshipping',
], ],
'demo': [], 'demo': [],
'data': [ 'data': [

View File

@@ -0,0 +1 @@
from . import test_sale_line_change

View File

@@ -0,0 +1,99 @@
from odoo.tests import common
from odoo.exceptions import ValidationError
class TestSaleLineChange(common.TransactionCase):
def setUp(self):
super(TestSaleLineChange, self).setUp()
self.warehouse0 = self.env.ref('stock.warehouse0')
self.warehouse1 = self.env['stock.warehouse'].create({
'company_id': self.env.user.company_id.id,
# 'partner_id': self.env.user.company_id.partner_id.id,
'name': 'TWH1',
'code': 'TWH1',
})
self.product1 = self.env.ref('product.product_product_24')
self.partner1 = self.env.ref('base.res_partner_12')
self.so1 = self.env['sale.order'].create({
'partner_id': self.partner1.id,
'partner_invoice_id': self.partner1.id,
'partner_shipping_id': self.partner1.id,
'order_line': [(0, 0, {
'product_id': self.product1.id,
'name': 'N/A',
'product_uom_qty': 1.0,
'price_unit': 100.0,
})]
})
self.dropship_route = self.env.ref('stock_dropshipping.route_drop_shipping')
self.warehouse0_route = self.warehouse0.route_ids.filtered(lambda r: r.name.find('Ship') >= 0)
def test_00_sale_change_warehouse(self):
so = self.so1
so.action_confirm()
self.assertTrue(so.state in ('sale', 'done'))
self.assertTrue(so.picking_ids)
org_picking = so.picking_ids
self.assertEqual(org_picking.picking_type_id.warehouse_id, self.warehouse0)
wiz = self.env['sale.line.change.order'].with_context(default_order_id=so.id).create({})
self.assertTrue(wiz.line_ids)
wiz.line_ids.line_warehouse_id = self.warehouse1
wiz.line_ids.line_date_planned = '2018-01-01 00:00:00'
wiz.apply()
self.assertTrue(len(so.picking_ids) == 2)
self.assertTrue(org_picking.state == 'cancel')
new_picking = so.picking_ids - org_picking
self.assertTrue(new_picking)
self.assertEqual(new_picking.picking_type_id.warehouse_id, self.warehouse1)
self.assertEqual(new_picking.scheduled_date, '2018-01-01 00:00:00')
def test_01_sale_change_route(self):
so = self.so1
so.action_confirm()
self.assertTrue(so.state in ('sale', 'done'))
self.assertTrue(so.picking_ids)
org_picking = so.picking_ids
self.assertEqual(org_picking.picking_type_id.warehouse_id, self.warehouse0)
# Change route on wizard line
wiz = self.env['sale.line.change.order'].with_context(default_order_id=so.id).create({})
self.assertTrue(wiz.line_ids)
wiz.line_ids.line_route_id = self.dropship_route
wiz.apply()
# Check that RFQ/PO was created.
self.assertTrue(org_picking.state == 'cancel')
po_line = self.env['purchase.order.line'].search([('sale_line_id', '=', so.order_line.id)])
self.assertTrue(po_line)
def test_02_sale_dropshipping_to_warehouse(self):
self.assertTrue(self.warehouse0_route)
self.product1.route_ids += self.dropship_route
so = self.so1
so.action_confirm()
self.assertTrue(so.state in ('sale', 'done'))
self.assertFalse(so.picking_ids)
# Change route on wizard line
wiz = self.env['sale.line.change.order'].with_context(default_order_id=so.id).create({})
self.assertTrue(wiz.line_ids)
wiz.line_ids.line_route_id = self.warehouse0_route
wiz.line_ids.line_date_planned = '2018-01-01 00:00:00'
# Wizard cannot complete because of non-cancelled Purchase Order.
with self.assertRaises(ValidationError):
wiz.apply()
po_line = self.env['purchase.order.line'].search([('sale_line_id', '=', so.order_line.id)])
po_line.order_id.button_cancel()
wiz.apply()
# Check parameters on new picking
self.assertTrue(so.picking_ids)
self.assertEqual(so.picking_ids.picking_type_id.warehouse_id, self.warehouse0)
self.assertEqual(so.picking_ids.scheduled_date, '2018-01-01 00:00:00')

View File

@@ -1,4 +1,5 @@
from odoo import api, fields, models from odoo import api, fields, models
from odoo.exceptions import ValidationError
class SaleLineChangeOrder(models.TransientModel): class SaleLineChangeOrder(models.TransientModel):
@@ -53,10 +54,19 @@ class SaleLineChangeOrderLine(models.TransientModel):
} }
def _apply(self): def _apply(self):
self._apply_clean_dropship()
self._apply_clean_existing_moves() self._apply_clean_existing_moves()
self._apply_new_values() self._apply_new_values()
self._apply_procurement() self._apply_procurement()
def _apply_clean_dropship(self):
po_line_model = self.env['purchase.order.line'].sudo()
po_lines = po_line_model.search([('sale_line_id', 'in', self.mapped('sale_line_id.id'))])
if po_lines and po_lines.filtered(lambda l: l.order_id.state != 'cancel'):
names = ', '.join(po_lines.filtered(lambda l: l.order_id.state != 'cancel').mapped('order_id.name'))
raise ValidationError('One or more lines has existing non-cancelled Purchase Orders associated: ' + names)
def _apply_clean_existing_moves(self): def _apply_clean_existing_moves(self):
moves = self.mapped('sale_line_id.move_ids').filtered(lambda m: m.state != 'done') moves = self.mapped('sale_line_id.move_ids').filtered(lambda m: m.state != 'done')
moves._action_cancel() moves._action_cancel()