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.

552 lines
22 KiB

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