[MIG] stock_available_immediately: Migration to 11.0

This commit is contained in:
Sergio Díaz
2019-11-29 16:28:15 +01:00
committed by Florian da Costa
parent 4ec4907a50
commit 70cd787d88
7 changed files with 65 additions and 63 deletions

View File

@@ -42,6 +42,7 @@ Contributors
* Lionel Sausin (Numérigraphe) <ls@numerigraphe.com>
* Sodexis <sodexis@sodexis.com>
* Cédric Pigeon <cedric.pigeon@acsone.eu>
* Sergio Díaz <sergiodm.1989@gmail.com>
Maintainer
----------

View File

@@ -1,6 +1,6 @@
# -*- coding: utf-8 -*-
# Copyright 2014 Camptocamp, Akretion, Numérigraphe
# Copyright 2016 Sodexis
# Copyright 2019 Sergio Díaz <sergiodm.1989@gmail.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from . import product_product

View File

@@ -1,13 +1,13 @@
# -*- coding: utf-8 -*-
# Copyright 2014 Camptocamp, Akretion, Numérigraphe
# Copyright 2016 Sodexis
# Copyright 2019 Sergio Díaz <sergiodm.1989@gmail.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
{
"name": "Ignore planned receptions in quantity available to promise",
"version": "10.0.1.0.0",
"version": "11.0.1.0.0",
"depends": ["stock_available"],
"author": "Camptocamp,Sodexis,Odoo Community Association (OCA)",
"author": "Camptocamp,Sodexis,Odoo Community Association (OCA),Sergio Díaz",
"license": "AGPL-3",
"category": "Hidden",
'installable': True

View File

@@ -4,7 +4,7 @@
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Project-Id-Version: Odoo Server 11.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: <>\n"
"Language-Team: \n"

View File

@@ -1,6 +1,6 @@
# -*- coding: utf-8 -*-
# Copyright 2014 Camptocamp, Akretion, Numérigraphe
# Copyright 2016 Sodexis
# Copyright 2019 Sergio Díaz <sergiodm.1989@gmail.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import api, models
@@ -12,8 +12,8 @@ class Product(models.Model):
@api.multi
def _compute_available_quantities_dict(self):
res, stock_dict = super(ProductProduct,
self)._compute_available_quantities_dict()
res, stock_dict = \
super(ProductProduct, self)._compute_available_quantities_dict()
for product in self:
res[product.id]['immediately_usable_qty'] -= \
stock_dict[product.id]['incoming_qty']

View File

@@ -1,3 +1 @@
# -*- coding: utf-8 -*-
from . import test_stock_available_immediately

View File

@@ -1,6 +1,6 @@
# -*- coding: utf-8 -*-
# Copyright 2014 Camptocamp, Akretion, Numérigraphe
# Copyright 2016 Sodexis
# Copyright 2019 Sergio Díaz <sergiodm.1989@gmail.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo.tests.common import TransactionCase
@@ -9,8 +9,10 @@ from odoo.tests.common import TransactionCase
class TestStockLogisticsWarehouse(TransactionCase):
def test01_stock_levels(self):
"""checking that immediately_usable_qty actually reflects \
the variations in stock, both on product and template"""
"""
Checking that immediately_usable_qty actually reflects the variations
in stock, both on product and template.
"""
moveObj = self.env['stock.move']
productObj = self.env['product.product']
templateObj = self.env['product.template']
@@ -20,48 +22,43 @@ the variations in stock, both on product and template"""
uom_unit = self.env.ref('product.product_uom_unit')
# Create product template
templateAB = templateObj.create(
{'name': 'templAB',
'uom_id': uom_unit.id,
})
templateAB = templateObj.create({
'name': 'templAB',
'uom_id': uom_unit.id})
# Create product A and B
productA = productObj.create(
{'name': 'product A',
productA = productObj.create({
'name': 'product A',
'standard_price': 1,
'type': 'product',
'uom_id': uom_unit.id,
'default_code': 'A',
'product_tmpl_id': templateAB.id,
})
'product_tmpl_id': templateAB.id})
productB = productObj.create(
{'name': 'product B',
productB = productObj.create({
'name': 'product B',
'standard_price': 1,
'type': 'product',
'uom_id': uom_unit.id,
'default_code': 'B',
'product_tmpl_id': templateAB.id,
})
'product_tmpl_id': templateAB.id})
# Create a stock move from INCOMING to STOCK
stockMoveInA = moveObj.create(
{'location_id': supplier_location.id,
stockMoveInA = moveObj.create({
'location_id': supplier_location.id,
'location_dest_id': stock_location.id,
'name': 'MOVE INCOMING -> STOCK ',
'product_id': productA.id,
'product_uom': productA.uom_id.id,
'product_uom_qty': 2,
})
'product_uom_qty': 2})
stockMoveInB = moveObj.create(
{'location_id': supplier_location.id,
stockMoveInB = moveObj.create({
'location_id': supplier_location.id,
'location_dest_id': stock_location.id,
'name': 'MOVE INCOMING -> STOCK ',
'product_id': productB.id,
'product_uom': productB.uom_id.id,
'product_uom_qty': 3,
})
'product_uom_qty': 3})
def compare_product_usable_qty(product, value):
# Refresh, because the function field is not recalculated between
@@ -72,36 +69,42 @@ the variations in stock, both on product and template"""
compare_product_usable_qty(productA, 0)
compare_product_usable_qty(templateAB, 0)
stockMoveInA.action_confirm()
stockMoveInA._action_confirm()
compare_product_usable_qty(productA, 0)
compare_product_usable_qty(templateAB, 0)
stockMoveInA.action_assign()
stockMoveInA._action_assign()
compare_product_usable_qty(productA, 0)
compare_product_usable_qty(templateAB, 0)
stockMoveInA.action_done()
stockMoveInA.move_line_ids.write({'qty_done': 2.0})
stockMoveInA._action_done()
compare_product_usable_qty(productA, 2)
compare_product_usable_qty(templateAB, 2)
# will directly trigger action_done on productB
stockMoveInB.action_done()
stockMoveInB._action_confirm()
stockMoveInB._action_assign()
stockMoveInB.move_line_ids.write({'qty_done': 3.0})
stockMoveInB._action_done()
compare_product_usable_qty(productA, 2)
compare_product_usable_qty(productB, 3)
compare_product_usable_qty(templateAB, 5)
# Create a stock move from STOCK to CUSTOMER
stockMoveOutA = moveObj.create(
{'location_id': stock_location.id,
stockMoveOutA = moveObj.create({
'location_id': stock_location.id,
'location_dest_id': customer_location.id,
'name': ' STOCK --> CUSTOMER ',
'product_id': productA.id,
'product_uom': productA.uom_id.id,
'product_uom_qty': 1,
'state': 'confirmed',
})
'state': 'confirmed'})
stockMoveOutA.action_done()
stockMoveOutA._action_confirm()
stockMoveOutA._action_assign()
stockMoveOutA.move_line_ids.write({'qty_done': 1.0})
stockMoveOutA._action_done()
compare_product_usable_qty(productA, 1)
compare_product_usable_qty(templateAB, 4)