fix bugs: add payment_schedule
if payment_terms_schedule
specified
This commit is contained in:
parent
96b8f223fd
commit
df3a175974
@ -85,14 +85,12 @@ class TestPurchaseOrder(unittest.TestCase):
|
|||||||
self.assertEquals(len(pi.get("items", [])), 1)
|
self.assertEquals(len(pi.get("items", [])), 1)
|
||||||
|
|
||||||
def test_make_purchase_invoice_with_terms(self):
|
def test_make_purchase_invoice_with_terms(self):
|
||||||
po = create_purchase_order(do_not_submit=True)
|
po = create_purchase_order(do_not_save=True)
|
||||||
|
|
||||||
self.assertRaises(frappe.ValidationError, make_purchase_invoice, po.name)
|
self.assertRaises(frappe.ValidationError, make_purchase_invoice, po.name)
|
||||||
|
|
||||||
po.update(
|
po.update(
|
||||||
{"payment_schedule": get_payment_terms(
|
{"payment_terms_template": "_Test Payment Term Template"}
|
||||||
"_Test Payment Term Template", po.transaction_date, po.grand_total
|
|
||||||
)}
|
|
||||||
)
|
)
|
||||||
|
|
||||||
po.save()
|
po.save()
|
||||||
@ -103,14 +101,15 @@ class TestPurchaseOrder(unittest.TestCase):
|
|||||||
self.assertEqual(po.payment_schedule[1].payment_amount, 2500.0)
|
self.assertEqual(po.payment_schedule[1].payment_amount, 2500.0)
|
||||||
self.assertEqual(po.payment_schedule[1].due_date, add_days(po.transaction_date, 30))
|
self.assertEqual(po.payment_schedule[1].due_date, add_days(po.transaction_date, 30))
|
||||||
pi = make_purchase_invoice(po.name)
|
pi = make_purchase_invoice(po.name)
|
||||||
|
pi.save()
|
||||||
|
|
||||||
self.assertEquals(pi.doctype, "Purchase Invoice")
|
self.assertEquals(pi.doctype, "Purchase Invoice")
|
||||||
self.assertEquals(len(pi.get("items", [])), 1)
|
self.assertEquals(len(pi.get("items", [])), 1)
|
||||||
|
|
||||||
self.assertEqual(pi.payment_schedule[0].payment_amount, 2500.0)
|
self.assertEqual(pi.payment_schedule[0].payment_amount, 2500.0)
|
||||||
self.assertEqual(pi.payment_schedule[0].due_date.strftime(DATE_FORMAT), po.transaction_date)
|
self.assertEqual(pi.payment_schedule[0].due_date, po.transaction_date)
|
||||||
self.assertEqual(pi.payment_schedule[1].payment_amount, 2500.0)
|
self.assertEqual(pi.payment_schedule[1].payment_amount, 2500.0)
|
||||||
self.assertEqual(pi.payment_schedule[1].due_date.strftime(DATE_FORMAT), add_days(po.transaction_date, 30))
|
self.assertEqual(pi.payment_schedule[1].due_date, add_days(po.transaction_date, 30))
|
||||||
|
|
||||||
def test_subcontracting(self):
|
def test_subcontracting(self):
|
||||||
po = create_purchase_order(item_code="_Test FG Item", is_subcontracted="Yes")
|
po = create_purchase_order(item_code="_Test FG Item", is_subcontracted="Yes")
|
||||||
|
@ -26,7 +26,9 @@ class AccountsController(TransactionBase):
|
|||||||
return self.__company_currency
|
return self.__company_currency
|
||||||
|
|
||||||
def onload(self):
|
def onload(self):
|
||||||
|
print("onload called:", self.get("__onload"))
|
||||||
self.get("__onload").make_payment_via_journal_entry = frappe.db.get_single_value('Accounts Settings', 'make_payment_via_journal_entry')
|
self.get("__onload").make_payment_via_journal_entry = frappe.db.get_single_value('Accounts Settings', 'make_payment_via_journal_entry')
|
||||||
|
self.set_payment_schedule()
|
||||||
|
|
||||||
def validate(self):
|
def validate(self):
|
||||||
if self.get("_action") and self._action != "update_after_submit":
|
if self.get("_action") and self._action != "update_after_submit":
|
||||||
@ -51,6 +53,8 @@ class AccountsController(TransactionBase):
|
|||||||
self.set_due_date()
|
self.set_due_date()
|
||||||
self.validate_due_date()
|
self.validate_due_date()
|
||||||
self.validate_advance_entries()
|
self.validate_advance_entries()
|
||||||
|
elif self.doctype in ("Quotation", "Purchase Order", "Sales Order"):
|
||||||
|
self.set_payment_schedule()
|
||||||
|
|
||||||
if self.meta.get_field("taxes_and_charges"):
|
if self.meta.get_field("taxes_and_charges"):
|
||||||
self.validate_enabled_taxes_and_charges()
|
self.validate_enabled_taxes_and_charges()
|
||||||
@ -608,13 +612,15 @@ class AccountsController(TransactionBase):
|
|||||||
self.remove(item)
|
self.remove(item)
|
||||||
|
|
||||||
def set_payment_schedule(self):
|
def set_payment_schedule(self):
|
||||||
due_date = self.due_date or get_due_date(self.posting_date)
|
posting_date = self.get("posting_date") or self.get("transaction_date")
|
||||||
|
date = self.get("due_date")
|
||||||
|
due_date = date or posting_date
|
||||||
|
|
||||||
if self.get("payment_terms_template"):
|
if self.get("payment_terms_template") and not self.get("payment_schedule"):
|
||||||
data = get_payment_terms(self.payment_terms_template, self.posting_date, self.grand_total)
|
data = get_payment_terms(self.payment_terms_template, posting_date, self.grand_total)
|
||||||
for item in data:
|
for item in data:
|
||||||
self.append("payment_schedule", item)
|
self.append("payment_schedule", item)
|
||||||
else:
|
elif not self.get("payment_schedule"):
|
||||||
data = dict(due_date=due_date, invoice_portion=100, payment_amount=self.grand_total)
|
data = dict(due_date=due_date, invoice_portion=100, payment_amount=self.grand_total)
|
||||||
self.append("payment_schedule", data)
|
self.append("payment_schedule", data)
|
||||||
|
|
||||||
|
@ -123,6 +123,11 @@ erpnext.TransactionController = erpnext.taxes_and_totals.extend({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(this.frm.fields_dict["payment_terms_template"]){
|
||||||
|
console.log("triggered");
|
||||||
|
this.frm.trigger("payment_terms_template");
|
||||||
|
}
|
||||||
|
|
||||||
if(this.frm.fields_dict["taxes"]) {
|
if(this.frm.fields_dict["taxes"]) {
|
||||||
this["taxes_remove"] = this.calculate_taxes_and_totals;
|
this["taxes_remove"] = this.calculate_taxes_and_totals;
|
||||||
}
|
}
|
||||||
|
@ -40,16 +40,15 @@ class TestQuotation(unittest.TestCase):
|
|||||||
quotation = frappe.copy_doc(test_records[0])
|
quotation = frappe.copy_doc(test_records[0])
|
||||||
quotation.transaction_date = nowdate()
|
quotation.transaction_date = nowdate()
|
||||||
quotation.valid_till = add_months(quotation.transaction_date, 1)
|
quotation.valid_till = add_months(quotation.transaction_date, 1)
|
||||||
quotation.insert()
|
|
||||||
quotation.update(
|
quotation.update(
|
||||||
{"payment_schedule": get_payment_terms(
|
{"payment_terms_template": "_Test Payment Term Template"}
|
||||||
"_Test Payment Term Template", quotation.transaction_date, quotation.grand_total
|
|
||||||
)}
|
|
||||||
)
|
)
|
||||||
|
quotation.insert()
|
||||||
|
|
||||||
self.assertRaises(frappe.ValidationError, make_sales_order, quotation.name)
|
self.assertRaises(frappe.ValidationError, make_sales_order, quotation.name)
|
||||||
quotation.save()
|
quotation.save()
|
||||||
quotation.submit()
|
quotation.submit()
|
||||||
|
|
||||||
self.assertEqual(quotation.payment_schedule[0].payment_amount, 8906.25)
|
self.assertEqual(quotation.payment_schedule[0].payment_amount, 8906.25)
|
||||||
self.assertEqual(quotation.payment_schedule[0].due_date, quotation.transaction_date)
|
self.assertEqual(quotation.payment_schedule[0].due_date, quotation.transaction_date)
|
||||||
self.assertEqual(quotation.payment_schedule[1].payment_amount, 8906.25)
|
self.assertEqual(quotation.payment_schedule[1].payment_amount, 8906.25)
|
||||||
@ -62,16 +61,19 @@ class TestQuotation(unittest.TestCase):
|
|||||||
self.assertEquals(sales_order.get("items")[0].doctype, "Sales Order Item")
|
self.assertEquals(sales_order.get("items")[0].doctype, "Sales Order Item")
|
||||||
self.assertEquals(sales_order.get("items")[0].prevdoc_docname, quotation.name)
|
self.assertEquals(sales_order.get("items")[0].prevdoc_docname, quotation.name)
|
||||||
self.assertEquals(sales_order.customer, "_Test Customer")
|
self.assertEquals(sales_order.customer, "_Test Customer")
|
||||||
self.assertEqual(sales_order.payment_schedule[0].payment_amount, 8906.25)
|
|
||||||
self.assertEqual(sales_order.payment_schedule[0].due_date.strftime(DATE_FORMAT), quotation.transaction_date)
|
|
||||||
self.assertEqual(sales_order.payment_schedule[1].payment_amount, 8906.25)
|
|
||||||
self.assertEqual(sales_order.payment_schedule[1].due_date.strftime(DATE_FORMAT), add_days(quotation.transaction_date, 30))
|
|
||||||
|
|
||||||
sales_order.delivery_date = "2014-01-01"
|
sales_order.delivery_date = "2014-01-01"
|
||||||
sales_order.naming_series = "_T-Quotation-"
|
sales_order.naming_series = "_T-Quotation-"
|
||||||
sales_order.transaction_date = nowdate()
|
sales_order.transaction_date = nowdate()
|
||||||
sales_order.insert()
|
sales_order.insert()
|
||||||
|
|
||||||
|
self.assertEqual(sales_order.payment_schedule[0].payment_amount, 8906.25)
|
||||||
|
self.assertEqual(sales_order.payment_schedule[0].due_date, quotation.transaction_date)
|
||||||
|
self.assertEqual(sales_order.payment_schedule[1].payment_amount, 8906.25)
|
||||||
|
self.assertEqual(
|
||||||
|
sales_order.payment_schedule[1].due_date, add_days(quotation.transaction_date, 30)
|
||||||
|
)
|
||||||
|
|
||||||
def test_valid_till(self):
|
def test_valid_till(self):
|
||||||
from erpnext.selling.doctype.quotation.quotation import make_sales_order
|
from erpnext.selling.doctype.quotation.quotation import make_sales_order
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user