fix: accepted warehouse and rejected warehouse can't be same
This commit is contained in:
parent
2f169575e9
commit
d618aaef32
@ -549,6 +549,7 @@
|
|||||||
"depends_on": "update_stock",
|
"depends_on": "update_stock",
|
||||||
"fieldname": "rejected_warehouse",
|
"fieldname": "rejected_warehouse",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"ignore_user_permissions": 1,
|
||||||
"label": "Rejected Warehouse",
|
"label": "Rejected Warehouse",
|
||||||
"no_copy": 1,
|
"no_copy": 1,
|
||||||
"options": "Warehouse",
|
"options": "Warehouse",
|
||||||
@ -1576,7 +1577,7 @@
|
|||||||
"idx": 204,
|
"idx": 204,
|
||||||
"is_submittable": 1,
|
"is_submittable": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2023-06-03 16:21:54.637245",
|
"modified": "2023-07-04 17:22:59.145031",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Accounts",
|
"module": "Accounts",
|
||||||
"name": "Purchase Invoice",
|
"name": "Purchase Invoice",
|
||||||
|
|||||||
@ -423,6 +423,7 @@
|
|||||||
{
|
{
|
||||||
"fieldname": "rejected_warehouse",
|
"fieldname": "rejected_warehouse",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"ignore_user_permissions": 1,
|
||||||
"label": "Rejected Warehouse",
|
"label": "Rejected Warehouse",
|
||||||
"options": "Warehouse"
|
"options": "Warehouse"
|
||||||
},
|
},
|
||||||
@ -904,7 +905,7 @@
|
|||||||
"idx": 1,
|
"idx": 1,
|
||||||
"istable": 1,
|
"istable": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2023-07-02 18:39:41.495723",
|
"modified": "2023-07-04 17:22:21.501152",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Accounts",
|
"module": "Accounts",
|
||||||
"name": "Purchase Invoice Item",
|
"name": "Purchase Invoice Item",
|
||||||
|
|||||||
@ -437,18 +437,23 @@ class BuyingController(SubcontractingController):
|
|||||||
# validate rate with ref PR
|
# validate rate with ref PR
|
||||||
|
|
||||||
def validate_rejected_warehouse(self):
|
def validate_rejected_warehouse(self):
|
||||||
for d in self.get("items"):
|
for item in self.get("items"):
|
||||||
if flt(d.rejected_qty) and not d.rejected_warehouse:
|
if flt(item.rejected_qty) and not item.rejected_warehouse:
|
||||||
if self.rejected_warehouse:
|
if self.rejected_warehouse:
|
||||||
d.rejected_warehouse = self.rejected_warehouse
|
item.rejected_warehouse = self.rejected_warehouse
|
||||||
|
|
||||||
if not d.rejected_warehouse:
|
if not item.rejected_warehouse:
|
||||||
frappe.throw(
|
frappe.throw(
|
||||||
_("Row #{0}: Rejected Warehouse is mandatory against rejected Item {1}").format(
|
_("Row #{0}: Rejected Warehouse is mandatory for the rejected Item {1}").format(
|
||||||
d.idx, d.item_code
|
item.idx, item.item_code
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if item.get("rejected_warehouse") and (item.get("rejected_warehouse") == item.get("warehouse")):
|
||||||
|
frappe.throw(
|
||||||
|
_("Row #{0}: Accepted Warehouse and Rejected Warehouse cannot be same").format(item.idx)
|
||||||
|
)
|
||||||
|
|
||||||
# validate accepted and rejected qty
|
# validate accepted and rejected qty
|
||||||
def validate_accepted_rejected_qty(self):
|
def validate_accepted_rejected_qty(self):
|
||||||
for d in self.get("items"):
|
for d in self.get("items"):
|
||||||
|
|||||||
@ -438,6 +438,7 @@
|
|||||||
{
|
{
|
||||||
"fieldname": "rejected_warehouse",
|
"fieldname": "rejected_warehouse",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"ignore_user_permissions": 1,
|
||||||
"label": "Rejected Warehouse",
|
"label": "Rejected Warehouse",
|
||||||
"no_copy": 1,
|
"no_copy": 1,
|
||||||
"oldfieldname": "rejected_warehouse",
|
"oldfieldname": "rejected_warehouse",
|
||||||
@ -1240,7 +1241,7 @@
|
|||||||
"idx": 261,
|
"idx": 261,
|
||||||
"is_submittable": 1,
|
"is_submittable": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2023-06-03 16:23:20.781368",
|
"modified": "2023-07-04 17:23:17.025390",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Stock",
|
"module": "Stock",
|
||||||
"name": "Purchase Receipt",
|
"name": "Purchase Receipt",
|
||||||
|
|||||||
@ -350,6 +350,15 @@ class TestPurchaseReceipt(FrappeTestCase):
|
|||||||
pr.cancel()
|
pr.cancel()
|
||||||
self.assertFalse(frappe.db.get_value("Serial No", pr_row_1_serial_no, "warehouse"))
|
self.assertFalse(frappe.db.get_value("Serial No", pr_row_1_serial_no, "warehouse"))
|
||||||
|
|
||||||
|
def test_rejected_warehouse_filter(self):
|
||||||
|
pr = frappe.copy_doc(test_records[0])
|
||||||
|
pr.get("items")[0].item_code = "_Test Serialized Item With Series"
|
||||||
|
pr.get("items")[0].qty = 3
|
||||||
|
pr.get("items")[0].rejected_qty = 2
|
||||||
|
pr.get("items")[0].received_qty = 5
|
||||||
|
pr.get("items")[0].rejected_warehouse = pr.get("items")[0].warehouse
|
||||||
|
self.assertRaises(frappe.ValidationError, pr.save)
|
||||||
|
|
||||||
def test_rejected_serial_no(self):
|
def test_rejected_serial_no(self):
|
||||||
pr = frappe.copy_doc(test_records[0])
|
pr = frappe.copy_doc(test_records[0])
|
||||||
pr.get("items")[0].item_code = "_Test Serialized Item With Series"
|
pr.get("items")[0].item_code = "_Test Serialized Item With Series"
|
||||||
|
|||||||
@ -502,6 +502,7 @@
|
|||||||
{
|
{
|
||||||
"fieldname": "rejected_warehouse",
|
"fieldname": "rejected_warehouse",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"ignore_user_permissions": 1,
|
||||||
"label": "Rejected Warehouse",
|
"label": "Rejected Warehouse",
|
||||||
"no_copy": 1,
|
"no_copy": 1,
|
||||||
"oldfieldname": "rejected_warehouse",
|
"oldfieldname": "rejected_warehouse",
|
||||||
@ -1058,7 +1059,7 @@
|
|||||||
"idx": 1,
|
"idx": 1,
|
||||||
"istable": 1,
|
"istable": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2023-07-02 18:40:48.152637",
|
"modified": "2023-07-04 17:22:02.830029",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Stock",
|
"module": "Stock",
|
||||||
"name": "Purchase Receipt Item",
|
"name": "Purchase Receipt Item",
|
||||||
|
|||||||
@ -251,6 +251,7 @@
|
|||||||
"description": "Sets 'Rejected Warehouse' in each row of the Items table.",
|
"description": "Sets 'Rejected Warehouse' in each row of the Items table.",
|
||||||
"fieldname": "rejected_warehouse",
|
"fieldname": "rejected_warehouse",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"ignore_user_permissions": 1,
|
||||||
"label": "Rejected Warehouse",
|
"label": "Rejected Warehouse",
|
||||||
"no_copy": 1,
|
"no_copy": 1,
|
||||||
"options": "Warehouse",
|
"options": "Warehouse",
|
||||||
@ -630,7 +631,7 @@
|
|||||||
"in_create": 1,
|
"in_create": 1,
|
||||||
"is_submittable": 1,
|
"is_submittable": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2023-06-03 16:18:39.088518",
|
"modified": "2023-07-06 18:43:16.171842",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Subcontracting",
|
"module": "Subcontracting",
|
||||||
"name": "Subcontracting Receipt",
|
"name": "Subcontracting Receipt",
|
||||||
|
|||||||
@ -192,13 +192,23 @@ class SubcontractingReceipt(SubcontractingController):
|
|||||||
self.total = total_amount
|
self.total = total_amount
|
||||||
|
|
||||||
def validate_rejected_warehouse(self):
|
def validate_rejected_warehouse(self):
|
||||||
if not self.rejected_warehouse:
|
for item in self.items:
|
||||||
for item in self.items:
|
if flt(item.rejected_qty) and not item.rejected_warehouse:
|
||||||
if item.rejected_qty:
|
if self.rejected_warehouse:
|
||||||
|
item.rejected_warehouse = self.rejected_warehouse
|
||||||
|
|
||||||
|
if not item.rejected_warehouse:
|
||||||
frappe.throw(
|
frappe.throw(
|
||||||
_("Rejected Warehouse is mandatory against rejected Item {0}").format(item.item_code)
|
_("Row #{0}: Rejected Warehouse is mandatory for the rejected Item {1}").format(
|
||||||
|
item.idx, item.item_code
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if item.get("rejected_warehouse") and (item.get("rejected_warehouse") == item.get("warehouse")):
|
||||||
|
frappe.throw(
|
||||||
|
_("Row #{0}: Accepted Warehouse and Rejected Warehouse cannot be same").format(item.idx)
|
||||||
|
)
|
||||||
|
|
||||||
def validate_available_qty_for_consumption(self):
|
def validate_available_qty_for_consumption(self):
|
||||||
for item in self.get("supplied_items"):
|
for item in self.get("supplied_items"):
|
||||||
precision = item.precision("consumed_qty")
|
precision = item.precision("consumed_qty")
|
||||||
|
|||||||
@ -254,6 +254,7 @@
|
|||||||
"depends_on": "eval: !parent.is_return",
|
"depends_on": "eval: !parent.is_return",
|
||||||
"fieldname": "rejected_warehouse",
|
"fieldname": "rejected_warehouse",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
|
"ignore_user_permissions": 1,
|
||||||
"label": "Rejected Warehouse",
|
"label": "Rejected Warehouse",
|
||||||
"no_copy": 1,
|
"no_copy": 1,
|
||||||
"options": "Warehouse",
|
"options": "Warehouse",
|
||||||
@ -494,7 +495,7 @@
|
|||||||
"idx": 1,
|
"idx": 1,
|
||||||
"istable": 1,
|
"istable": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2023-03-12 14:00:41.418681",
|
"modified": "2023-07-06 18:43:45.599761",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Subcontracting",
|
"module": "Subcontracting",
|
||||||
"name": "Subcontracting Receipt Item",
|
"name": "Subcontracting Receipt Item",
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user