mirror of
https://github.com/frappe/erpnext.git
synced 2026-05-29 09:54:47 +00:00
@@ -646,7 +646,7 @@
|
|||||||
"label": "Has Priority"
|
"label": "Has Priority"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"default": "0",
|
"default": "1",
|
||||||
"depends_on": "eval:doc.price_or_product_discount == 'Product'",
|
"depends_on": "eval:doc.price_or_product_discount == 'Product'",
|
||||||
"fieldname": "enforce_free_item_qty",
|
"fieldname": "enforce_free_item_qty",
|
||||||
"fieldtype": "Check",
|
"fieldtype": "Check",
|
||||||
@@ -656,7 +656,7 @@
|
|||||||
"icon": "fa fa-gift",
|
"icon": "fa fa-gift",
|
||||||
"idx": 1,
|
"idx": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2025-02-05 18:05:03.886828",
|
"modified": "2025-02-05 21:03:22.103044",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Accounts",
|
"module": "Accounts",
|
||||||
"name": "Pricing Rule",
|
"name": "Pricing Rule",
|
||||||
|
|||||||
@@ -386,7 +386,6 @@ class TestPricingRule(FrappeTestCase):
|
|||||||
"price_or_product_discount": "Product",
|
"price_or_product_discount": "Product",
|
||||||
"same_item": 1,
|
"same_item": 1,
|
||||||
"free_qty": 1,
|
"free_qty": 1,
|
||||||
"enforce_free_item_qty": 1,
|
|
||||||
"company": "_Test Company",
|
"company": "_Test Company",
|
||||||
}
|
}
|
||||||
frappe.get_doc(test_record.copy()).insert()
|
frappe.get_doc(test_record.copy()).insert()
|
||||||
@@ -419,7 +418,6 @@ class TestPricingRule(FrappeTestCase):
|
|||||||
"same_item": 0,
|
"same_item": 0,
|
||||||
"free_item": "_Test Item 2",
|
"free_item": "_Test Item 2",
|
||||||
"free_qty": 1,
|
"free_qty": 1,
|
||||||
"enforce_free_item_qty": 1,
|
|
||||||
"company": "_Test Company",
|
"company": "_Test Company",
|
||||||
}
|
}
|
||||||
frappe.get_doc(test_record.copy()).insert()
|
frappe.get_doc(test_record.copy()).insert()
|
||||||
@@ -430,6 +428,54 @@ class TestPricingRule(FrappeTestCase):
|
|||||||
self.assertEqual(so.items[1].is_free_item, 1)
|
self.assertEqual(so.items[1].is_free_item, 1)
|
||||||
self.assertEqual(so.items[1].item_code, "_Test Item 2")
|
self.assertEqual(so.items[1].item_code, "_Test Item 2")
|
||||||
|
|
||||||
|
def test_enforce_free_item_qty(self):
|
||||||
|
# this test is only for testing non-enforcement as all other tests in this file already test with enforcement
|
||||||
|
frappe.delete_doc_if_exists("Pricing Rule", "_Test Pricing Rule")
|
||||||
|
test_record = {
|
||||||
|
"doctype": "Pricing Rule",
|
||||||
|
"title": "_Test Pricing Rule",
|
||||||
|
"apply_on": "Item Code",
|
||||||
|
"currency": "USD",
|
||||||
|
"items": [
|
||||||
|
{
|
||||||
|
"item_code": "_Test Item",
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"selling": 1,
|
||||||
|
"rate_or_discount": "Discount Percentage",
|
||||||
|
"rate": 0,
|
||||||
|
"min_qty": 0,
|
||||||
|
"max_qty": 7,
|
||||||
|
"discount_percentage": 17.5,
|
||||||
|
"price_or_product_discount": "Product",
|
||||||
|
"same_item": 0,
|
||||||
|
"free_item": "_Test Item 2",
|
||||||
|
"free_qty": 1,
|
||||||
|
"company": "_Test Company",
|
||||||
|
}
|
||||||
|
pricing_rule = frappe.get_doc(test_record.copy()).insert()
|
||||||
|
|
||||||
|
# With enforcement
|
||||||
|
so = make_sales_order(item_code="_Test Item", qty=1, do_not_submit=True)
|
||||||
|
self.assertEqual(so.items[1].is_free_item, 1)
|
||||||
|
self.assertEqual(so.items[1].item_code, "_Test Item 2")
|
||||||
|
|
||||||
|
# Test 1 : Saving a document with an item with pricing list without it's corresponding free item will cause it the free item to be refetched on save
|
||||||
|
so.items.pop(1)
|
||||||
|
so.save()
|
||||||
|
so.reload()
|
||||||
|
self.assertEqual(len(so.items), 2)
|
||||||
|
|
||||||
|
# Without enforcement
|
||||||
|
pricing_rule.enforce_free_item_qty = 0
|
||||||
|
pricing_rule.save()
|
||||||
|
|
||||||
|
# Test 2 : Deleted free item will not be fetched again on save without enfrocement
|
||||||
|
so.items.pop(1)
|
||||||
|
so.save()
|
||||||
|
so.reload()
|
||||||
|
self.assertEqual(len(so.items), 1)
|
||||||
|
|
||||||
def test_cumulative_pricing_rule(self):
|
def test_cumulative_pricing_rule(self):
|
||||||
frappe.delete_doc_if_exists("Pricing Rule", "_Test Cumulative Pricing Rule")
|
frappe.delete_doc_if_exists("Pricing Rule", "_Test Cumulative Pricing Rule")
|
||||||
test_record = {
|
test_record = {
|
||||||
@@ -963,7 +1009,6 @@ class TestPricingRule(FrappeTestCase):
|
|||||||
"price_or_product_discount": "Product",
|
"price_or_product_discount": "Product",
|
||||||
"same_item": 1,
|
"same_item": 1,
|
||||||
"free_qty": 1,
|
"free_qty": 1,
|
||||||
"enforce_free_item_qty": 1,
|
|
||||||
"round_free_qty": 1,
|
"round_free_qty": 1,
|
||||||
"is_recursive": 1,
|
"is_recursive": 1,
|
||||||
"recurse_for": 2,
|
"recurse_for": 2,
|
||||||
@@ -1009,7 +1054,6 @@ class TestPricingRule(FrappeTestCase):
|
|||||||
"price_or_product_discount": "Product",
|
"price_or_product_discount": "Product",
|
||||||
"same_item": 1,
|
"same_item": 1,
|
||||||
"free_qty": 10,
|
"free_qty": 10,
|
||||||
"enforce_free_item_qty": 1,
|
|
||||||
"round_free_qty": 1,
|
"round_free_qty": 1,
|
||||||
"is_recursive": 1,
|
"is_recursive": 1,
|
||||||
"recurse_for": 100,
|
"recurse_for": 100,
|
||||||
|
|||||||
Reference in New Issue
Block a user