-
-
Notifications
You must be signed in to change notification settings - Fork 192
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add shopfloor_location_package_restriction
- Loading branch information
Showing
17 changed files
with
219 additions
and
28 deletions.
There are no files selected for viewing
1 change: 1 addition & 0 deletions
1
...shopfloor_location_package_restriction/odoo/addons/shopfloor_location_package_restriction
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
../../../../shopfloor_location_package_restriction |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
import setuptools | ||
|
||
setuptools.setup( | ||
setup_requires=['setuptools-odoo'], | ||
odoo_addon=True, | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from . import services |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
# Copyright 2023 Camptocamp SA | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) | ||
|
||
{ | ||
"name": "Shopfloor Location Package Restriction", | ||
"summary": "Glue module between shopfloor and location package restriction", | ||
"version": "14.0.1.0.0", | ||
"category": "Inventory", | ||
"website": "https://github.com/OCA/wms", | ||
"author": "Camptocamp, Odoo Community Association (OCA)", | ||
"license": "AGPL-3", | ||
"depends": [ | ||
"shopfloor", | ||
# OCA/stock-logistics-warehouse | ||
"stock_location_package_restriction", | ||
], | ||
"auto_install": True, | ||
} |
13 changes: 13 additions & 0 deletions
13
...oor_location_package_restriction/i18n/shopfloor_single_product_transfer_force_package.pot
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# Translation of Odoo Server. | ||
# This file contains the translation of the following modules: | ||
# | ||
msgid "" | ||
msgstr "" | ||
"Project-Id-Version: Odoo Server 14.0\n" | ||
"Report-Msgid-Bugs-To: \n" | ||
"Last-Translator: \n" | ||
"Language-Team: \n" | ||
"MIME-Version: 1.0\n" | ||
"Content-Type: text/plain; charset=UTF-8\n" | ||
"Content-Transfer-Encoding: \n" | ||
"Plural-Forms: \n" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
* Thierry Ducrest <[email protected]> |
3 changes: 3 additions & 0 deletions
3
shopfloor_location_package_restriction/readme/DESCRIPTION.rst
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
Glue module between `shopfloor` and `stock_location_package_restriction`. | ||
It allows to send proper error message to the frontend instead of a stack | ||
trace error being displayed. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
from . import single_pack_transfer | ||
from . import zone_picking |
26 changes: 26 additions & 0 deletions
26
shopfloor_location_package_restriction/services/single_pack_transfer.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# Copyright 2023 Camptocamp SA | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) | ||
|
||
|
||
from odoo.exceptions import ValidationError | ||
|
||
from odoo.addons.component.core import Component | ||
|
||
|
||
class ShopfloorSinglePackTransfer(Component): | ||
_inherit = "shopfloor.single.pack.transfer" | ||
|
||
def _validate_destination_location(self, package_level, location): | ||
response = super()._validate_destination_location(package_level, location) | ||
if response: | ||
return response | ||
if location.package_restriction != "norestriction": | ||
# Not sure about this | ||
# Could there be more move lines being checked than intended ? | ||
moves = package_level.move_line_ids.move_id | ||
try: | ||
moves._check_location_package_restriction(location) | ||
except ValidationError: | ||
return self._response_for_scan_location( | ||
package_level, message=self.msg_store.location_has_restrictions() | ||
) |
21 changes: 21 additions & 0 deletions
21
shopfloor_location_package_restriction/services/zone_picking.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# Copyright 2023 Camptocamp SA | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) | ||
|
||
|
||
from odoo.exceptions import ValidationError | ||
|
||
from odoo.addons.component.core import Component | ||
|
||
|
||
class ShopfloorZonePicking(Component): | ||
_inherit = "shopfloor.zone.picking" | ||
|
||
def _validate_destination(self, location, moves): | ||
message = super()._validate_destination(location, moves) | ||
if message: | ||
return message | ||
if location.package_restriction != "norestriction": | ||
try: | ||
moves._check_location_package_restriction(only_qty_done=False) | ||
except ValidationError: | ||
return self.msg_store.location_has_restrictions() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
from . import test_single_pack_transfer_force_package | ||
from . import test_zone_picking_force_package |
59 changes: 59 additions & 0 deletions
59
shopfloor_location_package_restriction/tests/test_single_pack_transfer_force_package.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
# Copyright 2023 Camptocamp SA | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) | ||
|
||
from odoo.addons.shopfloor.tests.test_single_pack_transfer_base import ( | ||
SinglePackTransferCommonBase, | ||
) | ||
|
||
|
||
class TestSinglePackTransferForcePackage(SinglePackTransferCommonBase): | ||
@classmethod | ||
def setUpClass(cls): | ||
super().setUpClass() | ||
# Prepare the pack and related picking has started | ||
cls.pack_a = cls.env["stock.quant.package"].create( | ||
{"location_id": cls.stock_location.id} | ||
) | ||
cls.quant_a = ( | ||
cls.env["stock.quant"] | ||
.sudo() | ||
.create( | ||
{ | ||
"product_id": cls.product_a.id, | ||
"location_id": cls.shelf1.id, | ||
"quantity": 1, | ||
"package_id": cls.pack_a.id, | ||
} | ||
) | ||
) | ||
cls.picking = cls._create_initial_move(lines=[(cls.product_a, 1)]) | ||
cls.package_level = cls.picking.move_line_ids.package_level_id | ||
cls.package_level.is_done = True | ||
cls.picking.move_line_ids.qty_done = 1 | ||
# Add restriction on destination location | ||
cls.shelf2.sudo().package_restriction = "singlepackage" | ||
# Add a package on the destination location | ||
cls._update_qty_in_location( | ||
cls.shelf2, | ||
cls.product_a, | ||
1, | ||
package=cls.env["stock.quant.package"].create( | ||
{"location_id": cls.shelf2.id} | ||
), | ||
) | ||
|
||
def test_scan_location_has_restrictions(self): | ||
""" """ | ||
response = self.service.dispatch( | ||
"validate", | ||
params={ | ||
"package_level_id": self.package_level.id, | ||
"location_barcode": self.shelf2.barcode, | ||
}, | ||
) | ||
self.assert_response( | ||
response, | ||
next_state="scan_location", | ||
data=self.ANY, | ||
message=self.service.msg_store.location_has_restrictions(), | ||
) |
42 changes: 42 additions & 0 deletions
42
shopfloor_location_package_restriction/tests/test_zone_picking_force_package.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
# Copyright 2023 Camptocamp SA | ||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) | ||
|
||
from odoo.addons.shopfloor.tests.test_zone_picking_base import ZonePickingCommonCase | ||
|
||
|
||
class TestZonePickingForcePackage(ZonePickingCommonCase): | ||
def setUp(self): | ||
super().setUp() | ||
self.service.work.current_picking_type = self.picking1.picking_type_id | ||
|
||
def test_set_destination_location_package_restriction(self): | ||
"""""" | ||
# Add a restriction on the location | ||
self.packing_location.sudo().package_restriction = "singlepackage" | ||
# Add a first package on the location | ||
self.pack_1 = self.env["stock.quant.package"].create( | ||
{"location_id": self.packing_location.id} | ||
) | ||
self._update_qty_in_location( | ||
self.packing_location, self.product_a, 1, package=self.pack_1 | ||
) | ||
picking_type = self.picking1.picking_type_id | ||
move_line = self.picking1.move_lines.move_line_ids | ||
move_line.qty_done = move_line.product_uom_qty | ||
response = self.service.dispatch( | ||
"set_destination", | ||
params={ | ||
"move_line_id": move_line.id, | ||
"barcode": self.packing_location.barcode, | ||
"quantity": move_line.product_uom_qty, | ||
"confirmation": False, | ||
}, | ||
) | ||
self.assert_response_set_line_destination( | ||
response, | ||
self.zone_location, | ||
picking_type, | ||
move_line, | ||
message=self.service.msg_store.location_has_restrictions(), | ||
qty_done=10.0, | ||
) |