mirror of
https://github.com/OCA/stock-logistics-warehouse.git
synced 2025-01-21 14:27:28 +02:00
When a sale order is confirmed and product packaging is filled in sale order line(s), the information is propagated through procurement orders and stock moves. This is conditioned by a parameter on procurement rule.
138 lines
5.9 KiB
Python
138 lines
5.9 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Copyright 2015-2017 ACSONE SA/NV (<http://acsone.eu>)
|
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
|
import odoo.tests.common as common
|
|
|
|
|
|
class TestPurchaseOrderLine(common.TransactionCase):
|
|
|
|
def setUp(self):
|
|
""" Create a packagings with uom product_uom_dozen on
|
|
product_supplierinfo_1'product (uom is product_uom_unit)
|
|
"""
|
|
super(TestPurchaseOrderLine, self).setUp()
|
|
self.product_supplier_info = self.env.ref(
|
|
'product.product_supplierinfo_1')
|
|
self.product_tmpl_id = self.product_supplier_info.product_tmpl_id
|
|
self.product_supplier_info.product_tmpl_id.uom_po_id = self.env.ref(
|
|
'product.product_uom_unit')
|
|
self.product_supplier_info.min_qty = 1
|
|
self.product_packaging_dozen = self.env['product.packaging'].create(
|
|
{'product_tmpl_id': self.product_tmpl_id.id,
|
|
'uom_id': self.env.ref('product.product_uom_dozen').id,
|
|
'name': 'Packaging Dozen'}
|
|
)
|
|
self.product_packaging_unit = self.env['product.packaging'].create(
|
|
{'product_tmpl_id': self.product_tmpl_id.id,
|
|
'uom_id': self.env.ref('product.product_uom_unit').id,
|
|
'name': 'Packaging Unit'}
|
|
)
|
|
self.product_uom_8 = self.env['product.uom'].create(
|
|
{'category_id': self.env.ref('product.product_uom_categ_unit').id,
|
|
'name': 'COL8',
|
|
'factor_inv': 8,
|
|
'uom_type': 'bigger',
|
|
'rounding': 1.0,
|
|
})
|
|
|
|
def test_po_line(self):
|
|
""" On supplierinfo set product_uom_8 as min_qty_uom_id
|
|
On supplierinfo set 2 as min_qty
|
|
Create purchase order line with product product_product_3
|
|
Check packaging_id is product_packaging_dozen
|
|
Check product_purchase_uom_id is product_uom_8
|
|
Check product_purchase_qty is 2
|
|
Check product_qty is 8*2 = 16
|
|
Check price_unit is 12*38 = 456
|
|
Check product_uom is product_uom_dozen
|
|
Confirm po
|
|
Check stock move packaging is product_packaging_dozen
|
|
Check stock move product_uom is product_uom_dozen
|
|
Check stock move product_qty is 16
|
|
"""
|
|
self.product_supplier_info.min_qty_uom_id = self.product_uom_8
|
|
self.product_supplier_info.min_qty = 2
|
|
self.product_supplier_info.packaging_id = self.product_packaging_dozen
|
|
|
|
po = self.env['purchase.order'].create(
|
|
{'partner_id': self.product_supplier_info.name.id})
|
|
po_line = po.order_line.new({
|
|
'product_id': self.product_tmpl_id.product_variant_id,
|
|
'product_purchase_qty': 1.0,
|
|
'product_purchase_uom_id':
|
|
po.order_line._default_product_purchase_uom_id(),
|
|
'order_id': po
|
|
})
|
|
po_line.onchange_product_id()
|
|
self.assertEqual(po_line.packaging_id.id,
|
|
self.product_packaging_dozen.id)
|
|
self.assertEqual(po_line.product_purchase_uom_id.id,
|
|
self.product_uom_8.id)
|
|
self.assertAlmostEqual(po_line.product_purchase_qty, 2)
|
|
self.assertAlmostEqual(po_line.product_qty, 16)
|
|
self.assertTrue(po_line.price_unit)
|
|
self.assertEqual(po_line.product_uom.id,
|
|
self.env.ref('product.product_uom_dozen').id)
|
|
values = po_line._convert_to_write(
|
|
{name: po_line[name] for name in po_line._cache})
|
|
po.order_line.create(values)
|
|
# check that all the packaging informations are on the created picking
|
|
po._create_picking()
|
|
sm = po.picking_ids[0].move_lines[0]
|
|
self.assertEqual(sm.product_packaging.id,
|
|
self.product_packaging_dozen.id)
|
|
self.assertEqual(sm.product_uom.id,
|
|
self.env.ref('product.product_uom_dozen').id)
|
|
self.assertAlmostEqual(sm.product_uom_qty, 16)
|
|
|
|
def test_po_line_no_product(self):
|
|
self.product_supplier_info.min_qty_uom_id = self.product_uom_8
|
|
self.product_supplier_info.min_qty = 2
|
|
self.product_supplier_info.packaging_id = self.product_packaging_dozen
|
|
|
|
po = self.env['purchase.order'].create(
|
|
{'partner_id': self.product_supplier_info.name.id})
|
|
po_line = po.order_line.new({
|
|
'product_id': self.product_tmpl_id.product_variant_id,
|
|
'product_purchase_qty': 1.0,
|
|
'product_purchase_uom_id':
|
|
po.order_line._default_product_purchase_uom_id(),
|
|
'order_id': po
|
|
})
|
|
po_line.onchange_product_id()
|
|
po_line.product_id = None
|
|
po_line.product_qty = 2.0
|
|
self.assertEqual(
|
|
2.0,
|
|
po_line.product_purchase_qty,
|
|
'The purchase quantity is not well set'
|
|
)
|
|
|
|
def test_po_line_change_packaging(self):
|
|
self.product_supplier_info.min_qty_uom_id = self.product_uom_8
|
|
self.product_supplier_info.min_qty = 2
|
|
self.product_supplier_info.packaging_id = self.product_packaging_dozen
|
|
|
|
po = self.env['purchase.order'].create(
|
|
{'partner_id': self.product_supplier_info.name.id})
|
|
po_line = po.order_line.new({
|
|
'product_id': self.product_tmpl_id.product_variant_id,
|
|
'product_purchase_qty': 1.0,
|
|
'product_purchase_uom_id':
|
|
po.order_line._default_product_purchase_uom_id(),
|
|
'order_id': po
|
|
})
|
|
po_line.onchange_product_id()
|
|
self.assertEquals(
|
|
self.product_packaging_dozen.uom_id,
|
|
po_line.product_uom,
|
|
'The UOM Unit is not well set'
|
|
)
|
|
po_line.packaging_id = self.product_packaging_unit
|
|
po_line._onchange_packaging_id()
|
|
self.assertEquals(
|
|
self.product_packaging_unit.uom_id,
|
|
po_line.product_uom,
|
|
'The product uom is not well set'
|
|
)
|