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.

466 lines
18 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
  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 . import abstract_test
  7. from odoo.tests.common import TransactionCase
  8. class TestGeneralLedger(abstract_test.AbstractTest):
  9. """
  10. Technical tests for General Ledger Report.
  11. """
  12. def _getReportModel(self):
  13. return self.env['report_general_ledger_qweb']
  14. def _getQwebReportName(self):
  15. return 'account_financial_report_qweb.report_general_ledger_qweb'
  16. def _getXlsxReportName(self):
  17. return 'account_financial_report_qweb.report_general_ledger_xlsx'
  18. def _getXlsxReportActionName(self):
  19. return 'account_financial_report_qweb.' \
  20. 'action_report_general_ledger_xlsx'
  21. def _getReportTitle(self):
  22. return 'General Ledger'
  23. def _getBaseFilters(self):
  24. return {
  25. 'date_from': time.strftime('%Y-01-01'),
  26. 'date_to': time.strftime('%Y-12-31'),
  27. 'company_id': self.env.ref('base.main_company').id,
  28. 'fy_start_date': time.strftime('%Y-01-01'),
  29. }
  30. def _getAdditionalFiltersToBeTested(self):
  31. return [
  32. {'only_posted_moves': True},
  33. {'hide_account_balance_at_0': True},
  34. {'centralize': True},
  35. {'only_posted_moves': True, 'hide_account_balance_at_0': True},
  36. {'only_posted_moves': True, 'centralize': True},
  37. {'hide_account_balance_at_0': True, 'centralize': True},
  38. {
  39. 'only_posted_moves': True,
  40. 'hide_account_balance_at_0': True,
  41. 'centralize': True
  42. },
  43. ]
  44. class TestGeneralLedgerReport(TransactionCase):
  45. def setUp(self):
  46. super(TestGeneralLedgerReport, self).setUp()
  47. self.before_previous_fy_year = '2014-05-05'
  48. self.previous_fy_date_start = '2015-01-01'
  49. self.previous_fy_date_end = '2015-12-31'
  50. self.fy_date_start = '2016-01-01'
  51. self.fy_date_end = '2016-12-31'
  52. self.receivable_account = self.env['account.account'].search([
  53. ('user_type_id.name', '=', 'Receivable')
  54. ], limit=1)
  55. self.income_account = self.env['account.account'].search([
  56. ('user_type_id.name', '=', 'Income')
  57. ], limit=1)
  58. self.unaffected_account = self.env['account.account'].search([
  59. (
  60. 'user_type_id',
  61. '=',
  62. self.env.ref('account.data_unaffected_earnings').id
  63. )], limit=1)
  64. def _add_move(
  65. self,
  66. date,
  67. receivable_debit,
  68. receivable_credit,
  69. income_debit,
  70. income_credit,
  71. unaffected_debit=0,
  72. unaffected_credit=0
  73. ):
  74. move_name = 'expense accrual'
  75. journal = self.env['account.journal'].search([
  76. ('code', '=', 'MISC')])
  77. partner = self.env.ref('base.res_partner_12')
  78. move_vals = {
  79. 'journal_id': journal.id,
  80. 'partner_id': partner.id,
  81. 'name': move_name,
  82. 'date': date,
  83. 'line_ids': [
  84. (0, 0, {
  85. 'name': move_name,
  86. 'debit': receivable_debit,
  87. 'credit': receivable_credit,
  88. 'account_id': self.receivable_account.id}),
  89. (0, 0, {
  90. 'name': move_name,
  91. 'debit': income_debit,
  92. 'credit': income_credit,
  93. 'account_id': self.income_account.id}),
  94. (0, 0, {
  95. 'name': move_name,
  96. 'debit': unaffected_debit,
  97. 'credit': unaffected_credit,
  98. 'account_id': self.unaffected_account.id}),
  99. ]}
  100. move = self.env['account.move'].create(move_vals)
  101. move.post()
  102. def _get_report_lines(self, with_partners=False):
  103. company = self.env.ref('base.main_company')
  104. general_ledger = self.env['report_general_ledger_qweb'].create({
  105. 'date_from': self.fy_date_start,
  106. 'date_to': self.fy_date_end,
  107. 'only_posted_moves': True,
  108. 'hide_account_balance_at_0': False,
  109. 'company_id': company.id,
  110. 'fy_start_date': self.fy_date_start,
  111. })
  112. general_ledger.compute_data_for_report(
  113. with_line_details=True, with_partners=with_partners
  114. )
  115. lines = {}
  116. report_account_model = self.env['report_general_ledger_qweb_account']
  117. lines['receivable'] = report_account_model.search([
  118. ('report_id', '=', general_ledger.id),
  119. ('account_id', '=', self.receivable_account.id),
  120. ])
  121. lines['income'] = report_account_model.search([
  122. ('report_id', '=', general_ledger.id),
  123. ('account_id', '=', self.income_account.id),
  124. ])
  125. lines['unaffected'] = report_account_model.search([
  126. ('report_id', '=', general_ledger.id),
  127. ('account_id', '=', self.unaffected_account.id),
  128. ])
  129. if with_partners:
  130. report_partner_model = self.env[
  131. 'report_general_ledger_qweb_partner'
  132. ]
  133. lines['partner_receivable'] = report_partner_model.search([
  134. ('report_account_id', '=', lines['receivable'].id),
  135. ('partner_id', '=', self.env.ref('base.res_partner_12').id),
  136. ])
  137. return lines
  138. def test_01_account_balance(self):
  139. # Generate the general ledger line
  140. lines = self._get_report_lines()
  141. self.assertEqual(len(lines['receivable']), 0)
  142. self.assertEqual(len(lines['income']), 0)
  143. # Add a move at the previous day of the first day of fiscal year
  144. # to check the initial balance
  145. self._add_move(
  146. date=self.previous_fy_date_end,
  147. receivable_debit=1000,
  148. receivable_credit=0,
  149. income_debit=0,
  150. income_credit=1000
  151. )
  152. # Re Generate the general ledger line
  153. lines = self._get_report_lines()
  154. self.assertEqual(len(lines['receivable']), 1)
  155. self.assertEqual(len(lines['income']), 0)
  156. # Check the initial and final balance
  157. self.assertEqual(lines['receivable'].initial_debit, 1000)
  158. self.assertEqual(lines['receivable'].initial_credit, 0)
  159. self.assertEqual(lines['receivable'].initial_balance, 1000)
  160. self.assertEqual(lines['receivable'].final_debit, 1000)
  161. self.assertEqual(lines['receivable'].final_credit, 0)
  162. self.assertEqual(lines['receivable'].final_balance, 1000)
  163. # Add reversale move of the initial move the first day of fiscal year
  164. # to check the first day of fiscal year is not used
  165. # to compute the initial balance
  166. self._add_move(
  167. date=self.fy_date_start,
  168. receivable_debit=0,
  169. receivable_credit=1000,
  170. income_debit=1000,
  171. income_credit=0
  172. )
  173. # Re Generate the general ledger line
  174. lines = self._get_report_lines()
  175. self.assertEqual(len(lines['receivable']), 1)
  176. self.assertEqual(len(lines['income']), 1)
  177. # Check the initial and final balance
  178. self.assertEqual(lines['receivable'].initial_debit, 1000)
  179. self.assertEqual(lines['receivable'].initial_credit, 0)
  180. self.assertEqual(lines['receivable'].initial_balance, 1000)
  181. self.assertEqual(lines['receivable'].final_debit, 1000)
  182. self.assertEqual(lines['receivable'].final_credit, 1000)
  183. self.assertEqual(lines['receivable'].final_balance, 0)
  184. self.assertEqual(lines['income'].initial_debit, 0)
  185. self.assertEqual(lines['income'].initial_credit, 0)
  186. self.assertEqual(lines['income'].initial_balance, 0)
  187. self.assertEqual(lines['income'].final_debit, 1000)
  188. self.assertEqual(lines['income'].final_credit, 0)
  189. self.assertEqual(lines['income'].final_balance, 1000)
  190. # Add another move at the end day of fiscal year
  191. # to check that it correctly used on report
  192. self._add_move(
  193. date=self.fy_date_end,
  194. receivable_debit=0,
  195. receivable_credit=1000,
  196. income_debit=1000,
  197. income_credit=0
  198. )
  199. # Re Generate the general ledger line
  200. lines = self._get_report_lines()
  201. self.assertEqual(len(lines['receivable']), 1)
  202. self.assertEqual(len(lines['income']), 1)
  203. # Check the initial and final balance
  204. self.assertEqual(lines['receivable'].initial_debit, 1000)
  205. self.assertEqual(lines['receivable'].initial_credit, 0)
  206. self.assertEqual(lines['receivable'].initial_balance, 1000)
  207. self.assertEqual(lines['receivable'].final_debit, 1000)
  208. self.assertEqual(lines['receivable'].final_credit, 2000)
  209. self.assertEqual(lines['receivable'].final_balance, -1000)
  210. self.assertEqual(lines['income'].initial_debit, 0)
  211. self.assertEqual(lines['income'].initial_credit, 0)
  212. self.assertEqual(lines['income'].initial_balance, 0)
  213. self.assertEqual(lines['income'].final_debit, 2000)
  214. self.assertEqual(lines['income'].final_credit, 0)
  215. self.assertEqual(lines['income'].final_balance, 2000)
  216. def test_02_partner_balance(self):
  217. # Generate the general ledger line
  218. lines = self._get_report_lines(with_partners=True)
  219. self.assertEqual(len(lines['partner_receivable']), 0)
  220. # Add a move at the previous day of the first day of fiscal year
  221. # to check the initial balance
  222. self._add_move(
  223. date=self.previous_fy_date_end,
  224. receivable_debit=1000,
  225. receivable_credit=0,
  226. income_debit=0,
  227. income_credit=1000
  228. )
  229. # Re Generate the general ledger line
  230. lines = self._get_report_lines(with_partners=True)
  231. self.assertEqual(len(lines['partner_receivable']), 1)
  232. # Check the initial and final balance
  233. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  234. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  235. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  236. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  237. self.assertEqual(lines['partner_receivable'].final_credit, 0)
  238. self.assertEqual(lines['partner_receivable'].final_balance, 1000)
  239. # Add reversale move of the initial move the first day of fiscal year
  240. # to check the first day of fiscal year is not used
  241. # to compute the initial balance
  242. self._add_move(
  243. date=self.fy_date_start,
  244. receivable_debit=0,
  245. receivable_credit=1000,
  246. income_debit=1000,
  247. income_credit=0
  248. )
  249. # Re Generate the general ledger line
  250. lines = self._get_report_lines(with_partners=True)
  251. self.assertEqual(len(lines['partner_receivable']), 1)
  252. # Check the initial and final balance
  253. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  254. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  255. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  256. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  257. self.assertEqual(lines['partner_receivable'].final_credit, 1000)
  258. self.assertEqual(lines['partner_receivable'].final_balance, 0)
  259. # Add another move at the end day of fiscal year
  260. # to check that it correctly used on report
  261. self._add_move(
  262. date=self.fy_date_end,
  263. receivable_debit=0,
  264. receivable_credit=1000,
  265. income_debit=1000,
  266. income_credit=0
  267. )
  268. # Re Generate the general ledger line
  269. lines = self._get_report_lines(with_partners=True)
  270. self.assertEqual(len(lines['partner_receivable']), 1)
  271. # Check the initial and final balance
  272. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  273. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  274. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  275. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  276. self.assertEqual(lines['partner_receivable'].final_credit, 2000)
  277. self.assertEqual(lines['partner_receivable'].final_balance, -1000)
  278. def test_03_unaffected_account_balance(self):
  279. # Generate the general ledger line
  280. lines = self._get_report_lines()
  281. self.assertEqual(len(lines['unaffected']), 1)
  282. # Check the initial and final balance
  283. self.assertEqual(lines['unaffected'].initial_debit, 0)
  284. self.assertEqual(lines['unaffected'].initial_credit, 0)
  285. self.assertEqual(lines['unaffected'].initial_balance, 0)
  286. self.assertEqual(lines['unaffected'].final_debit, 0)
  287. self.assertEqual(lines['unaffected'].final_credit, 0)
  288. self.assertEqual(lines['unaffected'].final_balance, 0)
  289. # Add a move at the previous day of the first day of fiscal year
  290. # to check the initial balance
  291. self._add_move(
  292. date=self.previous_fy_date_end,
  293. receivable_debit=1000,
  294. receivable_credit=0,
  295. income_debit=0,
  296. income_credit=1000
  297. )
  298. # Re Generate the general ledger line
  299. lines = self._get_report_lines()
  300. self.assertEqual(len(lines['unaffected']), 1)
  301. # Check the initial and final balance
  302. self.assertEqual(lines['unaffected'].initial_debit, 0)
  303. self.assertEqual(lines['unaffected'].initial_credit, 0)
  304. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  305. self.assertEqual(lines['unaffected'].final_debit, -0)
  306. self.assertEqual(lines['unaffected'].final_credit, 0)
  307. self.assertEqual(lines['unaffected'].final_balance, -1000)
  308. # Add reversale move of the initial move the first day of fiscal year
  309. # to check the first day of fiscal year is not used
  310. # to compute the initial balance
  311. self._add_move(
  312. date=self.fy_date_start,
  313. receivable_debit=0,
  314. receivable_credit=0,
  315. income_debit=0,
  316. income_credit=1000,
  317. unaffected_debit=1000,
  318. unaffected_credit=0
  319. )
  320. # Re Generate the general ledger line
  321. lines = self._get_report_lines()
  322. self.assertEqual(len(lines['unaffected']), 1)
  323. # Check the initial and final balance
  324. self.assertEqual(lines['unaffected'].initial_debit, 0)
  325. self.assertEqual(lines['unaffected'].initial_credit, 0)
  326. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  327. self.assertEqual(lines['unaffected'].final_debit, 1000)
  328. self.assertEqual(lines['unaffected'].final_credit, 0)
  329. self.assertEqual(lines['unaffected'].final_balance, 0)
  330. # Add another move at the end day of fiscal year
  331. # to check that it correctly used on report
  332. self._add_move(
  333. date=self.fy_date_end,
  334. receivable_debit=3000,
  335. receivable_credit=0,
  336. income_debit=0,
  337. income_credit=0,
  338. unaffected_debit=0,
  339. unaffected_credit=3000
  340. )
  341. # Re Generate the general ledger line
  342. lines = self._get_report_lines()
  343. self.assertEqual(len(lines['unaffected']), 1)
  344. # Check the initial and final balance
  345. self.assertEqual(lines['unaffected'].initial_debit, 0)
  346. self.assertEqual(lines['unaffected'].initial_credit, 0)
  347. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  348. self.assertEqual(lines['unaffected'].final_debit, 1000)
  349. self.assertEqual(lines['unaffected'].final_credit, 3000)
  350. self.assertEqual(lines['unaffected'].final_balance, -3000)
  351. def test_04_unaffected_account_balance_2_years(self):
  352. # 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, 0)
  358. self.assertEqual(lines['unaffected'].initial_balance, 0)
  359. self.assertEqual(lines['unaffected'].final_debit, 0)
  360. self.assertEqual(lines['unaffected'].final_credit, 0)
  361. self.assertEqual(lines['unaffected'].final_balance, 0)
  362. # Add a move at any date 2 years before the balance
  363. # (to create an historic)
  364. self._add_move(
  365. date=self.before_previous_fy_year,
  366. receivable_debit=0,
  367. receivable_credit=1000,
  368. income_debit=1000,
  369. income_credit=0
  370. )
  371. # Re Generate the general ledger line
  372. lines = self._get_report_lines()
  373. self.assertEqual(len(lines['unaffected']), 1)
  374. # Check the initial and final balance
  375. self.assertEqual(lines['unaffected'].initial_debit, 0)
  376. self.assertEqual(lines['unaffected'].initial_credit, 0)
  377. self.assertEqual(lines['unaffected'].initial_balance, 1000)
  378. self.assertEqual(lines['unaffected'].final_debit, 0)
  379. self.assertEqual(lines['unaffected'].final_credit, 0)
  380. self.assertEqual(lines['unaffected'].final_balance, 1000)
  381. # Affect the company's result last year
  382. self._add_move(
  383. date=self.previous_fy_date_start,
  384. receivable_debit=1000,
  385. receivable_credit=0,
  386. income_debit=0,
  387. income_credit=0,
  388. unaffected_debit=0,
  389. unaffected_credit=1000
  390. )
  391. # Add another move last year to test the initial balance this year
  392. self._add_move(
  393. date=self.previous_fy_date_start,
  394. receivable_debit=0,
  395. receivable_credit=500,
  396. income_debit=500,
  397. income_credit=0,
  398. unaffected_debit=0,
  399. unaffected_credit=0
  400. )
  401. # Re Generate the general ledger line
  402. lines = self._get_report_lines()
  403. self.assertEqual(len(lines['unaffected']), 1)
  404. # Check the initial and final balance
  405. self.assertEqual(lines['unaffected'].initial_debit, 0)
  406. self.assertEqual(lines['unaffected'].initial_credit, 0)
  407. self.assertEqual(lines['unaffected'].initial_balance, 500)
  408. self.assertEqual(lines['unaffected'].final_debit, 0)
  409. self.assertEqual(lines['unaffected'].final_credit, 0)
  410. self.assertEqual(lines['unaffected'].final_balance, 500)