fix: remove all stock UOM conversion when changing stock UOM (#29463)
(cherry picked from commit eb8d08b411)
Co-authored-by: Ankush Menat <ankush@frappe.io>
This commit is contained in:
@@ -219,18 +219,20 @@ class Item(Document):
|
||||
self.item_code))
|
||||
|
||||
def add_default_uom_in_conversion_factor_table(self):
|
||||
uom_conv_list = [d.uom for d in self.get("uoms")]
|
||||
if self.stock_uom not in uom_conv_list:
|
||||
ch = self.append('uoms', {})
|
||||
ch.uom = self.stock_uom
|
||||
ch.conversion_factor = 1
|
||||
if not self.is_new() and self.has_value_changed("stock_uom"):
|
||||
self.uoms = []
|
||||
frappe.msgprint(
|
||||
_("Successfully changed Stock UOM, please redefine conversion factors for new UOM."),
|
||||
alert=True,
|
||||
)
|
||||
|
||||
to_remove = []
|
||||
for d in self.get("uoms"):
|
||||
if d.conversion_factor == 1 and d.uom != self.stock_uom:
|
||||
to_remove.append(d)
|
||||
uoms_list = [d.uom for d in self.get("uoms")]
|
||||
|
||||
[self.remove(d) for d in to_remove]
|
||||
if self.stock_uom not in uoms_list:
|
||||
self.append("uoms", {
|
||||
"uom": self.stock_uom,
|
||||
"conversion_factor": 1
|
||||
})
|
||||
|
||||
def update_website_item(self):
|
||||
"""Update Website Item if change in Item impacts it."""
|
||||
|
||||
@@ -573,6 +573,16 @@ class TestItem(ERPNextTestCase):
|
||||
except frappe.ValidationError as e:
|
||||
self.fail(f"UoM change not allowed even though no SLE / BIN with positive qty exists: {e}")
|
||||
|
||||
def test_erasure_of_old_conversions(self):
|
||||
item = create_item("_item change uom")
|
||||
item.stock_uom = "Gram"
|
||||
item.append("uoms", frappe._dict(uom="Box", conversion_factor=2))
|
||||
item.save()
|
||||
item.reload()
|
||||
item.stock_uom = "Nos"
|
||||
item.save()
|
||||
self.assertEqual(len(item.uoms), 1)
|
||||
|
||||
def test_validate_stock_item(self):
|
||||
self.assertRaises(frappe.ValidationError, validate_is_stock_item, "_Test Non Stock Item")
|
||||
|
||||
|
||||
Reference in New Issue
Block a user