Merge pull request #34912 from s-aga-r/FIX-INTERNAL-PR-GL-ENTRIES
fix: internal Purchase Receipt GL Entries
This commit is contained in:
commit
6f26044163
@ -380,7 +380,19 @@ class PurchaseReceipt(BuyingController):
|
|||||||
|
|
||||||
outgoing_amount = d.base_net_amount
|
outgoing_amount = d.base_net_amount
|
||||||
if self.is_internal_supplier and d.valuation_rate:
|
if self.is_internal_supplier and d.valuation_rate:
|
||||||
outgoing_amount = d.valuation_rate * d.stock_qty
|
outgoing_amount = abs(
|
||||||
|
frappe.db.get_value(
|
||||||
|
"Stock Ledger Entry",
|
||||||
|
{
|
||||||
|
"voucher_type": "Purchase Receipt",
|
||||||
|
"voucher_no": self.name,
|
||||||
|
"voucher_detail_no": d.name,
|
||||||
|
"warehouse": d.from_warehouse,
|
||||||
|
"is_cancelled": 0,
|
||||||
|
},
|
||||||
|
"stock_value_difference",
|
||||||
|
)
|
||||||
|
)
|
||||||
credit_amount = outgoing_amount
|
credit_amount = outgoing_amount
|
||||||
|
|
||||||
if credit_amount:
|
if credit_amount:
|
||||||
|
|||||||
@ -1610,6 +1610,89 @@ class TestPurchaseReceipt(FrappeTestCase):
|
|||||||
|
|
||||||
frappe.db.set_single_value("Stock Settings", "over_delivery_receipt_allowance", 0)
|
frappe.db.set_single_value("Stock Settings", "over_delivery_receipt_allowance", 0)
|
||||||
|
|
||||||
|
def test_internal_pr_gl_entries(self):
|
||||||
|
from erpnext.stock import get_warehouse_account_map
|
||||||
|
from erpnext.stock.doctype.delivery_note.delivery_note import make_inter_company_purchase_receipt
|
||||||
|
from erpnext.stock.doctype.delivery_note.test_delivery_note import create_delivery_note
|
||||||
|
from erpnext.stock.doctype.stock_entry.test_stock_entry import make_stock_entry
|
||||||
|
from erpnext.stock.doctype.stock_reconciliation.test_stock_reconciliation import (
|
||||||
|
create_stock_reconciliation,
|
||||||
|
)
|
||||||
|
|
||||||
|
prepare_data_for_internal_transfer()
|
||||||
|
customer = "_Test Internal Customer 2"
|
||||||
|
company = "_Test Company with perpetual inventory"
|
||||||
|
from_warehouse = create_warehouse("_Test Internal From Warehouse New", company=company)
|
||||||
|
target_warehouse = create_warehouse("_Test Internal GIT Warehouse New", company=company)
|
||||||
|
to_warehouse = create_warehouse("_Test Internal To Warehouse New", company=company)
|
||||||
|
|
||||||
|
item = make_item(properties={"is_stock_item": 1, "valuation_rate": 100})
|
||||||
|
make_stock_entry(
|
||||||
|
purpose="Material Receipt",
|
||||||
|
item_code=item.name,
|
||||||
|
qty=10,
|
||||||
|
company=company,
|
||||||
|
to_warehouse=from_warehouse,
|
||||||
|
posting_date=add_days(today(), -3),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Step - 1: Create Delivery Note with Internal Customer
|
||||||
|
dn = create_delivery_note(
|
||||||
|
item_code=item.name,
|
||||||
|
company=company,
|
||||||
|
customer=customer,
|
||||||
|
cost_center="Main - TCP1",
|
||||||
|
expense_account="Cost of Goods Sold - TCP1",
|
||||||
|
qty=10,
|
||||||
|
rate=100,
|
||||||
|
warehouse=from_warehouse,
|
||||||
|
target_warehouse=target_warehouse,
|
||||||
|
posting_date=add_days(today(), -2),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Step - 2: Create Internal Purchase Receipt
|
||||||
|
pr = make_inter_company_purchase_receipt(dn.name)
|
||||||
|
pr.items[0].qty = 10
|
||||||
|
pr.items[0].from_warehouse = target_warehouse
|
||||||
|
pr.items[0].warehouse = to_warehouse
|
||||||
|
pr.items[0].rejected_warehouse = from_warehouse
|
||||||
|
pr.save()
|
||||||
|
pr.submit()
|
||||||
|
|
||||||
|
# Step - 3: Create back-date Stock Reconciliation [After DN and Before PR]
|
||||||
|
create_stock_reconciliation(
|
||||||
|
item_code=item,
|
||||||
|
warehouse=target_warehouse,
|
||||||
|
qty=10,
|
||||||
|
rate=50,
|
||||||
|
company=company,
|
||||||
|
posting_date=add_days(today(), -1),
|
||||||
|
)
|
||||||
|
|
||||||
|
warehouse_account = get_warehouse_account_map(company)
|
||||||
|
stock_account_value = frappe.db.get_value(
|
||||||
|
"GL Entry",
|
||||||
|
{
|
||||||
|
"account": warehouse_account[target_warehouse]["account"],
|
||||||
|
"voucher_type": "Purchase Receipt",
|
||||||
|
"voucher_no": pr.name,
|
||||||
|
"is_cancelled": 0,
|
||||||
|
},
|
||||||
|
fieldname=["credit"],
|
||||||
|
)
|
||||||
|
stock_diff = frappe.db.get_value(
|
||||||
|
"Stock Ledger Entry",
|
||||||
|
{
|
||||||
|
"voucher_type": "Purchase Receipt",
|
||||||
|
"voucher_no": pr.name,
|
||||||
|
"is_cancelled": 0,
|
||||||
|
},
|
||||||
|
fieldname=["sum(stock_value_difference)"],
|
||||||
|
)
|
||||||
|
|
||||||
|
# Value of Stock Account should be equal to the sum of Stock Value Difference
|
||||||
|
self.assertEqual(stock_account_value, stock_diff)
|
||||||
|
|
||||||
|
|
||||||
def prepare_data_for_internal_transfer():
|
def prepare_data_for_internal_transfer():
|
||||||
from erpnext.accounts.doctype.sales_invoice.test_sales_invoice import create_internal_supplier
|
from erpnext.accounts.doctype.sales_invoice.test_sales_invoice import create_internal_supplier
|
||||||
|
|||||||
@ -530,7 +530,9 @@ class TestStockReconciliation(FrappeTestCase, StockTestMixin):
|
|||||||
# check if cancellation of stock reco is blocked
|
# check if cancellation of stock reco is blocked
|
||||||
self.assertRaises(NegativeStockError, sr.cancel)
|
self.assertRaises(NegativeStockError, sr.cancel)
|
||||||
|
|
||||||
repost_exists = bool(frappe.db.exists("Repost Item Valuation", {"voucher_no": sr.name}))
|
repost_exists = bool(
|
||||||
|
frappe.db.exists("Repost Item Valuation", {"voucher_no": sr.name, "status": "Queued"})
|
||||||
|
)
|
||||||
self.assertFalse(repost_exists, msg="Negative stock validation not working on reco cancellation")
|
self.assertFalse(repost_exists, msg="Negative stock validation not working on reco cancellation")
|
||||||
|
|
||||||
def test_intermediate_sr_bin_update(self):
|
def test_intermediate_sr_bin_update(self):
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user