import datetime import json import os import unittest import frappe from frappe.utils import ( add_to_date, get_first_day, get_last_day, get_year_ending, get_year_start, getdate, ) from .tax_detail import filter_match, save_custom_report class TestTaxDetail(unittest.TestCase): def load_testdocs(self): from erpnext.accounts.utils import FiscalYearError, get_fiscal_year datapath, _ = os.path.splitext(os.path.realpath(__file__)) with open(datapath + '.json', 'r') as fp: docs = json.load(fp) now = getdate() self.from_date = get_first_day(now) self.to_date = get_last_day(now) try: get_fiscal_year(now, company="_T") except FiscalYearError: docs = [{ "companies": [{ "company": "_T", "parent": "_Test Fiscal", "parentfield": "companies", "parenttype": "Fiscal Year" }], "doctype": "Fiscal Year", "year": "_Test Fiscal", "year_end_date": get_year_ending(now), "year_start_date": get_year_start(now) }] + docs docs = [{ "abbr": "_T", "company_name": "_T", "country": "United Kingdom", "default_currency": "GBP", "doctype": "Company", "name": "_T" }] + docs for doc in docs: try: db_doc = frappe.get_doc(doc) if 'Invoice' in db_doc.doctype: db_doc.due_date = add_to_date(now, days=1) db_doc.insert() # Create GL Entries: db_doc.submit() else: db_doc.insert(ignore_if_duplicate=True) except frappe.exceptions.DuplicateEntryError: pass def load_defcols(self): self.company = frappe.get_doc('Company', '_T') custom_report = frappe.get_doc('Report', 'Tax Detail') self.default_columns, _ = custom_report.run_query_report( filters={ 'from_date': '2021-03-01', 'to_date': '2021-03-31', 'company': self.company.name, 'mode': 'run', 'report_name': 'Tax Detail' }, user=frappe.session.user) def rm_testdocs(self): "Remove the Company and all data" from erpnext.setup.doctype.company.company import create_transaction_deletion_request create_transaction_deletion_request(self.company.name) def test_report(self): self.load_testdocs() self.load_defcols() report_name = save_custom_report( 'Tax Detail', '_Test Tax Detail', json.dumps({ 'columns': self.default_columns, 'sections': { 'Box1':{'Filter0':{'type':'filter','filters':{'4':'VAT on Sales'}}}, 'Box2':{'Filter0':{'type':'filter','filters':{'4':'Acquisition'}}}, 'Box3':{'Box1':{'type':'section'},'Box2':{'type':'section'}}, 'Box4':{'Filter0':{'type':'filter','filters':{'4':'VAT on Purchases'}}}, 'Box5':{'Box3':{'type':'section'},'Box4':{'type':'section'}}, 'Box6':{'Filter0':{'type':'filter','filters':{'3':'!=Tax','4':'Sales'}}}, 'Box7':{'Filter0':{'type':'filter','filters':{'2':'Expense','3':'!=Tax'}}}, 'Box8':{'Filter0':{'type':'filter','filters':{'3':'!=Tax','4':'Sales','12':'EU'}}}, 'Box9':{'Filter0':{'type':'filter','filters':{'2':'Expense','3':'!=Tax','12':'EU'}}} }, 'show_detail': 1 })) data = frappe.desk.query_report.run(report_name, filters={ 'from_date': self.from_date, 'to_date': self.to_date, 'company': self.company.name, 'mode': 'run', 'report_name': report_name }, user=frappe.session.user) self.assertListEqual(data.get('columns'), self.default_columns) expected = (('Box1', 43.25), ('Box2', 0.0), ('Box3', 43.25), ('Box4', -85.28), ('Box5', -42.03), ('Box6', 825.0), ('Box7', -426.40), ('Box8', 0.0), ('Box9', 0.0)) exrow = iter(expected) for row in data.get('result'): if row.get('voucher_no') and not row.get('posting_date'): label, value = next(exrow) self.assertDictEqual(row, {'voucher_no': label, 'amount': value}) self.assertListEqual(data.get('report_summary'), [{'label': label, 'datatype': 'Currency', 'value': value} for label, value in expected]) self.rm_testdocs() def test_filter_match(self): # None - treated as -inf number except range self.assertTrue(filter_match(None, '!=')) self.assertTrue(filter_match(None, '<')) self.assertTrue(filter_match(None, '3.4')) self.assertFalse(filter_match(None, ' <')) self.assertFalse(filter_match(None, 'ew')) self.assertFalse(filter_match(None, ' ')) self.assertFalse(filter_match(None, ' f :')) # Numbers self.assertTrue(filter_match(3.4, '3.4')) self.assertTrue(filter_match(3.4, '.4')) self.assertTrue(filter_match(3.4, '3')) self.assertTrue(filter_match(-3.4, '< -3')) self.assertTrue(filter_match(-3.4, '> -4')) self.assertTrue(filter_match(3.4, '= 3.4 ')) self.assertTrue(filter_match(3.4, '!=4.5')) self.assertTrue(filter_match(3.4, ' 3 : 4 ')) self.assertTrue(filter_match(0.0, ' : ')) self.assertFalse(filter_match(3.4, '=4.5')) self.assertFalse(filter_match(3.4, ' = 3.4 ')) self.assertFalse(filter_match(3.4, '!=3.4')) self.assertFalse(filter_match(3.4, '>6')) self.assertFalse(filter_match(3.4, '<-4.5')) self.assertFalse(filter_match(3.4, '4.5')) self.assertFalse(filter_match(3.4, '5:9')) # Strings self.assertTrue(filter_match('ACC-SINV-2021-00001', 'SINV')) self.assertTrue(filter_match('ACC-SINV-2021-00001', 'sinv')) self.assertTrue(filter_match('ACC-SINV-2021-00001', '-2021')) self.assertTrue(filter_match(' ACC-SINV-2021-00001', ' acc')) self.assertTrue(filter_match('ACC-SINV-2021-00001', '=2021')) self.assertTrue(filter_match('ACC-SINV-2021-00001', '!=zz')) self.assertTrue(filter_match('ACC-SINV-2021-00001', '< zzz ')) self.assertTrue(filter_match('ACC-SINV-2021-00001', ' : sinv ')) self.assertFalse(filter_match('ACC-SINV-2021-00001', ' sinv :')) self.assertFalse(filter_match('ACC-SINV-2021-00001', ' acc')) self.assertFalse(filter_match('ACC-SINV-2021-00001', '= 2021 ')) self.assertFalse(filter_match('ACC-SINV-2021-00001', '!=sinv')) self.assertFalse(filter_match('ACC-SINV-2021-00001', ' >')) self.assertFalse(filter_match('ACC-SINV-2021-00001', '>aa')) self.assertFalse(filter_match('ACC-SINV-2021-00001', ' <')) self.assertFalse(filter_match('ACC-SINV-2021-00001', '< ')) self.assertFalse(filter_match('ACC-SINV-2021-00001', ' =')) self.assertFalse(filter_match('ACC-SINV-2021-00001', '=')) # Date - always match self.assertTrue(filter_match(datetime.date(2021, 3, 19), ' kdsjkldfs '))