mirror of
https://github.com/frappe/erpnext.git
synced 2026-05-21 14:09:19 +00:00
Merge pull request #47505 from aerele/fix/address-link
fix: validate inter company transaction address links
This commit is contained in:
@@ -2412,6 +2412,18 @@ def make_inter_company_transaction(doctype, source_name, target_doc=None):
|
|||||||
set_purchase_references(target)
|
set_purchase_references(target)
|
||||||
|
|
||||||
def update_details(source_doc, target_doc, source_parent):
|
def update_details(source_doc, target_doc, source_parent):
|
||||||
|
def _validate_address_link(address, link_doctype, link_name):
|
||||||
|
return frappe.db.get_value(
|
||||||
|
"Dynamic Link",
|
||||||
|
{
|
||||||
|
"parent": address,
|
||||||
|
"parenttype": "Address",
|
||||||
|
"link_doctype": link_doctype,
|
||||||
|
"link_name": link_name,
|
||||||
|
},
|
||||||
|
"parent",
|
||||||
|
)
|
||||||
|
|
||||||
target_doc.inter_company_invoice_reference = source_doc.name
|
target_doc.inter_company_invoice_reference = source_doc.name
|
||||||
if target_doc.doctype in ["Purchase Invoice", "Purchase Order"]:
|
if target_doc.doctype in ["Purchase Invoice", "Purchase Order"]:
|
||||||
currency = frappe.db.get_value("Supplier", details.get("party"), "default_currency")
|
currency = frappe.db.get_value("Supplier", details.get("party"), "default_currency")
|
||||||
@@ -2422,16 +2434,34 @@ def make_inter_company_transaction(doctype, source_name, target_doc=None):
|
|||||||
target_doc.buying_price_list = source_doc.selling_price_list
|
target_doc.buying_price_list = source_doc.selling_price_list
|
||||||
|
|
||||||
# Invert Addresses
|
# Invert Addresses
|
||||||
update_address(target_doc, "supplier_address", "address_display", source_doc.company_address)
|
if source_doc.company_address and _validate_address_link(
|
||||||
update_address(
|
source_doc.company_address, "Supplier", details.get("party")
|
||||||
target_doc, "dispatch_address", "dispatch_address_display", source_doc.dispatch_address_name
|
):
|
||||||
)
|
update_address(target_doc, "supplier_address", "address_display", source_doc.company_address)
|
||||||
update_address(
|
if source_doc.dispatch_address_name and _validate_address_link(
|
||||||
target_doc, "shipping_address", "shipping_address_display", source_doc.shipping_address_name
|
source_doc.dispatch_address_name, "Company", details.get("company")
|
||||||
)
|
):
|
||||||
update_address(
|
update_address(
|
||||||
target_doc, "billing_address", "billing_address_display", source_doc.customer_address
|
target_doc,
|
||||||
)
|
"dispatch_address",
|
||||||
|
"dispatch_address_display",
|
||||||
|
source_doc.dispatch_address_name,
|
||||||
|
)
|
||||||
|
if source_doc.shipping_address_name and _validate_address_link(
|
||||||
|
source_doc.shipping_address_name, "Company", details.get("company")
|
||||||
|
):
|
||||||
|
update_address(
|
||||||
|
target_doc,
|
||||||
|
"shipping_address",
|
||||||
|
"shipping_address_display",
|
||||||
|
source_doc.shipping_address_name,
|
||||||
|
)
|
||||||
|
if source_doc.customer_address and _validate_address_link(
|
||||||
|
source_doc.customer_address, "Company", details.get("company")
|
||||||
|
):
|
||||||
|
update_address(
|
||||||
|
target_doc, "billing_address", "billing_address_display", source_doc.customer_address
|
||||||
|
)
|
||||||
|
|
||||||
if currency:
|
if currency:
|
||||||
target_doc.currency = currency
|
target_doc.currency = currency
|
||||||
@@ -2452,13 +2482,22 @@ def make_inter_company_transaction(doctype, source_name, target_doc=None):
|
|||||||
target_doc.customer = details.get("party")
|
target_doc.customer = details.get("party")
|
||||||
target_doc.selling_price_list = source_doc.buying_price_list
|
target_doc.selling_price_list = source_doc.buying_price_list
|
||||||
|
|
||||||
update_address(
|
if source_doc.supplier_address and _validate_address_link(
|
||||||
target_doc, "company_address", "company_address_display", source_doc.supplier_address
|
source_doc.supplier_address, "Company", details.get("company")
|
||||||
)
|
):
|
||||||
update_address(
|
update_address(
|
||||||
target_doc, "shipping_address_name", "shipping_address", source_doc.shipping_address
|
target_doc, "company_address", "company_address_display", source_doc.supplier_address
|
||||||
)
|
)
|
||||||
update_address(target_doc, "customer_address", "address_display", source_doc.shipping_address)
|
if source_doc.shipping_address and _validate_address_link(
|
||||||
|
source_doc.shipping_address, "Customer", details.get("party")
|
||||||
|
):
|
||||||
|
update_address(
|
||||||
|
target_doc, "shipping_address_name", "shipping_address", source_doc.shipping_address
|
||||||
|
)
|
||||||
|
if source_doc.shipping_address and _validate_address_link(
|
||||||
|
source_doc.shipping_address, "Customer", details.get("party")
|
||||||
|
):
|
||||||
|
update_address(target_doc, "customer_address", "address_display", source_doc.shipping_address)
|
||||||
|
|
||||||
if currency:
|
if currency:
|
||||||
target_doc.currency = currency
|
target_doc.currency = currency
|
||||||
|
|||||||
@@ -2576,6 +2576,62 @@ class TestSalesInvoice(ERPNextTestSuite):
|
|||||||
acc_settings.book_deferred_entries_based_on = "Days"
|
acc_settings.book_deferred_entries_based_on = "Days"
|
||||||
acc_settings.save()
|
acc_settings.save()
|
||||||
|
|
||||||
|
def test_validate_inter_company_transaction_address_links(self):
|
||||||
|
def _validate_address_link(address, link_doctype, link_name):
|
||||||
|
return frappe.db.get_value(
|
||||||
|
"Dynamic Link",
|
||||||
|
{
|
||||||
|
"parent": address,
|
||||||
|
"parenttype": "Address",
|
||||||
|
"link_doctype": link_doctype,
|
||||||
|
"link_name": link_name,
|
||||||
|
},
|
||||||
|
"parent",
|
||||||
|
)
|
||||||
|
|
||||||
|
si = create_sales_invoice(
|
||||||
|
company="Wind Power LLC",
|
||||||
|
customer="_Test Internal Customer",
|
||||||
|
debit_to="Debtors - WP",
|
||||||
|
warehouse="Stores - WP",
|
||||||
|
income_account="Sales - WP",
|
||||||
|
expense_account="Cost of Goods Sold - WP",
|
||||||
|
cost_center="Main - WP",
|
||||||
|
currency="USD",
|
||||||
|
do_not_save=1,
|
||||||
|
)
|
||||||
|
|
||||||
|
si.selling_price_list = "_Test Price List Rest of the World"
|
||||||
|
si.submit()
|
||||||
|
|
||||||
|
target_doc = make_inter_company_transaction("Sales Invoice", si.name)
|
||||||
|
target_doc.items[0].update(
|
||||||
|
{
|
||||||
|
"expense_account": "Cost of Goods Sold - _TC1",
|
||||||
|
"cost_center": "Main - _TC1",
|
||||||
|
"warehouse": "Stores - _TC1",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
target_doc.save()
|
||||||
|
|
||||||
|
if target_doc.doctype in ["Purchase Invoice", "Purchase Order"]:
|
||||||
|
for details in [
|
||||||
|
("supplier_address", "Supplier", target_doc.supplier),
|
||||||
|
("dispatch_address", "Company", target_doc.company),
|
||||||
|
("shipping_address", "Company", target_doc.company),
|
||||||
|
("billing_address", "Company", target_doc.company),
|
||||||
|
]:
|
||||||
|
if address := target_doc.get(details[0]):
|
||||||
|
self.assertEqual(address, _validate_address_link(address, details[1], details[2]))
|
||||||
|
else:
|
||||||
|
for details in [
|
||||||
|
("company_address", "Company", target_doc.company),
|
||||||
|
("shipping_address_name", "Customer", target_doc.customer),
|
||||||
|
("customer_address", "Customer", target_doc.customer),
|
||||||
|
]:
|
||||||
|
if address := target_doc.get(details[0]):
|
||||||
|
self.assertEqual(address, _validate_address_link(address, details[1], details[2]))
|
||||||
|
|
||||||
def test_inter_company_transaction(self):
|
def test_inter_company_transaction(self):
|
||||||
si = create_sales_invoice(
|
si = create_sales_invoice(
|
||||||
company="Wind Power LLC",
|
company="Wind Power LLC",
|
||||||
|
|||||||
@@ -1147,6 +1147,18 @@ def make_inter_company_transaction(doctype, source_name, target_doc=None):
|
|||||||
frappe.throw(_("All items have already been received"))
|
frappe.throw(_("All items have already been received"))
|
||||||
|
|
||||||
def update_details(source_doc, target_doc, source_parent):
|
def update_details(source_doc, target_doc, source_parent):
|
||||||
|
def _validate_address_link(address, link_doctype, link_name):
|
||||||
|
return frappe.db.get_value(
|
||||||
|
"Dynamic Link",
|
||||||
|
{
|
||||||
|
"parent": address,
|
||||||
|
"parenttype": "Address",
|
||||||
|
"link_doctype": link_doctype,
|
||||||
|
"link_name": link_name,
|
||||||
|
},
|
||||||
|
"parent",
|
||||||
|
)
|
||||||
|
|
||||||
target_doc.inter_company_invoice_reference = source_doc.name
|
target_doc.inter_company_invoice_reference = source_doc.name
|
||||||
if target_doc.doctype == "Purchase Receipt":
|
if target_doc.doctype == "Purchase Receipt":
|
||||||
target_doc.company = details.get("company")
|
target_doc.company = details.get("company")
|
||||||
@@ -1156,16 +1168,34 @@ def make_inter_company_transaction(doctype, source_name, target_doc=None):
|
|||||||
target_doc.inter_company_reference = source_doc.name
|
target_doc.inter_company_reference = source_doc.name
|
||||||
|
|
||||||
# Invert the address on target doc creation
|
# Invert the address on target doc creation
|
||||||
update_address(target_doc, "supplier_address", "address_display", source_doc.company_address)
|
if source_doc.company_address and _validate_address_link(
|
||||||
update_address(
|
source_doc.company_address, "Supplier", details.get("party")
|
||||||
target_doc, "dispatch_address", "dispatch_address_display", source_doc.dispatch_address_name
|
):
|
||||||
)
|
update_address(target_doc, "supplier_address", "address_display", source_doc.company_address)
|
||||||
update_address(
|
if source_doc.dispatch_address_name and _validate_address_link(
|
||||||
target_doc, "shipping_address", "shipping_address_display", source_doc.shipping_address_name
|
source_doc.dispatch_address_name, "Company", details.get("company")
|
||||||
)
|
):
|
||||||
update_address(
|
update_address(
|
||||||
target_doc, "billing_address", "billing_address_display", source_doc.customer_address
|
target_doc,
|
||||||
)
|
"dispatch_address",
|
||||||
|
"dispatch_address_display",
|
||||||
|
source_doc.dispatch_address_name,
|
||||||
|
)
|
||||||
|
if source_doc.shipping_address_name and _validate_address_link(
|
||||||
|
source_doc.shipping_address_name, "Company", details.get("company")
|
||||||
|
):
|
||||||
|
update_address(
|
||||||
|
target_doc,
|
||||||
|
"shipping_address",
|
||||||
|
"shipping_address_display",
|
||||||
|
source_doc.shipping_address_name,
|
||||||
|
)
|
||||||
|
if source_doc.customer_address and _validate_address_link(
|
||||||
|
source_doc.customer_address, "Company", details.get("company")
|
||||||
|
):
|
||||||
|
update_address(
|
||||||
|
target_doc, "billing_address", "billing_address_display", source_doc.customer_address
|
||||||
|
)
|
||||||
|
|
||||||
update_taxes(
|
update_taxes(
|
||||||
target_doc,
|
target_doc,
|
||||||
@@ -1185,13 +1215,22 @@ def make_inter_company_transaction(doctype, source_name, target_doc=None):
|
|||||||
target_doc.inter_company_reference = source_doc.name
|
target_doc.inter_company_reference = source_doc.name
|
||||||
|
|
||||||
# Invert the address on target doc creation
|
# Invert the address on target doc creation
|
||||||
update_address(
|
if source_doc.supplier_address and _validate_address_link(
|
||||||
target_doc, "company_address", "company_address_display", source_doc.supplier_address
|
source_doc.supplier_address, "Company", details.get("company")
|
||||||
)
|
):
|
||||||
update_address(
|
update_address(
|
||||||
target_doc, "shipping_address_name", "shipping_address", source_doc.shipping_address
|
target_doc, "company_address", "company_address_display", source_doc.supplier_address
|
||||||
)
|
)
|
||||||
update_address(target_doc, "customer_address", "address_display", source_doc.shipping_address)
|
if source_doc.shipping_address and _validate_address_link(
|
||||||
|
source_doc.shipping_address, "Customer", details.get("party")
|
||||||
|
):
|
||||||
|
update_address(
|
||||||
|
target_doc, "shipping_address_name", "shipping_address", source_doc.shipping_address
|
||||||
|
)
|
||||||
|
if source_doc.shipping_address and _validate_address_link(
|
||||||
|
source_doc.shipping_address, "Customer", details.get("party")
|
||||||
|
):
|
||||||
|
update_address(target_doc, "customer_address", "address_display", source_doc.shipping_address)
|
||||||
|
|
||||||
update_taxes(
|
update_taxes(
|
||||||
target_doc,
|
target_doc,
|
||||||
|
|||||||
Reference in New Issue
Block a user