You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

554 lines
22 KiB

8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
  1. # -*- coding: utf-8 -*-
  2. # Author: Julien Coux
  3. # Copyright 2016 Camptocamp SA
  4. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  5. import time
  6. from odoo.api import Environment
  7. from odoo.tests import common
  8. from . import abstract_test_foreign_currency as a_t_f_c
  9. class TestGeneralLedger(a_t_f_c.AbstractTestForeignCurrency):
  10. """
  11. Technical tests for General Ledger Report.
  12. """
  13. def _getReportModel(self):
  14. return self.env['report_general_ledger_qweb']
  15. def _getQwebReportName(self):
  16. return 'account_financial_report_qweb.report_general_ledger_qweb'
  17. def _getXlsxReportName(self):
  18. return 'account_financial_report_qweb.report_general_ledger_xlsx'
  19. def _getXlsxReportActionName(self):
  20. return 'account_financial_report_qweb.' \
  21. 'action_report_general_ledger_xlsx'
  22. def _getReportTitle(self):
  23. return 'General Ledger'
  24. def _getBaseFilters(self):
  25. return {
  26. 'date_from': time.strftime('%Y-01-01'),
  27. 'date_to': time.strftime('%Y-12-31'),
  28. 'company_id': self.company.id,
  29. 'fy_start_date': time.strftime('%Y-01-01'),
  30. 'foreign_currency': True,
  31. }
  32. def _getAdditionalFiltersToBeTested(self):
  33. additional_filters = [
  34. {'only_posted_moves': True},
  35. {'hide_account_at_0': True},
  36. {'centralize': True},
  37. {'only_posted_moves': True, 'hide_account_at_0': True},
  38. {'only_posted_moves': True, 'centralize': True},
  39. {'hide_account_at_0': True, 'centralize': True},
  40. {
  41. 'only_posted_moves': True,
  42. 'hide_account_at_0': True,
  43. 'centralize': True
  44. },
  45. ]
  46. # Add `show_analytic_tags` filter on each cases
  47. additional_filters_with_show_tags = []
  48. for additional_filter in additional_filters:
  49. additional_filter['show_analytic_tags'] = True
  50. additional_filters_with_show_tags.append(
  51. additional_filter
  52. )
  53. additional_filters += additional_filters_with_show_tags
  54. # Add `filter_analytic_tag_ids` filter on each cases
  55. analytic_tag = self.env['account.analytic.tag'].create({
  56. 'name': 'TEST tag'
  57. })
  58. # Define all move lines on this tag
  59. # (this test just check with the all filters, all works technically)
  60. move_lines = self.env['account.move.line'].search([])
  61. move_lines.write({
  62. 'analytic_tag_ids': [(6, False, analytic_tag.ids)],
  63. })
  64. additional_filters_with_filter_tags = []
  65. for additional_filter in additional_filters:
  66. additional_filter['filter_analytic_tag_ids'] = [
  67. (6, False, analytic_tag.ids)
  68. ]
  69. additional_filters_with_filter_tags.append(
  70. additional_filter
  71. )
  72. additional_filters += additional_filters_with_filter_tags
  73. return additional_filters
  74. @common.at_install(False)
  75. @common.post_install(True)
  76. class TestGeneralLedgerReport(common.TransactionCase):
  77. def setUp(self):
  78. super(TestGeneralLedgerReport, self).setUp()
  79. self.before_previous_fy_year = '2014-05-05'
  80. self.previous_fy_date_start = '2015-01-01'
  81. self.previous_fy_date_end = '2015-12-31'
  82. self.fy_date_start = '2016-01-01'
  83. self.fy_date_end = '2016-12-31'
  84. self.receivable_account = self.env['account.account'].search([
  85. ('user_type_id.name', '=', 'Receivable')
  86. ], limit=1)
  87. self.income_account = self.env['account.account'].search([
  88. ('user_type_id.name', '=', 'Income')
  89. ], limit=1)
  90. self.unaffected_account = self.env['account.account'].search([
  91. (
  92. 'user_type_id',
  93. '=',
  94. self.env.ref('account.data_unaffected_earnings').id
  95. )], limit=1)
  96. def _add_move(
  97. self,
  98. date,
  99. receivable_debit,
  100. receivable_credit,
  101. income_debit,
  102. income_credit,
  103. unaffected_debit=0,
  104. unaffected_credit=0
  105. ):
  106. move_name = 'expense accrual'
  107. journal = self.env['account.journal'].search([
  108. ('code', '=', 'MISC')])
  109. partner = self.env.ref('base.res_partner_12')
  110. move_vals = {
  111. 'journal_id': journal.id,
  112. 'partner_id': partner.id,
  113. 'name': move_name,
  114. 'date': date,
  115. 'line_ids': [
  116. (0, 0, {
  117. 'name': move_name,
  118. 'debit': receivable_debit,
  119. 'credit': receivable_credit,
  120. 'account_id': self.receivable_account.id}),
  121. (0, 0, {
  122. 'name': move_name,
  123. 'debit': income_debit,
  124. 'credit': income_credit,
  125. 'account_id': self.income_account.id}),
  126. (0, 0, {
  127. 'name': move_name,
  128. 'debit': unaffected_debit,
  129. 'credit': unaffected_credit,
  130. 'account_id': self.unaffected_account.id}),
  131. ]}
  132. move = self.env['account.move'].create(move_vals)
  133. move.post()
  134. def _get_report_lines(self, with_partners=False):
  135. company = self.env.ref('base.main_company')
  136. general_ledger = self.env['report_general_ledger_qweb'].create({
  137. 'date_from': self.fy_date_start,
  138. 'date_to': self.fy_date_end,
  139. 'only_posted_moves': True,
  140. 'hide_account_at_0': False,
  141. 'company_id': company.id,
  142. 'fy_start_date': self.fy_date_start,
  143. })
  144. general_ledger.compute_data_for_report(
  145. with_line_details=True, with_partners=with_partners
  146. )
  147. lines = {}
  148. report_account_model = self.env['report_general_ledger_qweb_account']
  149. lines['receivable'] = report_account_model.search([
  150. ('report_id', '=', general_ledger.id),
  151. ('account_id', '=', self.receivable_account.id),
  152. ])
  153. lines['income'] = report_account_model.search([
  154. ('report_id', '=', general_ledger.id),
  155. ('account_id', '=', self.income_account.id),
  156. ])
  157. lines['unaffected'] = report_account_model.search([
  158. ('report_id', '=', general_ledger.id),
  159. ('account_id', '=', self.unaffected_account.id),
  160. ])
  161. if with_partners:
  162. report_partner_model = self.env[
  163. 'report_general_ledger_qweb_partner'
  164. ]
  165. lines['partner_receivable'] = report_partner_model.search([
  166. ('report_account_id', '=', lines['receivable'].id),
  167. ('partner_id', '=', self.env.ref('base.res_partner_12').id),
  168. ])
  169. return lines
  170. def test_01_account_balance(self):
  171. # Generate the general ledger line
  172. lines = self._get_report_lines()
  173. self.assertEqual(len(lines['receivable']), 0)
  174. self.assertEqual(len(lines['income']), 0)
  175. # Add a move at the previous day of the first day of fiscal year
  176. # to check the initial balance
  177. self._add_move(
  178. date=self.previous_fy_date_end,
  179. receivable_debit=1000,
  180. receivable_credit=0,
  181. income_debit=0,
  182. income_credit=1000
  183. )
  184. # Re Generate the general ledger line
  185. lines = self._get_report_lines()
  186. self.assertEqual(len(lines['receivable']), 1)
  187. self.assertEqual(len(lines['income']), 0)
  188. # Check the initial and final balance
  189. self.assertEqual(lines['receivable'].initial_debit, 1000)
  190. self.assertEqual(lines['receivable'].initial_credit, 0)
  191. self.assertEqual(lines['receivable'].initial_balance, 1000)
  192. self.assertEqual(lines['receivable'].final_debit, 1000)
  193. self.assertEqual(lines['receivable'].final_credit, 0)
  194. self.assertEqual(lines['receivable'].final_balance, 1000)
  195. # Add reversale move of the initial move the first day of fiscal year
  196. # to check the first day of fiscal year is not used
  197. # to compute the initial balance
  198. self._add_move(
  199. date=self.fy_date_start,
  200. receivable_debit=0,
  201. receivable_credit=1000,
  202. income_debit=1000,
  203. income_credit=0
  204. )
  205. # Re Generate the general ledger line
  206. lines = self._get_report_lines()
  207. self.assertEqual(len(lines['receivable']), 1)
  208. self.assertEqual(len(lines['income']), 1)
  209. # Check the initial and final balance
  210. self.assertEqual(lines['receivable'].initial_debit, 1000)
  211. self.assertEqual(lines['receivable'].initial_credit, 0)
  212. self.assertEqual(lines['receivable'].initial_balance, 1000)
  213. self.assertEqual(lines['receivable'].final_debit, 1000)
  214. self.assertEqual(lines['receivable'].final_credit, 1000)
  215. self.assertEqual(lines['receivable'].final_balance, 0)
  216. self.assertEqual(lines['income'].initial_debit, 0)
  217. self.assertEqual(lines['income'].initial_credit, 0)
  218. self.assertEqual(lines['income'].initial_balance, 0)
  219. self.assertEqual(lines['income'].final_debit, 1000)
  220. self.assertEqual(lines['income'].final_credit, 0)
  221. self.assertEqual(lines['income'].final_balance, 1000)
  222. # Add another move at the end day of fiscal year
  223. # to check that it correctly used on report
  224. self._add_move(
  225. date=self.fy_date_end,
  226. receivable_debit=0,
  227. receivable_credit=1000,
  228. income_debit=1000,
  229. income_credit=0
  230. )
  231. # Re Generate the general ledger line
  232. lines = self._get_report_lines()
  233. self.assertEqual(len(lines['receivable']), 1)
  234. self.assertEqual(len(lines['income']), 1)
  235. # Check the initial and final balance
  236. self.assertEqual(lines['receivable'].initial_debit, 1000)
  237. self.assertEqual(lines['receivable'].initial_credit, 0)
  238. self.assertEqual(lines['receivable'].initial_balance, 1000)
  239. self.assertEqual(lines['receivable'].final_debit, 1000)
  240. self.assertEqual(lines['receivable'].final_credit, 2000)
  241. self.assertEqual(lines['receivable'].final_balance, -1000)
  242. self.assertEqual(lines['income'].initial_debit, 0)
  243. self.assertEqual(lines['income'].initial_credit, 0)
  244. self.assertEqual(lines['income'].initial_balance, 0)
  245. self.assertEqual(lines['income'].final_debit, 2000)
  246. self.assertEqual(lines['income'].final_credit, 0)
  247. self.assertEqual(lines['income'].final_balance, 2000)
  248. def test_02_partner_balance(self):
  249. # Generate the general ledger line
  250. lines = self._get_report_lines(with_partners=True)
  251. self.assertEqual(len(lines['partner_receivable']), 0)
  252. # Add a move at the previous day of the first day of fiscal year
  253. # to check the initial balance
  254. self._add_move(
  255. date=self.previous_fy_date_end,
  256. receivable_debit=1000,
  257. receivable_credit=0,
  258. income_debit=0,
  259. income_credit=1000
  260. )
  261. # Re Generate the general ledger line
  262. lines = self._get_report_lines(with_partners=True)
  263. self.assertEqual(len(lines['partner_receivable']), 1)
  264. # Check the initial and final balance
  265. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  266. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  267. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  268. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  269. self.assertEqual(lines['partner_receivable'].final_credit, 0)
  270. self.assertEqual(lines['partner_receivable'].final_balance, 1000)
  271. # Add reversale move of the initial move the first day of fiscal year
  272. # to check the first day of fiscal year is not used
  273. # to compute the initial balance
  274. self._add_move(
  275. date=self.fy_date_start,
  276. receivable_debit=0,
  277. receivable_credit=1000,
  278. income_debit=1000,
  279. income_credit=0
  280. )
  281. # Re Generate the general ledger line
  282. lines = self._get_report_lines(with_partners=True)
  283. self.assertEqual(len(lines['partner_receivable']), 1)
  284. # Check the initial and final balance
  285. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  286. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  287. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  288. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  289. self.assertEqual(lines['partner_receivable'].final_credit, 1000)
  290. self.assertEqual(lines['partner_receivable'].final_balance, 0)
  291. # Add another move at the end day of fiscal year
  292. # to check that it correctly used on report
  293. self._add_move(
  294. date=self.fy_date_end,
  295. receivable_debit=0,
  296. receivable_credit=1000,
  297. income_debit=1000,
  298. income_credit=0
  299. )
  300. # Re Generate the general ledger line
  301. lines = self._get_report_lines(with_partners=True)
  302. self.assertEqual(len(lines['partner_receivable']), 1)
  303. # Check the initial and final balance
  304. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  305. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  306. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  307. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  308. self.assertEqual(lines['partner_receivable'].final_credit, 2000)
  309. self.assertEqual(lines['partner_receivable'].final_balance, -1000)
  310. def test_03_unaffected_account_balance(self):
  311. # Generate the general ledger line
  312. lines = self._get_report_lines()
  313. self.assertEqual(len(lines['unaffected']), 1)
  314. # Check the initial and final balance
  315. self.assertEqual(lines['unaffected'].initial_debit, 0)
  316. self.assertEqual(lines['unaffected'].initial_credit, 0)
  317. self.assertEqual(lines['unaffected'].initial_balance, 0)
  318. self.assertEqual(lines['unaffected'].final_debit, 0)
  319. self.assertEqual(lines['unaffected'].final_credit, 0)
  320. self.assertEqual(lines['unaffected'].final_balance, 0)
  321. # Add a move at the previous day of the first day of fiscal year
  322. # to check the initial balance
  323. self._add_move(
  324. date=self.previous_fy_date_end,
  325. receivable_debit=1000,
  326. receivable_credit=0,
  327. income_debit=0,
  328. income_credit=1000
  329. )
  330. # Re Generate the general ledger line
  331. lines = self._get_report_lines()
  332. self.assertEqual(len(lines['unaffected']), 1)
  333. # Check the initial and final balance
  334. self.assertEqual(lines['unaffected'].initial_debit, 0)
  335. self.assertEqual(lines['unaffected'].initial_credit, 1000)
  336. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  337. self.assertEqual(lines['unaffected'].final_debit, 0)
  338. self.assertEqual(lines['unaffected'].final_credit, 1000)
  339. self.assertEqual(lines['unaffected'].final_balance, -1000)
  340. # Add reversale move of the initial move the first day of fiscal year
  341. # to check the first day of fiscal year is not used
  342. # to compute the initial balance
  343. self._add_move(
  344. date=self.fy_date_start,
  345. receivable_debit=0,
  346. receivable_credit=0,
  347. income_debit=0,
  348. income_credit=1000,
  349. unaffected_debit=1000,
  350. unaffected_credit=0
  351. )
  352. # Re Generate the general ledger line
  353. lines = self._get_report_lines()
  354. self.assertEqual(len(lines['unaffected']), 1)
  355. # Check the initial and final balance
  356. self.assertEqual(lines['unaffected'].initial_debit, 0)
  357. self.assertEqual(lines['unaffected'].initial_credit, 1000)
  358. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  359. self.assertEqual(lines['unaffected'].final_debit, 1000)
  360. self.assertEqual(lines['unaffected'].final_credit, 1000)
  361. self.assertEqual(lines['unaffected'].final_balance, 0)
  362. # Add another move at the end day of fiscal year
  363. # to check that it correctly used on report
  364. self._add_move(
  365. date=self.fy_date_end,
  366. receivable_debit=3000,
  367. receivable_credit=0,
  368. income_debit=0,
  369. income_credit=0,
  370. unaffected_debit=0,
  371. unaffected_credit=3000
  372. )
  373. # Re Generate the general ledger line
  374. lines = self._get_report_lines()
  375. self.assertEqual(len(lines['unaffected']), 1)
  376. # Check the initial and final balance
  377. self.assertEqual(lines['unaffected'].initial_debit, 0)
  378. self.assertEqual(lines['unaffected'].initial_credit, 1000)
  379. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  380. self.assertEqual(lines['unaffected'].final_debit, 1000)
  381. self.assertEqual(lines['unaffected'].final_credit, 4000)
  382. self.assertEqual(lines['unaffected'].final_balance, -3000)
  383. def test_04_unaffected_account_balance_2_years(self):
  384. # Generate the general ledger line
  385. lines = self._get_report_lines()
  386. self.assertEqual(len(lines['unaffected']), 1)
  387. # Check the initial and final balance
  388. self.assertEqual(lines['unaffected'].initial_debit, 0)
  389. self.assertEqual(lines['unaffected'].initial_credit, 0)
  390. self.assertEqual(lines['unaffected'].initial_balance, 0)
  391. self.assertEqual(lines['unaffected'].final_debit, 0)
  392. self.assertEqual(lines['unaffected'].final_credit, 0)
  393. self.assertEqual(lines['unaffected'].final_balance, 0)
  394. # Add a move at any date 2 years before the balance
  395. # (to create an historic)
  396. self._add_move(
  397. date=self.before_previous_fy_year,
  398. receivable_debit=0,
  399. receivable_credit=1000,
  400. income_debit=1000,
  401. income_credit=0
  402. )
  403. # Re Generate the general ledger line
  404. lines = self._get_report_lines()
  405. self.assertEqual(len(lines['unaffected']), 1)
  406. # Check the initial and final balance
  407. self.assertEqual(lines['unaffected'].initial_debit, 1000)
  408. self.assertEqual(lines['unaffected'].initial_credit, 0)
  409. self.assertEqual(lines['unaffected'].initial_balance, 1000)
  410. self.assertEqual(lines['unaffected'].final_debit, 1000)
  411. self.assertEqual(lines['unaffected'].final_credit, 0)
  412. self.assertEqual(lines['unaffected'].final_balance, 1000)
  413. # Affect the company's result last year
  414. self._add_move(
  415. date=self.previous_fy_date_start,
  416. receivable_debit=1000,
  417. receivable_credit=0,
  418. income_debit=0,
  419. income_credit=0,
  420. unaffected_debit=0,
  421. unaffected_credit=1000
  422. )
  423. # Add another move last year to test the initial balance this year
  424. self._add_move(
  425. date=self.previous_fy_date_start,
  426. receivable_debit=0,
  427. receivable_credit=500,
  428. income_debit=500,
  429. income_credit=0,
  430. unaffected_debit=0,
  431. unaffected_credit=0
  432. )
  433. # Re Generate the general ledger line
  434. lines = self._get_report_lines()
  435. self.assertEqual(len(lines['unaffected']), 1)
  436. # Check the initial and final balance
  437. self.assertEqual(lines['unaffected'].initial_debit, 500)
  438. self.assertEqual(lines['unaffected'].initial_credit, 0)
  439. self.assertEqual(lines['unaffected'].initial_balance, 500)
  440. self.assertEqual(lines['unaffected'].final_debit, 500)
  441. self.assertEqual(lines['unaffected'].final_credit, 0)
  442. self.assertEqual(lines['unaffected'].final_balance, 500)
  443. def test_partner_filter(self):
  444. partner_1 = self.env.ref('base.res_partner_1')
  445. partner_2 = self.env.ref('base.res_partner_2')
  446. partner_3 = self.env.ref('base.res_partner_3')
  447. partner_4 = self.env.ref('base.res_partner_4')
  448. partner_1.write({'is_company': False,
  449. 'parent_id': partner_2.id})
  450. partner_3.write({'is_company': False})
  451. expected_list = [partner_2.id, partner_3.id, partner_4.id]
  452. context = {'active_ids': [
  453. partner_1.id, partner_2.id, partner_3.id, partner_4.id
  454. ],
  455. 'active_model': 'res.partner'}
  456. wizard = self.env["general.ledger.report.wizard"].with_context(context)
  457. self.assertEqual(wizard._default_partners(), expected_list)
  458. def test_validate_date(self):
  459. company_id = self.env.ref('base.main_company')
  460. company_id.write({
  461. 'fiscalyear_last_day': 31,
  462. 'fiscalyear_last_month': 12,
  463. })
  464. cr = self.registry.cursor()
  465. user = self.env.ref('base.user_root').with_context({
  466. 'company_id': company_id.id})
  467. env = Environment(cr, user.id, {})
  468. wizard = env["general.ledger.report.wizard"]
  469. self.assertEqual(wizard._init_date_from(),
  470. time.strftime('%Y') + '-01-01')
  471. def test_validate_date_range(self):
  472. rangetype = self.env['date.range.type'].create({
  473. 'name': 'Fiscal year',
  474. 'company_id': False,
  475. 'allow_overlap': False
  476. })
  477. dr = self.env['date.range'].create({
  478. 'name': 'FS2015',
  479. 'date_start': '2018-01-01',
  480. 'date_end': '2018-12-31',
  481. 'type_id': rangetype.id,
  482. })
  483. wizard = self.env["general.ledger.report.wizard"].create({
  484. 'date_range_id': dr.id})
  485. wizard.onchange_date_range_id()
  486. self.assertEqual(wizard.date_from, '2018-01-01')
  487. self.assertEqual(wizard.date_to, '2018-12-31')