mirror of
https://github.com/frappe/erpnext.git
synced 2026-03-24 21:52:21 +01:00
2956 lines
84 KiB
Python
2956 lines
84 KiB
Python
# Copyright (c) 2021, Frappe Technologies Pvt. Ltd. and Contributors
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
import unittest
|
|
from contextlib import contextmanager
|
|
from typing import Any, NewType
|
|
|
|
import frappe
|
|
from frappe import _
|
|
from frappe.core.doctype.report.report import get_report_module_dotted_path
|
|
from frappe.tests.utils import load_test_records_for
|
|
from frappe.utils import now_datetime, today
|
|
|
|
ReportFilters = dict[str, Any]
|
|
ReportName = NewType("ReportName", str)
|
|
|
|
|
|
def create_test_contact_and_address():
|
|
frappe.db.sql("delete from tabContact")
|
|
frappe.db.sql("delete from `tabContact Email`")
|
|
frappe.db.sql("delete from `tabContact Phone`")
|
|
frappe.db.sql("delete from tabAddress")
|
|
frappe.db.sql("delete from `tabDynamic Link`")
|
|
|
|
frappe.get_doc(
|
|
{
|
|
"doctype": "Address",
|
|
"address_title": "_Test Address for Customer",
|
|
"address_type": "Office",
|
|
"address_line1": "Station Road",
|
|
"city": "_Test City",
|
|
"state": "Test State",
|
|
"country": "India",
|
|
"links": [{"link_doctype": "Customer", "link_name": "_Test Customer"}],
|
|
}
|
|
).insert()
|
|
|
|
contact = frappe.get_doc(
|
|
{
|
|
"doctype": "Contact",
|
|
"first_name": "_Test Contact for _Test Customer",
|
|
"links": [{"link_doctype": "Customer", "link_name": "_Test Customer"}],
|
|
}
|
|
)
|
|
contact.add_email("test_contact_customer@example.com", is_primary=True)
|
|
contact.add_phone("+91 0000000000", is_primary_phone=True)
|
|
contact.insert()
|
|
|
|
contact_two = frappe.get_doc(
|
|
{
|
|
"doctype": "Contact",
|
|
"first_name": "_Test Contact 2 for _Test Customer",
|
|
"links": [{"link_doctype": "Customer", "link_name": "_Test Customer"}],
|
|
}
|
|
)
|
|
contact_two.add_email("test_contact_two_customer@example.com", is_primary=True)
|
|
contact_two.add_phone("+92 0000000000", is_primary_phone=True)
|
|
contact_two.insert()
|
|
|
|
|
|
def execute_script_report(
|
|
report_name: ReportName,
|
|
module: str,
|
|
filters: ReportFilters,
|
|
default_filters: ReportFilters | None = None,
|
|
optional_filters: ReportFilters | None = None,
|
|
):
|
|
"""Util for testing execution of a report with specified filters.
|
|
|
|
Tests the execution of report with default_filters + filters.
|
|
Tests the execution using optional_filters one at a time.
|
|
|
|
Args:
|
|
report_name: Human readable name of report (unscrubbed)
|
|
module: module to which report belongs to
|
|
filters: specific values for filters
|
|
default_filters: default values for filters such as company name.
|
|
optional_filters: filters which should be tested one at a time in addition to default filters.
|
|
"""
|
|
|
|
if default_filters is None:
|
|
default_filters = {}
|
|
|
|
test_filters = []
|
|
report_execute_fn = frappe.get_attr(get_report_module_dotted_path(module, report_name) + ".execute")
|
|
report_filters = frappe._dict(default_filters).copy().update(filters)
|
|
|
|
test_filters.append(report_filters)
|
|
|
|
if optional_filters:
|
|
for key, value in optional_filters.items():
|
|
test_filters.append(report_filters.copy().update({key: value}))
|
|
|
|
for test_filter in test_filters:
|
|
try:
|
|
report_execute_fn(test_filter)
|
|
except Exception:
|
|
print(f"Report failed to execute with filters: {test_filter}")
|
|
raise
|
|
|
|
|
|
def if_lending_app_installed(function):
|
|
"""Decorator to check if lending app is installed"""
|
|
|
|
def wrapper(*args, **kwargs):
|
|
if "lending" in frappe.get_installed_apps():
|
|
return function(*args, **kwargs)
|
|
return
|
|
|
|
return wrapper
|
|
|
|
|
|
def if_lending_app_not_installed(function):
|
|
"""Decorator to check if lending app is not installed"""
|
|
|
|
def wrapper(*args, **kwargs):
|
|
if "lending" not in frappe.get_installed_apps():
|
|
return function(*args, **kwargs)
|
|
return
|
|
|
|
return wrapper
|
|
|
|
|
|
class ERPNextTestSuite(unittest.TestCase):
|
|
@classmethod
|
|
def registerAs(cls, _as):
|
|
def decorator(cm_func):
|
|
setattr(cls, cm_func.__name__, _as(cm_func))
|
|
return cm_func
|
|
|
|
return decorator
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
# initilize global test records attribute
|
|
if not hasattr(cls, "globalTestRecords"):
|
|
cls.globalTestRecords = {}
|
|
|
|
cls.make_presets()
|
|
cls.make_persistent_master_data()
|
|
|
|
@classmethod
|
|
def load_test_records(cls, doctype):
|
|
if doctype not in cls.globalTestRecords:
|
|
records = load_test_records_for(doctype)
|
|
cls.globalTestRecords[doctype] = records[doctype]
|
|
|
|
@classmethod
|
|
def make_presets(cls):
|
|
from frappe.desk.page.setup_wizard.install_fixtures import update_genders, update_salutations
|
|
|
|
from erpnext.setup.setup_wizard.operations.install_fixtures import (
|
|
add_uom_data,
|
|
get_preset_records,
|
|
get_sale_stages,
|
|
)
|
|
|
|
update_genders()
|
|
update_salutations()
|
|
|
|
records = get_preset_records("India")
|
|
presets_primary_key_map = {
|
|
"Address Template": "country",
|
|
"Item Group": "item_group_name",
|
|
"Territory": "territory_name",
|
|
"Customer Group": "customer_group_name",
|
|
"Supplier Group": "supplier_group_name",
|
|
"Sales Person": "sales_person_name",
|
|
"Mode of Payment": "mode_of_payment",
|
|
"Activity Type": "activity_type",
|
|
"Item Attribute": "attribute_name",
|
|
"Party Type": "party_type",
|
|
"Project Type": "project_type",
|
|
"Print Heading": "print_heading",
|
|
"Share Type": "title",
|
|
"Market Segment": "market_segment",
|
|
"Workstation Operating Component": "component_name",
|
|
}
|
|
for x in records:
|
|
dt = x.get("doctype")
|
|
dn = x.get("name") or x.get(presets_primary_key_map.get(dt))
|
|
|
|
if not frappe.db.exists(dt, dn):
|
|
doc = frappe.get_doc(x)
|
|
doc.insert()
|
|
|
|
add_uom_data()
|
|
# add sale stages
|
|
for sales_stage in get_sale_stages():
|
|
if not frappe.db.exists("Sales Stage", {"stage_name": sales_stage.get("stage_name")}):
|
|
frappe.get_doc(sales_stage).insert()
|
|
|
|
from erpnext.buying.doctype.supplier_scorecard.supplier_scorecard import (
|
|
get_default_scorecard_standing,
|
|
get_default_scorecard_variables,
|
|
)
|
|
|
|
for x in get_default_scorecard_variables():
|
|
x["doctype"] = "Supplier Scorecard Variable"
|
|
if not frappe.db.exists("Supplier Scorecard Variable", {"name": x.get("variable_label")}):
|
|
frappe.get_doc(x).insert()
|
|
for x in get_default_scorecard_standing():
|
|
x["doctype"] = "Supplier Scorecard Standing"
|
|
if not frappe.db.exists("Supplier Scorecard Standing", {"name": x.get("standing_name")}):
|
|
frappe.get_doc(x).insert()
|
|
|
|
frappe.db.commit()
|
|
|
|
@classmethod
|
|
def make_persistent_master_data(cls):
|
|
cls.make_fiscal_year()
|
|
cls.make_holiday_list()
|
|
cls.make_company()
|
|
cls.make_test_account()
|
|
cls.make_supplier_group()
|
|
cls.make_payment_term()
|
|
cls.make_payment_terms_template()
|
|
cls.make_tax_category()
|
|
cls.make_account()
|
|
cls.make_supplier()
|
|
cls.make_role()
|
|
cls.make_department()
|
|
cls.make_territory()
|
|
cls.make_customer_group()
|
|
cls.make_customer()
|
|
cls.make_user()
|
|
cls.make_cost_center()
|
|
cls.make_warehouse()
|
|
cls.make_uom()
|
|
cls.make_item_tax_template()
|
|
cls.make_item_group()
|
|
cls.make_item_attribute()
|
|
cls.make_asset_maintenance_team()
|
|
cls.make_asset_category()
|
|
cls._make_item()
|
|
cls.make_product_bundle()
|
|
cls.make_location()
|
|
cls.make_price_list()
|
|
cls.make_item_price()
|
|
cls.make_loyalty_program()
|
|
cls.make_shareholder()
|
|
cls.make_sales_taxes_template()
|
|
cls.make_workstation()
|
|
cls.make_operation()
|
|
cls.make_bom()
|
|
cls.make_quality_inspection_param()
|
|
cls.make_quality_inspection_template()
|
|
cls.make_employees()
|
|
cls.update_selling_settings()
|
|
cls.update_stock_settings()
|
|
cls.update_system_settings()
|
|
|
|
frappe.db.commit()
|
|
|
|
@classmethod
|
|
def update_system_settings(cls):
|
|
system_settings = frappe.get_doc("System Settings")
|
|
system_settings.time_zone = "Asia/Kolkata"
|
|
system_settings.language = "en"
|
|
system_settings.currency_precision = system_settings.float_precision = 2
|
|
system_settings.rounding_method = "Banker's Rounding"
|
|
system_settings.save()
|
|
|
|
@classmethod
|
|
def update_selling_settings(cls):
|
|
selling_settings = frappe.get_doc("Selling Settings")
|
|
selling_settings.selling_price_list = "Standard Selling"
|
|
selling_settings.save()
|
|
|
|
@classmethod
|
|
def update_stock_settings(cls):
|
|
stock_settings = frappe.get_doc("Stock Settings")
|
|
stock_settings.item_naming_by = "Item Code"
|
|
stock_settings.valuation_method = "FIFO"
|
|
stock_settings.default_warehouse = frappe.db.get_value("Warehouse", {"warehouse_name": _("Stores")})
|
|
stock_settings.stock_uom = "Nos"
|
|
stock_settings.auto_indent = 1
|
|
stock_settings.auto_insert_price_list_rate_if_missing = 1
|
|
stock_settings.update_price_list_based_on = "Rate"
|
|
stock_settings.set_qty_in_transactions_based_on_serial_no_input = 1
|
|
stock_settings.enable_serial_and_batch_no_for_item = 1
|
|
stock_settings.save()
|
|
|
|
@classmethod
|
|
def make_price_list(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Price List",
|
|
"price_list_name": _("Standard Buying"),
|
|
"enabled": 1,
|
|
"buying": 1,
|
|
"selling": 0,
|
|
"currency": "INR",
|
|
},
|
|
{
|
|
"doctype": "Price List",
|
|
"price_list_name": _("Standard Selling"),
|
|
"enabled": 1,
|
|
"buying": 0,
|
|
"selling": 1,
|
|
"currency": "INR",
|
|
},
|
|
{
|
|
"buying": 1,
|
|
"currency": "INR",
|
|
"doctype": "Price List",
|
|
"enabled": 1,
|
|
"price_not_uom_dependant": 1,
|
|
"price_list_name": "_Test Price List",
|
|
"selling": 1,
|
|
},
|
|
{
|
|
"buying": 1,
|
|
"currency": "INR",
|
|
"doctype": "Price List",
|
|
"enabled": 1,
|
|
"price_list_name": "_Test Price List 2",
|
|
"selling": 1,
|
|
},
|
|
{
|
|
"buying": 1,
|
|
"currency": "INR",
|
|
"doctype": "Price List",
|
|
"enabled": 1,
|
|
"price_list_name": "_Test Price List India",
|
|
"selling": 1,
|
|
},
|
|
{
|
|
"buying": 1,
|
|
"currency": "USD",
|
|
"doctype": "Price List",
|
|
"enabled": 1,
|
|
"price_list_name": "_Test Price List Rest of the World",
|
|
"selling": 1,
|
|
},
|
|
{
|
|
"buying": 0,
|
|
"currency": "USD",
|
|
"doctype": "Price List",
|
|
"enabled": 1,
|
|
"price_list_name": "_Test Selling Price List",
|
|
"selling": 1,
|
|
},
|
|
{
|
|
"buying": 1,
|
|
"currency": "USD",
|
|
"doctype": "Price List",
|
|
"enabled": 1,
|
|
"price_list_name": "_Test Buying Price List",
|
|
"selling": 0,
|
|
},
|
|
]
|
|
cls.price_list = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Price List",
|
|
{
|
|
"price_list_name": x.get("price_list_name"),
|
|
"enabled": x.get("enabled"),
|
|
"selling": x.get("selling"),
|
|
"buying": x.get("buying"),
|
|
"currency": x.get("currency"),
|
|
},
|
|
):
|
|
cls.price_list.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.price_list.append(
|
|
frappe.get_doc(
|
|
"Price List",
|
|
{
|
|
"price_list_name": x.get("price_list_name"),
|
|
"enabled": x.get("enabled"),
|
|
"selling": x.get("selling"),
|
|
"buying": x.get("buying"),
|
|
"currency": x.get("currency"),
|
|
},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_monthly_distribution(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Monthly Distribution",
|
|
"distribution_id": "_Test Distribution",
|
|
"fiscal_year": "_Test Fiscal Year 2013",
|
|
"percentages": [
|
|
{"month": "January", "percentage_allocation": "8"},
|
|
{"month": "February", "percentage_allocation": "8"},
|
|
{"month": "March", "percentage_allocation": "8"},
|
|
{"month": "April", "percentage_allocation": "8"},
|
|
{"month": "May", "percentage_allocation": "8"},
|
|
{"month": "June", "percentage_allocation": "8"},
|
|
{"month": "July", "percentage_allocation": "8"},
|
|
{"month": "August", "percentage_allocation": "8"},
|
|
{"month": "September", "percentage_allocation": "8"},
|
|
{"month": "October", "percentage_allocation": "8"},
|
|
{"month": "November", "percentage_allocation": "10"},
|
|
{"month": "December", "percentage_allocation": "10"},
|
|
],
|
|
}
|
|
]
|
|
cls.monthly_distribution = []
|
|
for x in records:
|
|
if not frappe.db.exists("Monthly Distribution", {"distribution_id": x.get("distribution_id")}):
|
|
cls.monthly_distribution.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.monthly_distribution.append(
|
|
frappe.get_doc("Monthly Distribution", {"distribution_id": x.get("distribution_id")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_projects(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Project",
|
|
"company": "_Test Company",
|
|
"project_name": "_Test Project",
|
|
"status": "Open",
|
|
}
|
|
]
|
|
|
|
cls.projects = []
|
|
for x in records:
|
|
if not frappe.db.exists("Project", {"project_name": x.get("project_name")}):
|
|
cls.projects.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.projects.append(frappe.get_doc("Project", {"project_name": x.get("project_name")}))
|
|
|
|
@classmethod
|
|
def make_customer_group(cls):
|
|
records = [
|
|
{
|
|
"customer_group_name": "_Test Customer Group",
|
|
"doctype": "Customer Group",
|
|
"is_group": 0,
|
|
"parent_customer_group": "All Customer Groups",
|
|
},
|
|
{
|
|
"customer_group_name": "_Test Customer Group 1",
|
|
"doctype": "Customer Group",
|
|
"is_group": 0,
|
|
"parent_customer_group": "All Customer Groups",
|
|
},
|
|
]
|
|
cls.customer_group = []
|
|
for x in records:
|
|
if not frappe.db.exists("Customer Group", {"customer_group_name": x.get("customer_group_name")}):
|
|
cls.customer_group.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.customer_group.append(
|
|
frappe.get_doc("Customer Group", {"customer_group_name": x.get("customer_group_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_territory(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Territory",
|
|
"is_group": 0,
|
|
"parent_territory": "All Territories",
|
|
"territory_name": "_Test Territory",
|
|
},
|
|
{
|
|
"doctype": "Territory",
|
|
"is_group": 1,
|
|
"parent_territory": "All Territories",
|
|
"territory_name": "_Test Territory India",
|
|
},
|
|
{
|
|
"doctype": "Territory",
|
|
"is_group": 0,
|
|
"parent_territory": "_Test Territory India",
|
|
"territory_name": "_Test Territory Maharashtra",
|
|
},
|
|
{
|
|
"doctype": "Territory",
|
|
"is_group": 0,
|
|
"parent_territory": "All Territories",
|
|
"territory_name": "_Test Territory Rest Of The World",
|
|
},
|
|
{
|
|
"doctype": "Territory",
|
|
"is_group": 0,
|
|
"parent_territory": "All Territories",
|
|
"territory_name": "_Test Territory United States",
|
|
},
|
|
]
|
|
cls.territories = []
|
|
for x in records:
|
|
if not frappe.db.exists("Territory", {"territory_name": x.get("territory_name")}):
|
|
cls.territories.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.territories.append(
|
|
frappe.get_doc("Territory", {"territory_name": x.get("territory_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_department(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Department",
|
|
"department_name": "_Test Department",
|
|
"company": "_Test Company",
|
|
"parent_department": "All Departments",
|
|
},
|
|
{
|
|
"doctype": "Department",
|
|
"department_name": "_Test Department 1",
|
|
"company": "_Test Company",
|
|
"parent_department": "All Departments",
|
|
},
|
|
]
|
|
cls.department = []
|
|
for x in records:
|
|
if not frappe.db.exists("Department", {"department_name": x.get("department_name")}):
|
|
cls.department.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.department.append(
|
|
frappe.get_doc("Department", {"department_name": x.get("department_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_role(cls):
|
|
records = [
|
|
{"doctype": "Role", "role_name": "_Test Role", "desk_access": 1},
|
|
{"doctype": "Role", "role_name": "_Test Role 2", "desk_access": 1},
|
|
{"doctype": "Role", "role_name": "_Test Role 3", "desk_access": 1},
|
|
{"doctype": "Role", "role_name": "_Test Role 4", "desk_access": 0},
|
|
{"doctype": "Role", "role_name": "Technician"},
|
|
]
|
|
cls.roles = []
|
|
for x in records:
|
|
if not frappe.db.exists("Role", {"role_name": x.get("role_name")}):
|
|
cls.roles.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.roles.append(frappe.get_doc("Role", {"role_name": x.get("role_name")}))
|
|
|
|
@classmethod
|
|
def make_user(cls):
|
|
records = [
|
|
{
|
|
"doctype": "User",
|
|
"email": "test@example.com",
|
|
"enabled": 1,
|
|
"first_name": "_Test",
|
|
"new_password": "Eastern_43A1W",
|
|
"roles": [
|
|
{"doctype": "Has Role", "parentfield": "roles", "role": "_Test Role"},
|
|
{"doctype": "Has Role", "parentfield": "roles", "role": "System Manager"},
|
|
],
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "test1@example.com",
|
|
"first_name": "_Test1",
|
|
"new_password": "Eastern_43A1W",
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "test2@example.com",
|
|
"first_name": "_Test2",
|
|
"new_password": "Eastern_43A1W",
|
|
"enabled": 1,
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "test3@example.com",
|
|
"first_name": "_Test3",
|
|
"new_password": "Eastern_43A1W",
|
|
"enabled": 1,
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "test4@example.com",
|
|
"first_name": "_Test4",
|
|
"new_password": "Eastern_43A1W",
|
|
"enabled": 1,
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "test'5@example.com",
|
|
"first_name": "_Test'5",
|
|
"new_password": "Eastern_43A1W",
|
|
"enabled": 1,
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "testperm@example.com",
|
|
"first_name": "_Test Perm",
|
|
"new_password": "Eastern_43A1W",
|
|
"enabled": 1,
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "testdelete@example.com",
|
|
"enabled": 1,
|
|
"first_name": "_Test",
|
|
"new_password": "Eastern_43A1W",
|
|
"roles": [
|
|
{"doctype": "Has Role", "parentfield": "roles", "role": "_Test Role 2"},
|
|
{"doctype": "Has Role", "parentfield": "roles", "role": "System Manager"},
|
|
],
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "testpassword@example.com",
|
|
"enabled": 1,
|
|
"first_name": "_Test",
|
|
"new_password": "Eastern_43A1W",
|
|
"roles": [{"doctype": "Has Role", "parentfield": "roles", "role": "System Manager"}],
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "marcus@abc.com",
|
|
"first_name": "marcus@abc.com",
|
|
"new_password": "password",
|
|
"roles": [{"doctype": "Has Role", "role": "Technician"}],
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "thalia@abc.com",
|
|
"first_name": "thalia@abc.com",
|
|
"new_password": "password",
|
|
"roles": [{"doctype": "Has Role", "role": "Technician"}],
|
|
},
|
|
{
|
|
"doctype": "User",
|
|
"email": "mathias@abc.com",
|
|
"first_name": "mathias@abc.com",
|
|
"new_password": "password",
|
|
"roles": [{"doctype": "Has Role", "role": "Technician"}],
|
|
},
|
|
]
|
|
cls.users = []
|
|
for x in records:
|
|
if not frappe.db.exists("User", {"email": x.get("email")}):
|
|
user = frappe.get_doc(x)
|
|
user.flags.no_welcome_mail = True
|
|
cls.users.append(user.insert())
|
|
else:
|
|
cls.users.append(frappe.get_doc("User", {"email": x.get("email")}))
|
|
|
|
@classmethod
|
|
def make_employees(cls):
|
|
records = [
|
|
{
|
|
"company": "_Test Company",
|
|
"date_of_birth": "1980-01-01",
|
|
"date_of_joining": "2010-01-01",
|
|
"department": "_Test Department - _TC",
|
|
"doctype": "Employee",
|
|
"first_name": "_Test Employee",
|
|
"gender": "Female",
|
|
"naming_series": "_T-Employee-",
|
|
"status": "Active",
|
|
"user_id": "test@example.com",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"date_of_birth": "1980-01-01",
|
|
"date_of_joining": "2010-01-01",
|
|
"department": "_Test Department 1 - _TC",
|
|
"doctype": "Employee",
|
|
"first_name": "_Test Employee 1",
|
|
"gender": "Male",
|
|
"naming_series": "_T-Employee-",
|
|
"status": "Active",
|
|
"user_id": "test1@example.com",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"date_of_birth": "1980-01-01",
|
|
"date_of_joining": "2010-01-01",
|
|
"department": "_Test Department 1 - _TC",
|
|
"doctype": "Employee",
|
|
"first_name": "_Test Employee 2",
|
|
"gender": "Male",
|
|
"naming_series": "_T-Employee-",
|
|
"status": "Active",
|
|
"user_id": "test2@example.com",
|
|
},
|
|
]
|
|
cls.employees = []
|
|
for x in records:
|
|
if not frappe.db.exists("Employee", {"first_name": x.get("first_name")}):
|
|
cls.employees.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.employees.append(frappe.get_doc("Employee", {"first_name": x.get("first_name")}))
|
|
|
|
@classmethod
|
|
def make_sales_person(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Sales Person",
|
|
"employee": "_T-Employee-00001",
|
|
"is_group": 0,
|
|
"parent_sales_person": "Sales Team",
|
|
"sales_person_name": "_Test Sales Person",
|
|
},
|
|
{
|
|
"doctype": "Sales Person",
|
|
"employee": "_T-Employee-00002",
|
|
"is_group": 0,
|
|
"parent_sales_person": "Sales Team",
|
|
"sales_person_name": "_Test Sales Person 1",
|
|
},
|
|
{
|
|
"doctype": "Sales Person",
|
|
"employee": "_T-Employee-00003",
|
|
"is_group": 0,
|
|
"parent_sales_person": "Sales Team",
|
|
"sales_person_name": "_Test Sales Person 2",
|
|
},
|
|
]
|
|
cls.sales_person = []
|
|
for x in records:
|
|
if not frappe.db.exists("Sales Person", {"sales_person_name": x.get("sales_person_name")}):
|
|
cls.sales_person.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.sales_person.append(
|
|
frappe.get_doc("Sales Person", {"sales_person_name": x.get("sales_person_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_leads(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Lead",
|
|
"email_id": "test_lead@example.com",
|
|
"lead_name": "_Test Lead",
|
|
"status": "Open",
|
|
"territory": "_Test Territory",
|
|
"naming_series": "_T-Lead-",
|
|
},
|
|
{
|
|
"doctype": "Lead",
|
|
"email_id": "test_lead1@example.com",
|
|
"lead_name": "_Test Lead 1",
|
|
"status": "Open",
|
|
"naming_series": "_T-Lead-",
|
|
},
|
|
{
|
|
"doctype": "Lead",
|
|
"email_id": "test_lead2@example.com",
|
|
"lead_name": "_Test Lead 2",
|
|
"status": "Lead",
|
|
"naming_series": "_T-Lead-",
|
|
},
|
|
{
|
|
"doctype": "Lead",
|
|
"email_id": "test_lead3@example.com",
|
|
"lead_name": "_Test Lead 3",
|
|
"status": "Converted",
|
|
"naming_series": "_T-Lead-",
|
|
},
|
|
{
|
|
"doctype": "Lead",
|
|
"email_id": "test_lead4@example.com",
|
|
"lead_name": "_Test Lead 4",
|
|
"company_name": "_Test Lead 4",
|
|
"status": "Open",
|
|
"naming_series": "_T-Lead-",
|
|
},
|
|
]
|
|
cls.leads = []
|
|
for x in records:
|
|
if not frappe.db.exists("Lead", {"email_id": x.get("email_id")}):
|
|
cls.leads.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.leads.append(frappe.get_doc("Lead", {"email_id": x.get("email_id")}))
|
|
|
|
@classmethod
|
|
def make_holiday_list(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Holiday List",
|
|
"from_date": "2013-01-01",
|
|
"to_date": "2013-12-31",
|
|
"holidays": [
|
|
{"description": "New Year", "holiday_date": "2013-01-01"},
|
|
{"description": "Republic Day", "holiday_date": "2013-01-26"},
|
|
{"description": "Test Holiday", "holiday_date": "2013-02-01"},
|
|
],
|
|
"holiday_list_name": "_Test Holiday List",
|
|
}
|
|
]
|
|
cls.holiday_list = []
|
|
for x in records:
|
|
if not frappe.db.exists("Holiday List", {"holiday_list_name": x.get("holiday_list_name")}):
|
|
cls.holiday_list.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.holiday_list.append(
|
|
frappe.get_doc("Holiday List", {"holiday_list_name": x.get("holiday_list_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_company(cls):
|
|
records = [
|
|
{
|
|
"abbr": "_TC",
|
|
"company_name": "_Test Company",
|
|
"country": "India",
|
|
"default_currency": "INR",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
"allow_account_creation_against_child_company": 1,
|
|
},
|
|
{
|
|
"abbr": "_TC1",
|
|
"company_name": "_Test Company 1",
|
|
"country": "United States",
|
|
"default_currency": "USD",
|
|
"doctype": "Company",
|
|
"domain": "Retail",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"abbr": "_TC2",
|
|
"company_name": "_Test Company 2",
|
|
"default_currency": "EUR",
|
|
"country": "Germany",
|
|
"doctype": "Company",
|
|
"domain": "Retail",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"abbr": "_TC3",
|
|
"company_name": "_Test Company 3",
|
|
"is_group": 1,
|
|
"country": "Pakistan",
|
|
"default_currency": "INR",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"abbr": "_TC4",
|
|
"company_name": "_Test Company 4",
|
|
"parent_company": "_Test Company 3",
|
|
"is_group": 1,
|
|
"country": "Pakistan",
|
|
"default_currency": "INR",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"abbr": "_TC5",
|
|
"company_name": "_Test Company 5",
|
|
"parent_company": "_Test Company 4",
|
|
"country": "Pakistan",
|
|
"default_currency": "INR",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"abbr": "TCP1",
|
|
"company_name": "_Test Company with perpetual inventory",
|
|
"country": "India",
|
|
"default_currency": "INR",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"enable_perpetual_inventory": 1,
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
},
|
|
{
|
|
"abbr": "_TC6",
|
|
"company_name": "_Test Company 6",
|
|
"is_group": 1,
|
|
"country": "India",
|
|
"default_currency": "INR",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"abbr": "_TC7",
|
|
"company_name": "_Test Company 7",
|
|
"parent_company": "_Test Company 6",
|
|
"is_group": 1,
|
|
"country": "United States",
|
|
"default_currency": "USD",
|
|
"doctype": "Company",
|
|
"domain": "Manufacturing",
|
|
"chart_of_accounts": "Standard",
|
|
"default_holiday_list": cls.holiday_list[0].name,
|
|
"enable_perpetual_inventory": 0,
|
|
},
|
|
{
|
|
"doctype": "Company",
|
|
"default_currency": "USD",
|
|
"full_name": "Test User",
|
|
"company_name": "Wind Power LLC",
|
|
"timezone": "America/New_York",
|
|
"abbr": "WP",
|
|
"industry": "Manufacturing",
|
|
"country": "United States",
|
|
# "fy_start_date": f"{current_year}-01-01",
|
|
# "fy_end_date": f"{current_year}-12-31",
|
|
"language": "english",
|
|
"company_tagline": "Testing",
|
|
"email": "test@erpnext.com",
|
|
"password": "test",
|
|
"chart_of_accounts": "Standard",
|
|
},
|
|
]
|
|
cls.companies = []
|
|
for x in records:
|
|
if not frappe.db.exists("Company", {"company_name": x.get("company_name")}):
|
|
cls.companies.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.companies.append(frappe.get_doc("Company", {"company_name": x.get("company_name")}))
|
|
|
|
@classmethod
|
|
def make_fiscal_year(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Fiscal Year",
|
|
"year": "_Test Short Fiscal Year 2011",
|
|
"is_short_year": 1,
|
|
"year_start_date": "2011-04-01",
|
|
"year_end_date": "2011-12-31",
|
|
}
|
|
]
|
|
|
|
start = 2012
|
|
end = now_datetime().year + 25
|
|
for year in range(start, end):
|
|
records.append(
|
|
{
|
|
"doctype": "Fiscal Year",
|
|
"year": f"_Test Fiscal Year {year}",
|
|
"year_start_date": f"{year}-01-01",
|
|
"year_end_date": f"{year}-12-31",
|
|
}
|
|
)
|
|
|
|
cls.fiscal_year = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Fiscal Year",
|
|
{"year_start_date": x.get("year_start_date"), "year_end_date": x.get("year_end_date")},
|
|
):
|
|
cls.fiscal_year.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.fiscal_year.append(
|
|
frappe.get_doc(
|
|
"Fiscal Year",
|
|
{
|
|
"year_start_date": x.get("year_start_date"),
|
|
"year_end_date": x.get("year_end_date"),
|
|
},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_payment_term(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Payment Term",
|
|
"due_date_based_on": "Day(s) after invoice date",
|
|
"payment_term_name": "_Test N30",
|
|
"description": "_Test Net 30 Days",
|
|
"invoice_portion": 50,
|
|
"credit_days": 30,
|
|
},
|
|
{
|
|
"doctype": "Payment Term",
|
|
"due_date_based_on": "Day(s) after invoice date",
|
|
"payment_term_name": "_Test COD",
|
|
"description": "_Test Cash on Delivery",
|
|
"invoice_portion": 50,
|
|
"credit_days": 0,
|
|
},
|
|
{
|
|
"doctype": "Payment Term",
|
|
"due_date_based_on": "Month(s) after the end of the invoice month",
|
|
"payment_term_name": "_Test EONM",
|
|
"description": "_Test End of Next Month",
|
|
"invoice_portion": 100,
|
|
"credit_months": 1,
|
|
},
|
|
{
|
|
"doctype": "Payment Term",
|
|
"due_date_based_on": "Day(s) after invoice date",
|
|
"payment_term_name": "_Test N30 1",
|
|
"description": "_Test Net 30 Days",
|
|
"invoice_portion": 100,
|
|
"credit_days": 30,
|
|
},
|
|
]
|
|
cls.payment_terms = []
|
|
for x in records:
|
|
if not frappe.db.exists("Payment Term", {"payment_term_name": x.get("payment_term_name")}):
|
|
cls.payment_terms.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.payment_terms.append(
|
|
frappe.get_doc("Payment Term", {"payment_term_name": x.get("payment_term_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_payment_terms_template(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Payment Terms Template",
|
|
"terms": [
|
|
{
|
|
"doctype": "Payment Terms Template Detail",
|
|
"due_date_based_on": "Day(s) after invoice date",
|
|
"idx": 1,
|
|
"description": "Cash on Delivery",
|
|
"invoice_portion": 50,
|
|
"credit_days": 0,
|
|
"credit_months": 0,
|
|
"payment_term": "_Test COD",
|
|
},
|
|
{
|
|
"doctype": "Payment Terms Template Detail",
|
|
"due_date_based_on": "Day(s) after invoice date",
|
|
"idx": 2,
|
|
"description": "Net 30 Days ",
|
|
"invoice_portion": 50,
|
|
"credit_days": 30,
|
|
"credit_months": 0,
|
|
"payment_term": "_Test N30",
|
|
},
|
|
],
|
|
"template_name": "_Test Payment Term Template",
|
|
},
|
|
{
|
|
"doctype": "Payment Terms Template",
|
|
"terms": [
|
|
{
|
|
"doctype": "Payment Terms Template Detail",
|
|
"due_date_based_on": "Month(s) after the end of the invoice month",
|
|
"idx": 1,
|
|
"description": "_Test End of Next Months",
|
|
"invoice_portion": 100,
|
|
"credit_days": 0,
|
|
"credit_months": 1,
|
|
"payment_term": "_Test EONM",
|
|
}
|
|
],
|
|
"template_name": "_Test Payment Term Template 1",
|
|
},
|
|
{
|
|
"doctype": "Payment Terms Template",
|
|
"terms": [
|
|
{
|
|
"doctype": "Payment Terms Template Detail",
|
|
"due_date_based_on": "Day(s) after invoice date",
|
|
"idx": 1,
|
|
"description": "_Test Net Within 30 days",
|
|
"invoice_portion": 100,
|
|
"credit_days": 30,
|
|
"credit_months": 0,
|
|
"payment_term": "_Test N30 1",
|
|
}
|
|
],
|
|
"template_name": "_Test Payment Term Template 3",
|
|
},
|
|
]
|
|
cls.payment_terms_template = []
|
|
for x in records:
|
|
if not frappe.db.exists("Payment Terms Template", {"template_name": x.get("template_name")}):
|
|
cls.payment_terms_template.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.payment_terms_template.append(
|
|
frappe.get_doc("Payment Terms Template", {"template_name": x.get("template_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_tax_category(cls):
|
|
records = [
|
|
{"doctype": "Tax Category", "title": "_Test Tax Category 1"},
|
|
{"doctype": "Tax Category", "title": "_Test Tax Category 2"},
|
|
{"doctype": "Tax Category", "title": "_Test Tax Category 3"},
|
|
]
|
|
cls.tax_category = []
|
|
for x in records:
|
|
if not frappe.db.exists("Tax Category", {"name": x.get("title")}):
|
|
cls.tax_category.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.tax_category.append(frappe.get_doc("Tax Category", {"name": x.get("title")}))
|
|
|
|
@classmethod
|
|
def make_account(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Account",
|
|
"account_name": "_Test Payable USD",
|
|
"parent_account": "Accounts Receivable - _TC",
|
|
"company": "_Test Company",
|
|
"account_currency": "USD",
|
|
},
|
|
{
|
|
"doctype": "Account",
|
|
"account_name": "_Test Bank",
|
|
"parent_account": "Bank Accounts - _TC",
|
|
"company": "_Test Company",
|
|
},
|
|
{
|
|
"doctype": "Account",
|
|
"account_name": "_Test Bank",
|
|
"parent_account": "Bank Accounts - TCP1",
|
|
"company": "_Test Company with perpetual inventory",
|
|
},
|
|
]
|
|
cls.accounts = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Account", {"account_name": x.get("account_name"), "company": x.get("company")}
|
|
):
|
|
cls.accounts.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.accounts.append(
|
|
frappe.get_doc(
|
|
"Account", {"account_name": x.get("account_name"), "company": x.get("company")}
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_supplier(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier With Template 1",
|
|
"supplier_group": "_Test Supplier Group",
|
|
"payment_terms": "_Test Payment Term Template 3",
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier P",
|
|
"supplier_group": "_Test Supplier Group",
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier with Country",
|
|
"supplier_group": "_Test Supplier Group",
|
|
"country": "Greece",
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier",
|
|
"supplier_group": "_Test Supplier Group",
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier 1",
|
|
"supplier_group": "_Test Supplier Group",
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier 2",
|
|
"supplier_group": "_Test Supplier Group",
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier USD",
|
|
"supplier_group": "_Test Supplier Group",
|
|
"default_currency": "USD",
|
|
"accounts": [{"company": "_Test Company", "account": "_Test Payable USD - _TC"}],
|
|
},
|
|
{
|
|
"doctype": "Supplier",
|
|
"supplier_name": "_Test Supplier With Tax Category",
|
|
"supplier_group": "_Test Supplier Group",
|
|
"tax_category": "_Test Tax Category 1",
|
|
},
|
|
]
|
|
cls.suppliers = []
|
|
for x in records:
|
|
if not frappe.db.exists("Supplier", {"supplier_name": x.get("supplier_name")}):
|
|
cls.suppliers.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.suppliers.append(frappe.get_doc("Supplier", {"supplier_name": x.get("supplier_name")}))
|
|
|
|
@classmethod
|
|
def make_supplier_group(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Supplier Group",
|
|
"supplier_group_name": "_Test Supplier Group",
|
|
"parent_supplier_group": "All Supplier Groups",
|
|
}
|
|
]
|
|
cls.supplier_groups = []
|
|
for x in records:
|
|
if not frappe.db.exists("Supplier Group", {"supplier_group_name": x.get("supplier_group_name")}):
|
|
cls.supplier_groups.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.supplier_groups.append(
|
|
frappe.get_doc("Supplier Group", {"supplier_group_name": x.get("supplier_group_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_cost_center(cls):
|
|
records = [
|
|
{
|
|
"company": "_Test Company",
|
|
"cost_center_name": "_Test Cost Center",
|
|
"doctype": "Cost Center",
|
|
"is_group": 0,
|
|
"parent_cost_center": "_Test Company - _TC",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"cost_center_name": "_Test Cost Center 2",
|
|
"doctype": "Cost Center",
|
|
"is_group": 0,
|
|
"parent_cost_center": "_Test Company - _TC",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"cost_center_name": "_Test Write Off Cost Center",
|
|
"doctype": "Cost Center",
|
|
"is_group": 0,
|
|
"parent_cost_center": "_Test Company - _TC",
|
|
},
|
|
]
|
|
cls.cost_center = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Cost Center", {"cost_center_name": x.get("cost_center_name"), "company": x.get("company")}
|
|
):
|
|
cls.cost_center.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.cost_center.append(
|
|
frappe.get_doc(
|
|
"Cost Center",
|
|
{"cost_center_name": x.get("cost_center_name"), "company": x.get("company")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_location(cls):
|
|
records = [
|
|
{"doctype": "Location", "location_name": "Test Location Area", "is_group": 1, "is_container": 1},
|
|
{
|
|
"doctype": "Location",
|
|
"location_name": "Basil Farm",
|
|
"location": '{"type":"FeatureCollection","features":[{"type":"Feature","properties":{"point_type":"circle","radius":884.5625420736483},"geometry":{"type":"Point","coordinates":[72.875834,19.100566]}}]}',
|
|
"parent_location": "Test Location Area",
|
|
"parent": "Test Location Area",
|
|
"is_group": 1,
|
|
"is_container": 1,
|
|
},
|
|
{
|
|
"doctype": "Location",
|
|
"location_name": "Division 1",
|
|
"location": '{"type":"FeatureCollection","features":[{"type":"Feature","properties":{"point_type":"circle","radius":542.3424997060739},"geometry":{"type":"Point","coordinates":[72.852359,19.11557]}}]}',
|
|
"parent_location": "Basil Farm",
|
|
"parent": "Basil Farm",
|
|
"is_group": 1,
|
|
"is_container": 1,
|
|
},
|
|
{
|
|
"doctype": "Location",
|
|
"location_name": "Field 1",
|
|
"location": '{"type":"FeatureCollection","features":[{"type":"Feature","properties":{},"geometry":{"type":"Polygon","coordinates":[[[72.846758,19.118287],[72.846758,19.121206],[72.850535,19.121206],[72.850535,19.118287],[72.846758,19.118287]]]}}]}',
|
|
"parent_location": "Division 1",
|
|
"parent": "Division 1",
|
|
"is_group": 1,
|
|
"is_container": 1,
|
|
},
|
|
{
|
|
"doctype": "Location",
|
|
"location_name": "Block 1",
|
|
"location": '{"type":"FeatureCollection","features":[{"type":"Feature","properties":{},"geometry":{"type":"Polygon","coordinates":[[[72.921495,19.073313],[72.924929,19.068121],[72.934713,19.06585],[72.929392,19.05579],[72.94158,19.056926],[72.951365,19.095213],[72.921495,19.073313]]]}}]}',
|
|
"parent_location": "Field 1",
|
|
"parent": "Field 1",
|
|
"is_group": 0,
|
|
"is_container": 1,
|
|
},
|
|
]
|
|
cls.location = []
|
|
for x in records:
|
|
if not frappe.db.exists("Location", {"location_name": x.get("location_name")}):
|
|
cls.location.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.location.append(
|
|
frappe.get_doc(
|
|
"Location",
|
|
{"location_name": x.get("location_name")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_warehouse(cls):
|
|
records = [
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Scrap Warehouse",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse 1",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse 2",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Rejected Warehouse",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company 1",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse 2",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse No Account",
|
|
"is_group": 0,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse Group",
|
|
"is_group": 1,
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse Group-C1",
|
|
"is_group": 0,
|
|
"parent_warehouse": "_Test Warehouse Group - _TC",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Warehouse",
|
|
"warehouse_name": "_Test Warehouse Group-C2",
|
|
"is_group": 0,
|
|
"parent_warehouse": "_Test Warehouse Group - _TC",
|
|
},
|
|
]
|
|
cls.warehouse = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Warehouse", {"warehouse_name": x.get("warehouse_name"), "company": x.get("company")}
|
|
):
|
|
cls.warehouse.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.warehouse.append(
|
|
frappe.get_doc(
|
|
"Warehouse",
|
|
{"warehouse_name": x.get("warehouse_name"), "company": x.get("company")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_uom(cls):
|
|
records = [
|
|
{"doctype": "UOM", "must_be_whole_number": 1, "uom_name": "_Test UOM"},
|
|
{"doctype": "UOM", "uom_name": "_Test UOM 1"},
|
|
]
|
|
cls.uom = []
|
|
for x in records:
|
|
if not frappe.db.exists("UOM", {"uom_name": x.get("uom_name")}):
|
|
cls.uom.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.uom.append(
|
|
frappe.get_doc(
|
|
"UOM",
|
|
{"uom_name": x.get("uom_name")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_item_attribute(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Item Attribute",
|
|
"attribute_name": "Test Size",
|
|
"priority": 1,
|
|
"item_attribute_values": [
|
|
{"attribute_value": "Extra Small", "abbr": "XSL"},
|
|
{"attribute_value": "Small", "abbr": "S"},
|
|
{"attribute_value": "Medium", "abbr": "M"},
|
|
{"attribute_value": "Large", "abbr": "L"},
|
|
{"attribute_value": "Extra Large", "abbr": "XL"},
|
|
{"attribute_value": "2XL", "abbr": "2XL"},
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Attribute",
|
|
"attribute_name": "Test Colour",
|
|
"priority": 2,
|
|
"item_attribute_values": [
|
|
{"attribute_value": "Red", "abbr": "R"},
|
|
{"attribute_value": "Green", "abbr": "G"},
|
|
{"attribute_value": "Blue", "abbr": "B"},
|
|
],
|
|
},
|
|
]
|
|
cls.item_attribute = []
|
|
for x in records:
|
|
if not frappe.db.exists("Item Attribute", {"attribute_name": x.get("attribute_name")}):
|
|
cls.item_attribute.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.item_attribute.append(
|
|
frappe.get_doc(
|
|
"Item Attribute",
|
|
{"attribute_name": x.get("attribute_name")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_item_tax_template(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Item Tax Template",
|
|
"title": "_Test Account Excise Duty @ 10",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 10,
|
|
"tax_type": "_Test Account Excise Duty - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Tax Template",
|
|
"title": "_Test Account Excise Duty @ 12",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 12,
|
|
"tax_type": "_Test Account Excise Duty - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Tax Template",
|
|
"title": "_Test Account Excise Duty @ 15",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 15,
|
|
"tax_type": "_Test Account Excise Duty - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Tax Template",
|
|
"title": "_Test Account Excise Duty @ 20",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 20,
|
|
"tax_type": "_Test Account Excise Duty - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Tax Template",
|
|
"title": "_Test Item Tax Template 1",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 5,
|
|
"tax_type": "_Test Account Excise Duty - _TC",
|
|
},
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 10,
|
|
"tax_type": "_Test Account Education Cess - _TC",
|
|
},
|
|
{
|
|
"doctype": "Item Tax Template Detail",
|
|
"parentfield": "taxes",
|
|
"tax_rate": 15,
|
|
"tax_type": "_Test Account S&H Education Cess - _TC",
|
|
},
|
|
],
|
|
},
|
|
]
|
|
cls.item_tax_template = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Item Tax Template", {"title": x.get("title"), "company": x.get("company")}
|
|
):
|
|
cls.item_tax_template.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.item_tax_template.append(
|
|
frappe.get_doc(
|
|
"Item Tax Template",
|
|
{"title": x.get("title"), "company": x.get("company")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_item_group(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 0,
|
|
"item_group_name": "_Test Item Group",
|
|
"parent_item_group": "All Item Groups",
|
|
"item_group_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"buying_cost_center": "_Test Cost Center 2 - _TC",
|
|
"selling_cost_center": "_Test Cost Center 2 - _TC",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 0,
|
|
"item_group_name": "_Test Item Group Desktops",
|
|
"parent_item_group": "All Item Groups",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group A",
|
|
"parent_item_group": "All Item Groups",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group B",
|
|
"parent_item_group": "All Item Groups",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group B - 1",
|
|
"parent_item_group": "_Test Item Group B",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group B - 2",
|
|
"parent_item_group": "_Test Item Group B",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 0,
|
|
"item_group_name": "_Test Item Group B - 3",
|
|
"parent_item_group": "_Test Item Group B",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group C",
|
|
"parent_item_group": "All Item Groups",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group C - 1",
|
|
"parent_item_group": "_Test Item Group C",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group C - 2",
|
|
"parent_item_group": "_Test Item Group C",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group D",
|
|
"parent_item_group": "All Item Groups",
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 1,
|
|
"item_group_name": "_Test Item Group Tax Parent",
|
|
"parent_item_group": "All Item Groups",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 10 - _TC",
|
|
"tax_category": "",
|
|
},
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 12 - _TC",
|
|
"tax_category": "_Test Tax Category 1",
|
|
},
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Item Group",
|
|
"is_group": 0,
|
|
"item_group_name": "_Test Item Group Tax Child Override",
|
|
"parent_item_group": "_Test Item Group Tax Parent",
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 15 - _TC",
|
|
"tax_category": "",
|
|
}
|
|
],
|
|
},
|
|
]
|
|
cls.item_group = []
|
|
for x in records:
|
|
if not frappe.db.exists("Item Group", {"item_group_name": x.get("item_group_name")}):
|
|
cls.item_group.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.item_group.append(
|
|
frappe.get_doc("Item Group", {"item_group_name": x.get("item_group_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def _make_item(cls):
|
|
records = [
|
|
{
|
|
"description": "_Test Item 1",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item",
|
|
"item_group": "_Test Item Group",
|
|
"item_name": "_Test Item",
|
|
"apply_warehouse_wise_reorder_level": 1,
|
|
"opening_stock": 10,
|
|
"valuation_rate": 100,
|
|
"allow_negative_stock": True,
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
"reorder_levels": [
|
|
{
|
|
"material_request_type": "Purchase",
|
|
"warehouse": "_Test Warehouse - _TC",
|
|
"warehouse_reorder_level": 20,
|
|
"warehouse_reorder_qty": 20,
|
|
}
|
|
],
|
|
"uoms": [
|
|
{"uom": "_Test UOM", "conversion_factor": 1.0},
|
|
{"uom": "_Test UOM 1", "conversion_factor": 10.0},
|
|
],
|
|
"stock_uom": "_Test UOM",
|
|
},
|
|
{
|
|
"description": "_Test Item 2",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item 2",
|
|
"item_group": "_Test Item Group",
|
|
"item_name": "_Test Item 2",
|
|
"stock_uom": "_Test UOM",
|
|
"opening_stock": 10,
|
|
"valuation_rate": 100,
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Item Home Desktop 100 3",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Home Desktop 100",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Item Home Desktop 100",
|
|
"valuation_rate": 100,
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 10 - _TC",
|
|
}
|
|
],
|
|
"stock_uom": "_Test UOM 1",
|
|
},
|
|
{
|
|
"description": "_Test Item Home Desktop 200 4",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Home Desktop 200",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Item Home Desktop 200",
|
|
"stock_uom": "_Test UOM 1",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Product Bundle Item 5",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 0,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Product Bundle Item",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Product Bundle Item",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test FG Item 6",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 1,
|
|
"item_code": "_Test FG Item",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test FG Item",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Non Stock Item 7",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 0,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Non Stock Item",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Non Stock Item",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Serialized Item 8",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 1,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Serialized Item",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Serialized Item",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Serialized Item 9",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 1,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Serialized Item With Series",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Serialized Item With Series",
|
|
"serial_no_series": "ABCD.#####",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Item Home Desktop Manufactured 10",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Home Desktop Manufactured",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Item Home Desktop Manufactured",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test FG Item 2 11",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 1,
|
|
"item_code": "_Test FG Item 2",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test FG Item 2",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Variant Item 12",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 1,
|
|
"item_code": "_Test Variant Item",
|
|
"item_group": "_Test Item Group Desktops",
|
|
"item_name": "_Test Variant Item",
|
|
"stock_uom": "_Test UOM",
|
|
"has_variants": 1,
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
"attributes": [{"attribute": "Test Size"}],
|
|
"apply_warehouse_wise_reorder_level": 1,
|
|
"reorder_levels": [
|
|
{
|
|
"material_request_type": "Purchase",
|
|
"warehouse": "_Test Warehouse - _TC",
|
|
"warehouse_reorder_level": 20,
|
|
"warehouse_reorder_qty": 20,
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Item 1",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Warehouse Group Wise Reorder",
|
|
"item_group": "_Test Item Group",
|
|
"item_name": "_Test Item Warehouse Group Wise Reorder",
|
|
"apply_warehouse_wise_reorder_level": 1,
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse Group-C1 - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
"reorder_levels": [
|
|
{
|
|
"warehouse_group": "_Test Warehouse Group - _TC",
|
|
"material_request_type": "Purchase",
|
|
"warehouse": "_Test Warehouse Group-C1 - _TC",
|
|
"warehouse_reorder_level": 20,
|
|
"warehouse_reorder_qty": 20,
|
|
}
|
|
],
|
|
"stock_uom": "_Test UOM",
|
|
},
|
|
{
|
|
"description": "_Test Item With Item Tax Template",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item With Item Tax Template",
|
|
"item_group": "_Test Item Group",
|
|
"item_name": "_Test Item With Item Tax Template",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 10 - _TC",
|
|
},
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 12 - _TC",
|
|
"tax_category": "_Test Tax Category 1",
|
|
},
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Item Inherit Group Item Tax Template 1",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Inherit Group Item Tax Template 1",
|
|
"item_group": "_Test Item Group Tax Parent",
|
|
"item_name": "_Test Item Inherit Group Item Tax Template 1",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Item Inherit Group Item Tax Template 2",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Inherit Group Item Tax Template 2",
|
|
"item_group": "_Test Item Group Tax Child Override",
|
|
"item_name": "_Test Item Inherit Group Item Tax Template 2",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test Item Override Group Item Tax Template",
|
|
"doctype": "Item",
|
|
"has_batch_no": 0,
|
|
"has_serial_no": 0,
|
|
"inspection_required": 0,
|
|
"is_stock_item": 1,
|
|
"is_sub_contracted_item": 0,
|
|
"item_code": "_Test Item Override Group Item Tax Template",
|
|
"item_group": "_Test Item Group Tax Child Override",
|
|
"item_name": "_Test Item Override Group Item Tax Template",
|
|
"stock_uom": "_Test UOM",
|
|
"item_defaults": [
|
|
{
|
|
"company": "_Test Company",
|
|
"default_warehouse": "_Test Warehouse - _TC",
|
|
"expense_account": "_Test Account Cost for Goods Sold - _TC",
|
|
"buying_cost_center": "_Test Cost Center - _TC",
|
|
"selling_cost_center": "_Test Cost Center - _TC",
|
|
"income_account": "Sales - _TC",
|
|
}
|
|
],
|
|
"taxes": [
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"item_tax_template": "_Test Account Excise Duty @ 20 - _TC",
|
|
},
|
|
{
|
|
"doctype": "Item Tax",
|
|
"parentfield": "taxes",
|
|
"tax_category": "_Test Tax Category 1",
|
|
"item_tax_template": "_Test Item Tax Template 1 - _TC",
|
|
},
|
|
],
|
|
},
|
|
{
|
|
"description": "_Test",
|
|
"doctype": "Item",
|
|
"is_stock_item": 1,
|
|
"item_code": "138-CMS Shoe",
|
|
"item_group": "_Test Item Group",
|
|
"item_name": "138-CMS Shoe",
|
|
"stock_uom": "_Test UOM",
|
|
},
|
|
{
|
|
"doctype": "Item",
|
|
"item_code": "Photocopier",
|
|
"item_name": "Photocopier",
|
|
"item_group": "All Item Groups",
|
|
"company": "_Test Company",
|
|
"is_fixed_asset": 1,
|
|
"is_stock_item": 0,
|
|
"asset_category": "Equipment",
|
|
"auto_create_assets": 1,
|
|
"asset_naming_series": "ABC.###",
|
|
"stock_uom": "_Test UOM",
|
|
},
|
|
{
|
|
"doctype": "Item",
|
|
"item_code": "Loyal Item",
|
|
"item_name": "Loyal Item",
|
|
"item_group": "All Item Groups",
|
|
"company": "_Test Company",
|
|
"is_stock_item": 1,
|
|
"opening_stock": 100,
|
|
"valuation_rate": 10000,
|
|
"stock_uom": "_Test UOM",
|
|
},
|
|
]
|
|
cls.item = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Item", {"item_code": x.get("item_code"), "item_name": x.get("item_name")}
|
|
):
|
|
cls.item.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.item.append(
|
|
frappe.get_doc(
|
|
"Item",
|
|
{"item_code": x.get("item_code"), "item_name": x.get("item_name")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_product_bundle(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Product Bundle",
|
|
"new_item_code": "_Test Product Bundle Item",
|
|
"items": [
|
|
{
|
|
"doctype": "Product Bundle Item",
|
|
"item_code": "_Test Item",
|
|
"parentfield": "items",
|
|
"qty": 5.0,
|
|
},
|
|
{
|
|
"doctype": "Product Bundle Item",
|
|
"item_code": "_Test Item Home Desktop 100",
|
|
"parentfield": "items",
|
|
"qty": 2.0,
|
|
},
|
|
],
|
|
}
|
|
]
|
|
cls.product_bundle = []
|
|
for x in records:
|
|
if not frappe.db.exists("Product Bundle", {"new_item_code": x.get("new_item_code")}):
|
|
cls.product_bundle.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.product_bundle.append(
|
|
frappe.get_doc(
|
|
"Product Bundle",
|
|
{"new_item_code": x.get("new_item_code")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_test_account(cls):
|
|
records = [
|
|
# [account_name, parent_account, is_group]
|
|
["_Test Bank", "Bank Accounts", 0, "Bank", None],
|
|
["_Test Bank USD", "Bank Accounts", 0, "Bank", "USD"],
|
|
["_Test Bank EUR", "Bank Accounts", 0, "Bank", "EUR"],
|
|
["_Test Cash", "Cash In Hand", 0, "Cash", None],
|
|
["_Test Account Stock Expenses", "Direct Expenses", 1, None, None],
|
|
["_Test Account Shipping Charges", "_Test Account Stock Expenses", 0, "Chargeable", None],
|
|
["_Test Account Customs Duty", "_Test Account Stock Expenses", 0, "Tax", None],
|
|
["_Test Account Insurance Charges", "_Test Account Stock Expenses", 0, "Chargeable", None],
|
|
["_Test Account Stock Adjustment", "_Test Account Stock Expenses", 0, "Stock Adjustment", None],
|
|
["_Test Employee Advance", "Current Liabilities", 0, None, None],
|
|
["_Test Account Tax Assets", "Current Assets", 1, None, None],
|
|
["_Test Account VAT", "_Test Account Tax Assets", 0, "Tax", None],
|
|
["_Test Account Service Tax", "_Test Account Tax Assets", 0, "Tax", None],
|
|
["_Test Account Reserves and Surplus", "Current Liabilities", 0, None, None],
|
|
["_Test Account Cost for Goods Sold", "Expenses", 0, None, None],
|
|
["_Test Account Excise Duty", "_Test Account Tax Assets", 0, "Tax", None],
|
|
["_Test Account Education Cess", "_Test Account Tax Assets", 0, "Tax", None],
|
|
["_Test Account S&H Education Cess", "_Test Account Tax Assets", 0, "Tax", None],
|
|
["_Test Account CST", "Direct Expenses", 0, "Tax", None],
|
|
["_Test Account Discount", "Direct Expenses", 0, None, None],
|
|
["_Test Write Off", "Indirect Expenses", 0, None, None],
|
|
["_Test Exchange Gain/Loss", "Indirect Expenses", 0, None, None],
|
|
["_Test Account Sales", "Direct Income", 0, None, None],
|
|
# related to Account Inventory Integration
|
|
["_Test Account Stock In Hand", "Current Assets", 0, None, None],
|
|
# fixed asset depreciation
|
|
["_Test Fixed Asset", "Current Assets", 0, "Fixed Asset", None],
|
|
["_Test Accumulated Depreciations", "Current Assets", 0, "Accumulated Depreciation", None],
|
|
["_Test Depreciations", "Expenses", 0, "Depreciation", None],
|
|
["_Test Gain/Loss on Asset Disposal", "Expenses", 0, None, None],
|
|
# Receivable / Payable Account
|
|
["_Test Receivable", "Current Assets", 0, "Receivable", None],
|
|
["_Test Payable", "Current Liabilities", 0, "Payable", None],
|
|
["_Test Receivable USD", "Current Assets", 0, "Receivable", "USD"],
|
|
["_Test Payable USD", "Current Liabilities", 0, "Payable", "USD"],
|
|
# Loyalty Account
|
|
["Loyalty", "Direct Expenses", 0, "Expense Account", None],
|
|
]
|
|
|
|
cls.test_accounts = []
|
|
for company, abbr in [
|
|
["_Test Company", "_TC"],
|
|
["_Test Company 1", "_TC1"],
|
|
["_Test Company with perpetual inventory", "TCP1"],
|
|
]:
|
|
for account_name, parent_account, is_group, account_type, currency in records:
|
|
if not frappe.db.exists("Account", {"account_name": account_name, "company": company}):
|
|
cls.test_accounts.append(
|
|
frappe.get_doc(
|
|
{
|
|
"doctype": "Account",
|
|
"account_name": account_name,
|
|
"parent_account": parent_account + " - " + abbr,
|
|
"company": company,
|
|
"is_group": is_group,
|
|
"account_type": account_type,
|
|
"account_currency": currency,
|
|
}
|
|
).insert()
|
|
)
|
|
else:
|
|
cls.test_accounts.append(
|
|
frappe.get_doc("Account", {"account_name": account_name, "company": company})
|
|
)
|
|
|
|
@classmethod
|
|
def make_customer(cls):
|
|
records = [
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer With Template",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer P",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer 1",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer 2",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer 3",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer USD",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
"default_currency": "USD",
|
|
"accounts": [{"company": "_Test Company", "account": "_Test Receivable USD - _TC"}],
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "_Test Customer With Tax Category",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
"tax_category": "_Test Tax Category 1",
|
|
},
|
|
{
|
|
"customer_group": "_Test Customer Group",
|
|
"customer_name": "Test Loyalty Customer",
|
|
"customer_type": "Individual",
|
|
"doctype": "Customer",
|
|
"territory": "_Test Territory",
|
|
},
|
|
]
|
|
cls.customer = []
|
|
for x in records:
|
|
if not frappe.db.exists("Customer", {"customer_name": x.get("customer_name")}):
|
|
cls.customer.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.customer.append(frappe.get_doc("Customer", {"customer_name": x.get("customer_name")}))
|
|
|
|
@classmethod
|
|
def make_shareholder(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Shareholder",
|
|
"naming_series": "SH-",
|
|
"title": "Iron Man",
|
|
"company": "_Test Company",
|
|
},
|
|
{"doctype": "Shareholder", "naming_series": "SH-", "title": "Thor", "company": "_Test Company"},
|
|
{"doctype": "Shareholder", "naming_series": "SH-", "title": "Hulk", "company": "_Test Company"},
|
|
]
|
|
cls.shareholder = []
|
|
for x in records:
|
|
if not frappe.db.exists("Shareholder", {"title": x.get("title"), "company": x.get("company")}):
|
|
cls.shareholder.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.shareholder.append(
|
|
frappe.get_doc("Shareholder", {"title": x.get("title"), "company": x.get("company")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_sales_taxes_template(cls):
|
|
records = [
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"taxes": [
|
|
{
|
|
"account_head": "_Test Account VAT - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "VAT",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 6,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Service Tax - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "Service Tax",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 6.36,
|
|
},
|
|
],
|
|
"title": "_Test Sales Taxes and Charges Template",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"taxes": [
|
|
{
|
|
"account_head": "_Test Account Shipping Charges - _TC",
|
|
"charge_type": "Actual",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "Shipping Charges",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"tax_amount": 100,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Customs Duty - _TC",
|
|
"charge_type": "On Net Total",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "Customs Duty",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": 10,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Excise Duty - _TC",
|
|
"charge_type": "On Net Total",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "Excise Duty",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": 12,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Education Cess - _TC",
|
|
"charge_type": "On Previous Row Amount",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "Education Cess",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": 2,
|
|
"row_id": 3,
|
|
},
|
|
{
|
|
"account_head": "_Test Account S&H Education Cess - _TC",
|
|
"charge_type": "On Previous Row Amount",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "S&H Education Cess",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": 1,
|
|
"row_id": 3,
|
|
},
|
|
{
|
|
"account_head": "_Test Account CST - _TC",
|
|
"charge_type": "On Previous Row Total",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "CST",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": 2,
|
|
"row_id": 5,
|
|
},
|
|
{
|
|
"account_head": "_Test Account VAT - _TC",
|
|
"charge_type": "On Net Total",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "VAT",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": 12.5,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Discount - _TC",
|
|
"charge_type": "On Previous Row Total",
|
|
"cost_center": "_Test Cost Center - _TC",
|
|
"description": "Discount",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"parentfield": "taxes",
|
|
"rate": -10,
|
|
"row_id": 7,
|
|
},
|
|
],
|
|
"title": "_Test India Tax Master",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"taxes": [
|
|
{
|
|
"account_head": "_Test Account VAT - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "VAT",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 12,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Service Tax - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "Service Tax",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 4,
|
|
},
|
|
],
|
|
"title": "_Test Sales Taxes and Charges Template - Rest of the World",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"taxes": [
|
|
{
|
|
"account_head": "_Test Account VAT - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "VAT",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 12,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Service Tax - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "Service Tax",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 4,
|
|
},
|
|
],
|
|
"title": "_Test Sales Taxes and Charges Template 1",
|
|
},
|
|
{
|
|
"company": "_Test Company",
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"taxes": [
|
|
{
|
|
"account_head": "_Test Account VAT - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "VAT",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 12,
|
|
},
|
|
{
|
|
"account_head": "_Test Account Service Tax - _TC",
|
|
"charge_type": "On Net Total",
|
|
"description": "Service Tax",
|
|
"doctype": "Sales Taxes and Charges",
|
|
"cost_center": "Main - _TC",
|
|
"parentfield": "taxes",
|
|
"rate": 4,
|
|
},
|
|
],
|
|
"title": "_Test Sales Taxes and Charges Template 2",
|
|
},
|
|
{
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"title": "_Test Tax 1",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"charge_type": "Actual",
|
|
"account_head": "Sales Expenses - _TC",
|
|
"cost_center": "Main - _TC",
|
|
"description": "Test Shopping cart taxes with Tax Rule",
|
|
"tax_amount": 1000,
|
|
}
|
|
],
|
|
},
|
|
{
|
|
"doctype": "Sales Taxes and Charges Template",
|
|
"title": "_Test Tax 2",
|
|
"company": "_Test Company",
|
|
"taxes": [
|
|
{
|
|
"charge_type": "Actual",
|
|
"account_head": "Sales Expenses - _TC",
|
|
"cost_center": "Main - _TC",
|
|
"description": "Test Shopping cart taxes with Tax Rule",
|
|
"tax_amount": 200,
|
|
}
|
|
],
|
|
},
|
|
]
|
|
cls.sales_taxes_and_template = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Sales Taxes and Charges Template", {"title": x.get("title"), "company": x.get("company")}
|
|
):
|
|
cls.sales_taxes_and_template.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.sales_taxes_and_template.append(
|
|
frappe.get_doc(
|
|
"Sales Taxes and Charges Template",
|
|
{"title": x.get("title"), "company": x.get("company")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_asset_category(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Asset Category",
|
|
"asset_category_name": "Equipment",
|
|
"total_number_of_depreciations": 3,
|
|
"frequency_of_depreciation": 3,
|
|
"accounts": [
|
|
{
|
|
"company_name": "_Test Company",
|
|
"fixed_asset_account": "_Test Fixed Asset - _TC",
|
|
"accumulated_depreciation_account": "_Test Accumulated Depreciations - _TC",
|
|
"depreciation_expense_account": "_Test Depreciations - _TC",
|
|
}
|
|
],
|
|
}
|
|
]
|
|
cls.asset_category = []
|
|
for x in records:
|
|
if not frappe.db.exists("Asset Category", {"asset_category_name": x.get("asset_category_name")}):
|
|
cls.asset_category.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.asset_category.append(
|
|
frappe.get_doc(
|
|
"Asset Category",
|
|
{"asset_category_name": x.get("asset_category_name")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_asset_maintenance_team(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Asset Maintenance Team",
|
|
"maintenance_manager": "marcus@abc.com",
|
|
"maintenance_team_name": "Team Awesome",
|
|
"company": "_Test Company",
|
|
"maintenance_team_members": [
|
|
{
|
|
"team_member": "marcus@abc.com",
|
|
"full_name": "marcus@abc.com",
|
|
"maintenance_role": "Technician",
|
|
},
|
|
{
|
|
"team_member": "thalia@abc.com",
|
|
"full_name": "thalia@abc.com",
|
|
"maintenance_role": "Technician",
|
|
},
|
|
{
|
|
"team_member": "mathias@abc.com",
|
|
"full_name": "mathias@abc.com",
|
|
"maintenance_role": "Technician",
|
|
},
|
|
],
|
|
}
|
|
]
|
|
cls.asset_maintenance_team = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Asset Maintenance Team", {"maintenance_team_name": x.get("maintenance_team_name")}
|
|
):
|
|
cls.asset_maintenance_team.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.asset_maintenance_team.append(
|
|
frappe.get_doc(
|
|
"Asset Maintenance Team",
|
|
{"maintenance_team_name": x.get("maintenance_team_name")},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_activity_type(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Activity Type",
|
|
"name": "_Test Activity Type",
|
|
"activity_type": "_Test Activity Type",
|
|
},
|
|
{
|
|
"doctype": "Activity Type",
|
|
"name": "_Test Activity Type 1",
|
|
"activity_type": "_Test Activity Type 1",
|
|
},
|
|
]
|
|
cls.activity_type = []
|
|
for x in records:
|
|
if not frappe.db.exists("Activity Type", {"activity_type": x.get("activity_type")}):
|
|
cls.activity_type.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.activity_type.append(
|
|
frappe.get_doc("Activity Type", {"activity_type": x.get("activity_type")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_loyalty_program(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Loyalty Program",
|
|
"loyalty_program_name": "Test Single Loyalty",
|
|
"auto_opt_in": 1,
|
|
"from_date": today(),
|
|
"loyalty_program_type": "Single Tier Program",
|
|
"conversion_factor": 1,
|
|
"expiry_duration": 10,
|
|
"company": "_Test Company",
|
|
"cost_center": "Main - _TC",
|
|
"expense_account": "Loyalty - _TC",
|
|
"collection_rules": [{"tier_name": "Bronce", "collection_factor": 1000, "min_spent": 0}],
|
|
},
|
|
{
|
|
"doctype": "Loyalty Program",
|
|
"loyalty_program_name": "Test Multiple Loyalty",
|
|
"auto_opt_in": 1,
|
|
"from_date": today(),
|
|
"loyalty_program_type": "Multiple Tier Program",
|
|
"conversion_factor": 1,
|
|
"expiry_duration": 10,
|
|
"company": "_Test Company",
|
|
"cost_center": "Main - _TC",
|
|
"expense_account": "Loyalty - _TC",
|
|
"collection_rules": [
|
|
{"tier_name": "Bronze", "collection_factor": 1000, "min_spent": 0},
|
|
{"tier_name": "Silver", "collection_factor": 1000, "min_spent": 10000},
|
|
{"tier_name": "Gold", "collection_factor": 1000, "min_spent": 19000},
|
|
],
|
|
},
|
|
]
|
|
cls.loyalty_program = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Loyalty Program", {"loyalty_program_name": x.get("loyalty_program_name")}
|
|
):
|
|
cls.loyalty_program.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.loyalty_program.append(
|
|
frappe.get_doc("Loyalty Program", {"loyalty_program_name": x.get("loyalty_program_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_item_price(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item",
|
|
"price_list": "_Test Price List",
|
|
"price_list_rate": 100,
|
|
"valid_from": "2017-04-18",
|
|
"valid_upto": "2017-04-26",
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item",
|
|
"price_list": "_Test Price List Rest of the World",
|
|
"price_list_rate": 10,
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item 2",
|
|
"price_list": "_Test Price List Rest of the World",
|
|
"price_list_rate": 20,
|
|
"valid_from": "2017-04-18",
|
|
"valid_upto": "2017-04-26",
|
|
"customer": "_Test Customer",
|
|
"uom": "_Test UOM",
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item Home Desktop 100",
|
|
"price_list": "_Test Price List",
|
|
"price_list_rate": 1000,
|
|
"valid_from": "2017-04-10",
|
|
"valid_upto": "2017-04-17",
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item Home Desktop Manufactured",
|
|
"price_list": "_Test Price List",
|
|
"price_list_rate": 1000,
|
|
"valid_from": "2017-04-10",
|
|
"valid_upto": "2017-04-17",
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item",
|
|
"price_list": "_Test Buying Price List",
|
|
"price_list_rate": 100,
|
|
"supplier": "_Test Supplier",
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"item_code": "_Test Item",
|
|
"price_list": "_Test Selling Price List",
|
|
"price_list_rate": 200,
|
|
"customer": "_Test Customer",
|
|
},
|
|
{
|
|
"doctype": "Item Price",
|
|
"price_list": _("Standard Selling"),
|
|
"item_code": "Loyal Item",
|
|
"price_list_rate": 10000,
|
|
},
|
|
]
|
|
cls.item_price = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Item Price",
|
|
{
|
|
"item_code": x.get("item_code"),
|
|
"price_list": x.get("price_list"),
|
|
"price_list_rate": x.get("price_list_rate"),
|
|
},
|
|
):
|
|
cls.item_price.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.item_price.append(
|
|
frappe.get_doc(
|
|
"Item Price",
|
|
{
|
|
"item_code": x.get("item_code"),
|
|
"price_list": x.get("price_list"),
|
|
"price_list_rate": x.get("price_list_rate"),
|
|
},
|
|
)
|
|
)
|
|
|
|
@classmethod
|
|
def make_operation(cls):
|
|
records = [
|
|
{"doctype": "Operation", "name": "_Test Operation 1", "workstation": "_Test Workstation 1"}
|
|
]
|
|
cls.operation = []
|
|
for x in records:
|
|
if not frappe.db.exists("Operation", {"name": x.get("name")}):
|
|
cls.operation.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.operation.append(frappe.get_doc("Operation", {"name": x.get("name")}))
|
|
|
|
@classmethod
|
|
def make_workstation(cls):
|
|
records = [
|
|
{
|
|
"doctype": "Workstation",
|
|
"name": "_Test Workstation 1",
|
|
"workstation_name": "_Test Workstation 1",
|
|
"warehouse": "_Test warehouse - _TC",
|
|
"hour_rate_labour": 25,
|
|
"hour_rate_electricity": 25,
|
|
"hour_rate_consumable": 25,
|
|
"hour_rate_rent": 25,
|
|
"holiday_list": "_Test Holiday List",
|
|
"working_hours": [{"start_time": "10:00:00", "end_time": "20:00:00"}],
|
|
}
|
|
]
|
|
cls.workstation = []
|
|
for x in records:
|
|
if not frappe.db.exists("Workstation", {"workstation_name": x.get("workstation_name")}):
|
|
cls.workstation.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.workstation.append(
|
|
frappe.get_doc("Workstation", {"workstation_name": x.get("workstation_name")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_bom(cls):
|
|
# TODO: replace JSON source with hardcoded data in py
|
|
cls.load_test_records("BOM")
|
|
records = cls.globalTestRecords["BOM"]
|
|
cls.bom = []
|
|
for x in records:
|
|
x["company"] = cls.companies[0].name
|
|
if not frappe.db.exists("BOM", {"item": x.get("item"), "company": x.get("company")}):
|
|
cls.bom.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.bom.append(frappe.get_doc("BOM", {"item": x.get("item"), "company": x.get("company")}))
|
|
|
|
@classmethod
|
|
def make_quality_inspection_param(cls):
|
|
records = [{"doctype": "Quality Inspection Parameter", "parameter": "_Test Param"}]
|
|
cls.quality_inspection_param = []
|
|
for x in records:
|
|
if not frappe.db.exists("Quality Inspection Parameter", {"parameter": x.get("parameter")}):
|
|
cls.quality_inspection_param.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.quality_inspection_param.append(
|
|
frappe.get_doc("Quality Inspection Parameter", {"parameter": x.get("parameter")})
|
|
)
|
|
|
|
@classmethod
|
|
def make_quality_inspection_template(cls):
|
|
records = [
|
|
{
|
|
"quality_inspection_template_name": "_Test Quality Inspection Template",
|
|
"doctype": "Quality Inspection Template",
|
|
"item_quality_inspection_parameter": [
|
|
{
|
|
"specification": cls.quality_inspection_param[0].name,
|
|
"doctype": "Item Quality Inspection Parameter",
|
|
"parentfield": "item_quality_inspection_parameter",
|
|
}
|
|
],
|
|
}
|
|
]
|
|
cls.quality_inspection_template = []
|
|
for x in records:
|
|
if not frappe.db.exists(
|
|
"Quality Inspection Template",
|
|
{"quality_inspection_template_name": x.get("quality_inspection_template_name")},
|
|
):
|
|
cls.quality_inspection_template.append(frappe.get_doc(x).insert())
|
|
else:
|
|
cls.quality_inspection_template.append(
|
|
frappe.get_doc(
|
|
"Quality Inspection Template",
|
|
{"quality_inspection_template_name": x.get("quality_inspection_template_name")},
|
|
)
|
|
)
|
|
|
|
@contextmanager
|
|
def set_user(self, user: str):
|
|
try:
|
|
old_user = frappe.session.user
|
|
frappe.set_user(user)
|
|
yield
|
|
finally:
|
|
frappe.set_user(old_user)
|
|
|
|
|
|
@ERPNextTestSuite.registerAs(staticmethod)
|
|
@contextmanager
|
|
def change_settings(doctype, settings_dict=None, /, **settings) -> None:
|
|
"""Temporarily: change settings in a settings doctype."""
|
|
import copy
|
|
|
|
if settings_dict is None:
|
|
settings_dict = settings
|
|
|
|
settings = frappe.get_doc(doctype)
|
|
previous_settings = copy.deepcopy(settings_dict)
|
|
for key in previous_settings:
|
|
previous_settings[key] = getattr(settings, key)
|
|
|
|
for key, value in settings_dict.items():
|
|
setattr(settings, key, value)
|
|
settings.save(ignore_permissions=True)
|
|
|
|
yield
|
|
|
|
settings = frappe.get_doc(doctype)
|
|
for key, value in previous_settings.items():
|
|
setattr(settings, key, value)
|
|
settings.save(ignore_permissions=True)
|