2021-04-09 00:23:08 +00:00
|
|
|
import datetime
|
|
|
|
import json
|
|
|
|
import os
|
2021-04-10 00:31:16 +00:00
|
|
|
import unittest
|
2021-09-02 11:14:59 +00:00
|
|
|
|
2021-04-09 00:23:08 +00:00
|
|
|
import frappe
|
2021-04-10 00:31:16 +00:00
|
|
|
from frappe.utils import (
|
|
|
|
add_to_date,
|
|
|
|
get_first_day,
|
|
|
|
get_last_day,
|
|
|
|
get_year_ending,
|
|
|
|
get_year_start,
|
|
|
|
getdate,
|
2021-09-02 11:14:59 +00:00
|
|
|
)
|
|
|
|
|
2021-04-08 22:19:31 +00:00
|
|
|
from .tax_detail import filter_match, save_custom_report
|
2021-03-19 23:05:19 +00:00
|
|
|
|
2021-09-02 11:14:59 +00:00
|
|
|
|
2021-03-19 23:05:19 +00:00
|
|
|
class TestTaxDetail(unittest.TestCase):
|
2021-04-08 22:19:31 +00:00
|
|
|
def load_testdocs(self):
|
2021-04-12 13:03:09 +00:00
|
|
|
from erpnext.accounts.utils import FiscalYearError, get_fiscal_year
|
2021-04-08 22:19:31 +00:00
|
|
|
datapath, _ = os.path.splitext(os.path.realpath(__file__))
|
|
|
|
with open(datapath + '.json', 'r') as fp:
|
2021-04-10 00:31:16 +00:00
|
|
|
docs = json.load(fp)
|
2021-04-08 22:19:31 +00:00
|
|
|
|
|
|
|
now = getdate()
|
|
|
|
self.from_date = get_first_day(now)
|
|
|
|
self.to_date = get_last_day(now)
|
|
|
|
|
2021-04-12 13:03:09 +00:00
|
|
|
try:
|
|
|
|
get_fiscal_year(now, company="_T")
|
|
|
|
except FiscalYearError:
|
2021-04-10 18:59:57 +00:00
|
|
|
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
|
|
|
|
|
2021-04-10 00:31:16 +00:00
|
|
|
docs = [{
|
2021-04-10 02:27:00 +00:00
|
|
|
"abbr": "_T",
|
|
|
|
"company_name": "_T",
|
|
|
|
"country": "United Kingdom",
|
|
|
|
"default_currency": "GBP",
|
|
|
|
"doctype": "Company",
|
|
|
|
"name": "_T"
|
2021-04-10 00:31:16 +00:00
|
|
|
}] + docs
|
|
|
|
|
|
|
|
for doc in docs:
|
2021-04-08 22:19:31 +00:00
|
|
|
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()
|
2021-04-09 00:23:08 +00:00
|
|
|
except frappe.exceptions.DuplicateEntryError:
|
2021-04-08 22:19:31 +00:00
|
|
|
pass
|
|
|
|
|
2021-04-10 00:31:16 +00:00
|
|
|
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)
|
|
|
|
|
2021-04-10 20:32:22 +00:00
|
|
|
def rm_testdocs(self):
|
2021-04-08 22:19:31 +00:00
|
|
|
"Remove the Company and all data"
|
2021-05-29 17:48:36 +00:00
|
|
|
from erpnext.setup.doctype.company.company import create_transaction_deletion_request
|
|
|
|
create_transaction_deletion_request(self.company.name)
|
2021-04-08 22:19:31 +00:00
|
|
|
|
|
|
|
def test_report(self):
|
2021-04-10 20:32:22 +00:00
|
|
|
self.load_testdocs()
|
|
|
|
self.load_defcols()
|
2021-04-08 22:19:31 +00:00
|
|
|
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,
|
2021-04-10 00:31:16 +00:00
|
|
|
'company': self.company.name,
|
2021-04-08 22:19:31 +00:00
|
|
|
'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])
|
2021-03-19 23:05:19 +00:00
|
|
|
|
2021-04-10 20:32:22 +00:00
|
|
|
self.rm_testdocs()
|
|
|
|
|
2021-03-19 23:05:19 +00:00
|
|
|
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, '<jjj'))
|
|
|
|
self.assertTrue(filter_match(None, ' : '))
|
|
|
|
self.assertTrue(filter_match(None, ':56'))
|
|
|
|
self.assertTrue(filter_match(None, ':de'))
|
|
|
|
self.assertFalse(filter_match(None, '3.4'))
|
|
|
|
self.assertFalse(filter_match(None, '='))
|
|
|
|
self.assertFalse(filter_match(None, '=3.4'))
|
|
|
|
self.assertFalse(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 '))
|