mirror of
https://github.com/OCA/manufacture.git
synced 2025-01-28 16:37:15 +02:00
126 lines
5.8 KiB
Python
126 lines
5.8 KiB
Python
# Copyright 2018 Eficent Business and IT Consulting Services S.L.
|
|
# (http://www.eficent.com)
|
|
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
|
|
|
|
from datetime import datetime, timedelta
|
|
|
|
from odoo.tests.common import SavepointCase
|
|
from odoo import fields
|
|
|
|
|
|
class TestMultiLevelMRP(SavepointCase):
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super(TestMultiLevelMRP, cls).setUpClass()
|
|
cls.wiz_multi_level_mrp_model = cls.env['multi.level.mrp']
|
|
cls.stock_picking_model = cls.env['stock.picking']
|
|
cls.mrp_inventory_model = cls.env['mrp.inventory']
|
|
cls.fp_1 = cls.env.ref('multi_level_mrp.product_product_fp_1')
|
|
cls.fp_2 = cls.env.ref('multi_level_mrp.product_product_fp_2')
|
|
cls.sf_1 = cls.env.ref('multi_level_mrp.product_product_sf_1')
|
|
cls.sf_2 = cls.env.ref('multi_level_mrp.product_product_sf_2')
|
|
cls.pp_1 = cls.env.ref('multi_level_mrp.product_product_pp_1')
|
|
cls.pp_2 = cls.env.ref('multi_level_mrp.product_product_pp_2')
|
|
cls.wh = cls.env.ref('stock.warehouse0')
|
|
cls.stock_location = cls.wh.lot_stock_id
|
|
cls.customer_location = cls.env.ref(
|
|
'stock.stock_location_customers')
|
|
date_move = datetime.today() + timedelta(days=7)
|
|
cls.picking_1 = cls.stock_picking_model.create({
|
|
'picking_type_id': cls.env.ref('stock.picking_type_out').id,
|
|
'location_id': cls.stock_location.id,
|
|
'location_dest_id': cls.customer_location.id,
|
|
'move_lines': [
|
|
(0, 0, {
|
|
'name': 'Test move pf-1',
|
|
'product_id': cls.fp_1.id,
|
|
'date_expected': date_move,
|
|
'date': date_move,
|
|
'product_uom': cls.fp_1.uom_id.id,
|
|
'product_uom_qty': 100,
|
|
'location_id': cls.stock_location.id,
|
|
'location_dest_id': cls.customer_location.id
|
|
}),
|
|
(0, 0, {
|
|
'name': 'Test move fp-2',
|
|
'product_id': cls.fp_2.id,
|
|
'date_expected': date_move,
|
|
'date': date_move,
|
|
'product_uom': cls.fp_2.uom_id.id,
|
|
'product_uom_qty': 15,
|
|
'location_id': cls.stock_location.id,
|
|
'location_dest_id': cls.customer_location.id
|
|
})]
|
|
})
|
|
cls.picking_1.action_confirm()
|
|
cls.wiz_multi_level_mrp_model.create({}).run_multi_level_mrp()
|
|
|
|
def test_01_mrp_levels(self):
|
|
"""Tests computation of MRP levels."""
|
|
self.assertEqual(self.fp_1.llc, 0)
|
|
self.assertEqual(self.fp_2.llc, 0)
|
|
self.assertEqual(self.sf_1.llc, 1)
|
|
self.assertEqual(self.sf_2.llc, 1)
|
|
self.assertEqual(self.pp_1.llc, 2)
|
|
self.assertEqual(self.pp_2.llc, 2)
|
|
|
|
def test_02_multi_level_mrp(self):
|
|
"""Tests MRP inventories created."""
|
|
# FP-1
|
|
fp_1_inventory_lines = self.mrp_inventory_model.search(
|
|
[('mrp_product_id.product_id', '=', self.fp_1.id)])
|
|
self.assertEqual(len(fp_1_inventory_lines), 1)
|
|
date_7 = fields.Date.to_string(datetime.today() + timedelta(days=7))
|
|
self.assertEqual(fp_1_inventory_lines.date, date_7)
|
|
self.assertEqual(fp_1_inventory_lines.demand_qty, 100.0)
|
|
self.assertEqual(fp_1_inventory_lines.to_procure, 100.0)
|
|
# FP-2
|
|
fp_2_inventory_lines = self.mrp_inventory_model.search(
|
|
[('mrp_product_id.product_id', '=', self.fp_2.id)])
|
|
self.assertEqual(len(fp_2_inventory_lines), 1)
|
|
self.assertEqual(fp_2_inventory_lines.date, date_7)
|
|
self.assertEqual(fp_2_inventory_lines.demand_qty, 15.0)
|
|
self.assertEqual(fp_2_inventory_lines.to_procure, 15.0)
|
|
|
|
# SF-1
|
|
sf_1_inventory_lines = self.mrp_inventory_model.search(
|
|
[('mrp_product_id.product_id', '=', self.sf_1.id)])
|
|
self.assertEqual(len(sf_1_inventory_lines), 1)
|
|
date_6 = fields.Date.to_string(datetime.today() + timedelta(days=6))
|
|
self.assertEqual(sf_1_inventory_lines.date, date_6)
|
|
self.assertEqual(sf_1_inventory_lines.demand_qty, 30.0)
|
|
self.assertEqual(sf_1_inventory_lines.to_procure, 30.0)
|
|
# SF-2
|
|
sf_2_inventory_lines = self.mrp_inventory_model.search(
|
|
[('mrp_product_id.product_id', '=', self.sf_2.id)])
|
|
self.assertEqual(len(sf_2_inventory_lines), 1)
|
|
self.assertEqual(sf_2_inventory_lines.date, date_6)
|
|
self.assertEqual(sf_2_inventory_lines.demand_qty, 45.0)
|
|
self.assertEqual(sf_2_inventory_lines.to_procure, 30.0)
|
|
|
|
# PP-1
|
|
pp_1_inventory_lines = self.mrp_inventory_model.search(
|
|
[('mrp_product_id.product_id', '=', self.pp_1.id)])
|
|
self.assertEqual(len(pp_1_inventory_lines), 1)
|
|
date_5 = fields.Date.to_string(datetime.today() + timedelta(days=5))
|
|
self.assertEqual(pp_1_inventory_lines.date, date_5)
|
|
self.assertEqual(pp_1_inventory_lines.demand_qty, 290.0)
|
|
self.assertEqual(pp_1_inventory_lines.to_procure, 280.0)
|
|
# PP-2
|
|
pp_2_line_1 = self.mrp_inventory_model.search([
|
|
('mrp_product_id.product_id', '=', self.pp_2.id),
|
|
('date', '=', date_5)])
|
|
self.assertEqual(len(pp_2_line_1), 1)
|
|
self.assertEqual(pp_2_line_1.demand_qty, 360.0)
|
|
self.assertEqual(pp_2_line_1.to_procure, 360.0)
|
|
date_3 = fields.Date.to_string(datetime.today() + timedelta(days=3))
|
|
pp_2_line_2 = self.mrp_inventory_model.search([
|
|
('mrp_product_id.product_id', '=', self.pp_2.id),
|
|
('date', '=', date_3)])
|
|
self.assertEqual(len(pp_2_line_2), 1)
|
|
self.assertEqual(pp_2_line_2.demand_qty, 90.0)
|
|
self.assertEqual(pp_2_line_2.to_procure, 70.0)
|
|
|
|
# TODO: test procure wizard: dates...
|