2022-01-09 13:53:27 +00:00
|
|
|
import unittest
|
|
|
|
from typing import List, Tuple
|
|
|
|
|
|
|
|
from erpnext.tests.utils import ReportFilters, ReportName, execute_script_report
|
|
|
|
|
|
|
|
DEFAULT_FILTERS = {
|
|
|
|
"company": "_Test Company",
|
|
|
|
"from_date": "2010-01-01",
|
|
|
|
"to_date": "2030-01-01",
|
|
|
|
"period_start_date": "2010-01-01",
|
2022-03-28 13:22:46 +00:00
|
|
|
"period_end_date": "2030-01-01",
|
2022-01-09 13:53:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
REPORT_FILTER_TEST_CASES: List[Tuple[ReportName, ReportFilters]] = [
|
2022-03-28 13:22:46 +00:00
|
|
|
("General Ledger", {"group_by": "Group by Voucher (Consolidated)"}),
|
|
|
|
("General Ledger", {"group_by": "Group by Voucher (Consolidated)", "include_dimensions": 1}),
|
2022-01-09 13:53:27 +00:00
|
|
|
("Accounts Payable", {"range1": 30, "range2": 60, "range3": 90, "range4": 120}),
|
|
|
|
("Accounts Receivable", {"range1": 30, "range2": 60, "range3": 90, "range4": 120}),
|
2022-03-28 13:22:46 +00:00
|
|
|
("Consolidated Financial Statement", {"report": "Balance Sheet"}),
|
|
|
|
("Consolidated Financial Statement", {"report": "Profit and Loss Statement"}),
|
|
|
|
("Consolidated Financial Statement", {"report": "Cash Flow"}),
|
2022-01-09 13:53:27 +00:00
|
|
|
("Gross Profit", {"group_by": "Invoice"}),
|
|
|
|
("Gross Profit", {"group_by": "Item Code"}),
|
|
|
|
("Gross Profit", {"group_by": "Item Group"}),
|
|
|
|
("Gross Profit", {"group_by": "Customer"}),
|
|
|
|
("Gross Profit", {"group_by": "Customer Group"}),
|
|
|
|
("Item-wise Sales Register", {}),
|
|
|
|
("Item-wise Purchase Register", {}),
|
|
|
|
("Sales Register", {}),
|
2022-06-07 09:53:32 +00:00
|
|
|
("Sales Register", {"item_group": "All Item Groups"}),
|
2022-01-09 13:53:27 +00:00
|
|
|
("Purchase Register", {}),
|
2022-03-28 13:22:46 +00:00
|
|
|
(
|
|
|
|
"Tax Detail",
|
|
|
|
{"mode": "run", "report_name": "Tax Detail"},
|
|
|
|
),
|
2022-01-09 13:53:27 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
OPTIONAL_FILTERS = {}
|
|
|
|
|
|
|
|
|
|
|
|
class TestReports(unittest.TestCase):
|
|
|
|
def test_execute_all_accounts_reports(self):
|
|
|
|
"""Test that all script report in stock modules are executable with supported filters"""
|
|
|
|
for report, filter in REPORT_FILTER_TEST_CASES:
|
2022-02-22 13:54:49 +00:00
|
|
|
with self.subTest(report=report):
|
|
|
|
execute_script_report(
|
|
|
|
report_name=report,
|
|
|
|
module="Accounts",
|
|
|
|
filters=filter,
|
|
|
|
default_filters=DEFAULT_FILTERS,
|
|
|
|
optional_filters=OPTIONAL_FILTERS if filter.get("_optional") else None,
|
|
|
|
)
|