2023-07-28 15:32:21 +00:00
|
|
|
import frappe
|
2023-08-21 09:24:03 +00:00
|
|
|
from frappe import qb
|
2023-07-28 15:32:21 +00:00
|
|
|
|
|
|
|
from erpnext.stock.doctype.item.test_item import create_item
|
|
|
|
|
|
|
|
|
|
|
|
class AccountsTestMixin:
|
2023-08-08 14:57:12 +00:00
|
|
|
def create_customer(self, customer_name="_Test Customer", currency=None):
|
2023-07-28 15:32:21 +00:00
|
|
|
if not frappe.db.exists("Customer", customer_name):
|
|
|
|
customer = frappe.new_doc("Customer")
|
|
|
|
customer.customer_name = customer_name
|
|
|
|
customer.type = "Individual"
|
|
|
|
|
|
|
|
if currency:
|
|
|
|
customer.default_currency = currency
|
|
|
|
customer.save()
|
|
|
|
self.customer = customer.name
|
|
|
|
else:
|
|
|
|
self.customer = customer_name
|
|
|
|
|
2023-08-08 14:57:12 +00:00
|
|
|
def create_supplier(self, supplier_name="_Test Supplier", currency=None):
|
2023-07-28 15:32:21 +00:00
|
|
|
if not frappe.db.exists("Supplier", supplier_name):
|
|
|
|
supplier = frappe.new_doc("Supplier")
|
|
|
|
supplier.supplier_name = supplier_name
|
|
|
|
supplier.supplier_type = "Individual"
|
|
|
|
supplier.supplier_group = "Local"
|
|
|
|
|
|
|
|
if currency:
|
|
|
|
supplier.default_currency = currency
|
|
|
|
supplier.save()
|
|
|
|
self.supplier = supplier.name
|
|
|
|
else:
|
|
|
|
self.supplier = supplier_name
|
|
|
|
|
2023-08-08 14:57:12 +00:00
|
|
|
def create_item(self, item_name="_Test Item", is_stock=0, warehouse=None, company=None):
|
2023-07-28 15:32:21 +00:00
|
|
|
item = create_item(item_name, is_stock_item=is_stock, warehouse=warehouse, company=company)
|
|
|
|
self.item = item.name
|
|
|
|
|
|
|
|
def create_company(self, company_name="_Test Company", abbr="_TC"):
|
|
|
|
self.company_abbr = abbr
|
|
|
|
if frappe.db.exists("Company", company_name):
|
|
|
|
company = frappe.get_doc("Company", company_name)
|
|
|
|
else:
|
|
|
|
company = frappe.get_doc(
|
|
|
|
{
|
|
|
|
"doctype": "Company",
|
|
|
|
"company_name": company_name,
|
|
|
|
"country": "India",
|
|
|
|
"default_currency": "INR",
|
|
|
|
"create_chart_of_accounts_based_on": "Standard Template",
|
|
|
|
"chart_of_accounts": "Standard",
|
|
|
|
}
|
|
|
|
)
|
|
|
|
company = company.save()
|
|
|
|
|
|
|
|
self.company = company.name
|
|
|
|
self.cost_center = company.cost_center
|
|
|
|
self.warehouse = "Stores - " + abbr
|
|
|
|
self.finished_warehouse = "Finished Goods - " + abbr
|
|
|
|
self.income_account = "Sales - " + abbr
|
|
|
|
self.expense_account = "Cost of Goods Sold - " + abbr
|
|
|
|
self.debit_to = "Debtors - " + abbr
|
|
|
|
self.cash = "Cash - " + abbr
|
|
|
|
self.creditors = "Creditors - " + abbr
|
2023-08-08 14:57:12 +00:00
|
|
|
self.retained_earnings = "Retained Earnings - " + abbr
|
2023-07-28 15:32:21 +00:00
|
|
|
|
2023-08-08 14:57:12 +00:00
|
|
|
# Deferred revenue, expense and bank accounts
|
|
|
|
other_accounts = [
|
|
|
|
frappe._dict(
|
|
|
|
{
|
|
|
|
"attribute_name": "deferred_revenue",
|
|
|
|
"account_name": "Deferred Revenue",
|
|
|
|
"parent_account": "Current Liabilities - " + abbr,
|
|
|
|
}
|
|
|
|
),
|
|
|
|
frappe._dict(
|
2023-07-28 15:32:21 +00:00
|
|
|
{
|
2023-08-08 14:57:12 +00:00
|
|
|
"attribute_name": "deferred_expense",
|
|
|
|
"account_name": "Deferred Expense",
|
|
|
|
"parent_account": "Current Assets - " + abbr,
|
|
|
|
}
|
|
|
|
),
|
|
|
|
frappe._dict(
|
|
|
|
{
|
|
|
|
"attribute_name": "bank",
|
2023-07-28 15:32:21 +00:00
|
|
|
"account_name": "HDFC",
|
|
|
|
"parent_account": "Bank Accounts - " + abbr,
|
|
|
|
}
|
2023-08-08 14:57:12 +00:00
|
|
|
),
|
|
|
|
]
|
|
|
|
for acc in other_accounts:
|
|
|
|
acc_name = acc.account_name + " - " + abbr
|
|
|
|
if frappe.db.exists("Account", acc_name):
|
|
|
|
setattr(self, acc.attribute_name, acc_name)
|
|
|
|
else:
|
|
|
|
new_acc = frappe.get_doc(
|
|
|
|
{
|
|
|
|
"doctype": "Account",
|
|
|
|
"account_name": acc.account_name,
|
|
|
|
"parent_account": acc.parent_account,
|
|
|
|
"company": self.company,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
new_acc.save()
|
|
|
|
setattr(self, acc.attribute_name, new_acc.name)
|
2023-08-21 09:24:03 +00:00
|
|
|
|
2023-08-24 15:16:33 +00:00
|
|
|
def create_usd_receivable_account(self):
|
|
|
|
account_name = "Debtors USD"
|
|
|
|
if not frappe.db.get_value(
|
|
|
|
"Account", filters={"account_name": account_name, "company": self.company}
|
|
|
|
):
|
|
|
|
acc = frappe.new_doc("Account")
|
|
|
|
acc.account_name = account_name
|
|
|
|
acc.parent_account = "Accounts Receivable - " + self.company_abbr
|
|
|
|
acc.company = self.company
|
|
|
|
acc.account_currency = "USD"
|
|
|
|
acc.account_type = "Receivable"
|
|
|
|
acc.insert()
|
|
|
|
else:
|
|
|
|
name = frappe.db.get_value(
|
|
|
|
"Account",
|
|
|
|
filters={"account_name": account_name, "company": self.company},
|
|
|
|
fieldname="name",
|
|
|
|
pluck=True,
|
|
|
|
)
|
|
|
|
acc = frappe.get_doc("Account", name)
|
|
|
|
self.debtors_usd = acc.name
|
|
|
|
|
2023-09-02 07:38:08 +00:00
|
|
|
def create_usd_payable_account(self):
|
|
|
|
account_name = "Creditors USD"
|
|
|
|
if not frappe.db.get_value(
|
|
|
|
"Account", filters={"account_name": account_name, "company": self.company}
|
|
|
|
):
|
|
|
|
acc = frappe.new_doc("Account")
|
|
|
|
acc.account_name = account_name
|
|
|
|
acc.parent_account = "Accounts Payable - " + self.company_abbr
|
|
|
|
acc.company = self.company
|
|
|
|
acc.account_currency = "USD"
|
|
|
|
acc.account_type = "Payable"
|
|
|
|
acc.insert()
|
|
|
|
else:
|
|
|
|
name = frappe.db.get_value(
|
|
|
|
"Account",
|
|
|
|
filters={"account_name": account_name, "company": self.company},
|
|
|
|
fieldname="name",
|
|
|
|
pluck=True,
|
|
|
|
)
|
|
|
|
acc = frappe.get_doc("Account", name)
|
|
|
|
self.creditors_usd = acc.name
|
|
|
|
|
2023-08-21 09:24:03 +00:00
|
|
|
def clear_old_entries(self):
|
|
|
|
doctype_list = [
|
|
|
|
"GL Entry",
|
|
|
|
"Payment Ledger Entry",
|
|
|
|
"Sales Invoice",
|
|
|
|
"Purchase Invoice",
|
|
|
|
"Payment Entry",
|
|
|
|
"Journal Entry",
|
2023-08-24 15:16:33 +00:00
|
|
|
"Sales Order",
|
|
|
|
"Exchange Rate Revaluation",
|
2023-09-15 09:14:07 +00:00
|
|
|
"Bank Account",
|
|
|
|
"Bank Transaction",
|
2023-08-21 09:24:03 +00:00
|
|
|
]
|
|
|
|
for doctype in doctype_list:
|
|
|
|
qb.from_(qb.DocType(doctype)).delete().where(qb.DocType(doctype).company == self.company).run()
|